HarmonyOS h5拉起系统扫码页面的demo

HarmonyOS h5拉起系统扫码页面的demo。

HarmonyOS
2024-11-05 10:42:39
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
Heiang

可参考下述demo进行扫码服务编写,如果是原生调用扫码页面的话,直接调用scan()函数即。

// WebComponent.ets: 
import web_webview from '@ohos.web.webview' 
import { scanCore, scanBarcode } from '@kit.ScanKit'; 
// 导入默认界面需要的日志模块和错误码模块 
import { hilog } from '@kit.PerformanceAnalysisKit'; 
import { BusinessError } from '@kit.BasicServicesKit'; 
 
let options: scanBarcode.ScanOptions = { 
  scanTypes: [scanCore.ScanType.ALL], 
  enableMultiMode: true, 
  enableAlbum: true 
}; 
 
class TestClass { 
  // arkts h5都用await保障执行顺序 
  async scan(): Promise<string> { 
    let scanResult = await scanBarcode.startScanForResult(getContext(this), options) 
    // 收到扫码结果后返回 
    hilog.info(0x0001, '[Scan CPSample]', 'Promise scan result: %{public}s', JSON.stringify(scanResult)); 
    return scanResult.originalValue; 
  } 
} 
 
@Entry 
@Component 
export struct PageWeb { 
  readonly webUrl: string | Resource = 'www.harmonyOS.com' 
  readonly controller: WebviewController = new web_webview.WebviewController() 
  userAgentAlreadySet: boolean = false 
  @State customUserAgent?: string = undefined 
  @State testObj: TestClass = new TestClass(); 
 
  build() { 
    if (this.customUserAgent) { 
      Column() { 
 
 
        Web({ src: $rawfile('index.html'), controller: this.controller }) 
          .domStorageAccess(true) 
          .javaScriptProxy({ 
            object: this.testObj, 
            name: "testObjName", 
            methodList: ["scan"], 
            controller: this.controller 
          }) 
 
      } 
    } 
  } 
 
  aboutToAppear(): void { 
    // 模拟异步构建 customUserAgent 过程 
    setTimeout(() => this.customUserAgent = 'ua/value', 200) 
  } 
 
  applyCustomUserAgent(): void { 
    this.userAgentAlreadySet = true 
    let defaultUserAgent = this.controller.getUserAgent() 
    this.controller.setCustomUserAgent(defaultUserAgent + ' ' + this.customUserAgent) 
    this.controller.loadUrl(this.webUrl) 
  } 
 
  onBackPress(): boolean | void { 
    // 自定义页面返回逻辑 
    // if (this.controller.accessBackward()) { 
    // this.controller.backward() 
    // return true 
    // } 
    return true; 
  } 
} 
<!-- index.html --> 
  <!DOCTYPE html> 
  <html> 
  <body> 
  <button type="button" onclick="callArkTS()">Click Me!</button> 
  <p id="demo"></p> 
  <script> 
  async function callArkTS() { 
    let str = await testObjName.scan(); 
    document.getElementById("demo").innerHTML = str; 
    console.info('ArkTS Hello World! :' + str); 
  } 
  </script> 
  </body> 
  </html>
分享
微博
QQ
微信
回复
2024-11-05 18:06:13
相关问题
HarmonyOS H5拉起系统相机的样例代码
259浏览 • 1回复 待解决
HarmonyOS web组件加载h5h5拉起摄像头
589浏览 • 1回复 待解决
HarmonyOS H5如何复用?
185浏览 • 1回复 待解决
HarmonyOS 应用涉及H5,如何使用?
226浏览 • 1回复 待解决
H5原生调JSbrige的demo示例
205浏览 • 1回复 待解决
HarmonyOS H5与应用侧数据交互的Demo
565浏览 • 1回复 待解决
HarmonyOS h5页面缩放问题
573浏览 • 0回复 待解决
Web能直接加载h5吗?
3061浏览 • 2回复 待解决
跨平台开发,h5怎么调试?
232浏览 • 1回复 待解决
H5通过url scheme拉起对应应用
549浏览 • 1回复 待解决
如何调试H5,有人知道吗?
1616浏览 • 1回复 待解决
HarmonyOS h5原生交互、页面状态机
44浏览 • 1回复 待解决