【HarmonyOS】纯血鸿蒙真实项目开辟---履历总结贴

打印 上一主题 下一主题

主题 998|帖子 998|积分 2994

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
项目场景:

将已有的Web网页接入到原生App。
涉及到一些网页回退、webviewController实行时机报错1710000001、位置定位数据获取拉起呼叫页面系统分享本领使用等。

题目描述


  • 我们在选项卡组件中,在每个TabContent内容页中使用web组件加载网页。
    在最开始接入操作时,出现了Web组件加载某个页面,出现白屏、页面显示不出来。
办理方案:

颠末对题目定位,发现需要设置是否开启文档对象模子存储接口(DOM Storage API)权限,默认未开启
  1. Web({ src: this.webSrc, controller: this.webviewController })
  2.   .domStorageAccess(true);
复制代码
题目描述


  • 每个TabContent内容页中使用web组件加载的网页,会涉及到一些页面的返回。如果是用户点击返回,网页端会举行回退操作,若用户使用侧滑返回网页端无法检测,会直接退出应用。
办理方案:

为了办理这个题目,我查阅到了有关侧滑返回或点击返回按钮时触发的自定义组件生命周期onBackPress(仅@Entry装饰的自定义组件生效)
  1. @Entry
  2. @Component
  3. struct IndexComponent {
  4.   @State textColor: Color = Color.Black;
  5.   onBackPress() {
  6.     this.textColor = Color.Red;
  7.     console.info('IndexComponent onBackPress');
  8.   }
  9.   build() {
  10.     Column() {
  11.       Text('Hello World')
  12.         .fontColor(this.textColor)
  13.         .fontSize(30)
  14.         .margin(30)
  15.     }.width('100%')
  16.   }
  17. }
复制代码
  返回true表示页面自己处理返回逻辑,不举行页面路由;返回false表示使用默认的路由返回逻辑,不设置返回值按照false处理。
  重点:在每个TabContent内容页加载的@Entry页面里,使用onBackPress是不生效的。我们只能在Tab所在的@Entry页面里,使用onBackPress才会生效。
为了控制TabContent中的Web页面回退,我们需要在Tab所在的页面里创建webviewController并将它通报给子组件。

  1. 父组件示例代码:
  2. import { Page1, Page2 } from './Page1'
  3. @Entry
  4. @Component
  5. struct demo {
  6.   //controller创建
  7.   @Provide webcontroller1: webview.WebviewController = new webview.WebviewController();
  8.   @Provide webcontroller2: webview.WebviewController = new webview.WebviewController();
  9.   //返回逻辑
  10.   onBackPress() {
  11.     if (this.webcontroller1.accessStep(-1)) {
  12.       this.webcontroller1.backward()
  13.       // 执行用户自定义返回逻辑
  14.       return true;
  15.     } else if (this.webcontroller2.accessStep(-1)) {
  16.       this.webcontroller2.backward();
  17.       // 执行用户自定义返回逻辑
  18.       return true;
  19.     }  else {
  20.       //执行系统默认返回逻辑,返回上一个page页
  21.       return false;
  22.     }
  23.   }
  24.   build() {
  25.     Tabs(){
  26.       TabContent(){
  27.         Page1()
  28.       }.tabBar('示例一')
  29.       TabContent(){
  30.         Page2()
  31.       }.tabBar('示例二')
  32.     }
  33.   }
  34. }
复制代码
  1. 子组件示例代码:
  2. import { webview } from '@kit.ArkWeb'
  3. @Entry
  4. @Component
  5. export struct Page1/2 {
  6. @Consume webcontroller1/2:webview.WebviewController
  7. build() {
  8.    RelativeContainer() {
  9.      Web({src:'https://www.baidu.com',controller:this.webcontroller1/2})
  10.        .domStorageAccess(true)
  11.    }
  12.    .height('100%')
  13.    .width('100%')
  14. }
  15. }
复制代码
题目描述


  • 因为每个Web页面的控制器是由父组件传入的,我们在使用时可能会出现710000001的报错,经查阅论坛发现,该报错缘故原由是Web组件还未创建,我们的WebviewController控制器先实行了。
   高发于在emitter中调用WebviewController控制器,只管避免在emitter中使用,若必须使用参照下面的办理方案
  办理方案:

办理这个题目,我并没有发现可以同一办理各种情况的方法。以下有多种办理方法:


  • [1] 在web组件的生命周期onPageEnd中使用控制器
  • [2]在onControllerAttached()这一回调方法中使用控制器
  • [3]在onDisAppear中使用控制器
题目描述


  • 我们在一些场景下可能会需要用户的具体位置,以下是关于用户授权和逆地址编码转化,获取地址位置描述的方案总结。
办理方案:

  1. 获取用户位置授权
  2.   onClickGetLocation = async () => {
  3.     //首次权限请求
  4.     if (this.step == 0) {
  5.       const steps = await abilityAccessCtrl.createAtManager()
  6.         .requestPermissionsFromUser(getContext(),
  7.           ['ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'])
  8.       this.step++
  9.     }
  10.     // 二次请求用户同意权限
  11.     await this.checkPermissions()
  12.     //获取当前位置
  13.     let Location = await geoLocationManager.getCurrentLocation();
  14.     await this.locationChange(Location)
  15.     return JSON.stringify(this.returnInfor)
  16.   }
复制代码
  1. 若用户拒绝定位权限二次拉起
  2.   async checkPermissions() {
  3.     let grantStatus1: boolean = await WebUtils.checkPermissionGrant('ohos.permission.LOCATION') ===
  4.     abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED; // 获取精确定位权限状态
  5.     let grantStatus2: boolean = await WebUtils.checkPermissionGrant('ohos.permission.APPROXIMATELY_LOCATION') ===
  6.     abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED; // 获取模糊定位权限状态
  7.     // 精确定位权限只能跟模糊定位权限一起申请,或者已经有模糊定位权限才能申请精确定位权限
  8.     if (!grantStatus2 && !grantStatus1) {
  9.       // 用户拒绝二次拉起弹窗
  10.       let atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager();
  11.       let context: Context = getContext(this) as common.UIAbilityContext;
  12.       await atManager.requestPermissionsFromUser(context,
  13.         ['ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'])
  14.       await atManager.requestPermissionOnSetting(context, ['ohos.permission.APPROXIMATELY_LOCATION'])
  15.         .then((data: Array<abilityAccessCtrl.GrantStatus>) => {
  16.           console.info('data:' + JSON.stringify(data));
  17.         })
  18.         .catch((err: BusinessError) => {
  19.           console.error('data:' + JSON.stringify(err));
  20.         });
  21.     } else {
  22.       // 已经授权,可以继续访问目标操作
  23.       return
  24.     }
  25.   }
复制代码
  1. /** * 定位回调 */
  2.   //获取用户位置信息
  3.   private async locationChange(location: geoLocationManager.Location) {
  4.     if (location) {
  5.       let reverseGeocodeRequest: geoLocationManager.ReverseGeoCodeRequest = {
  6.         'latitude': location.latitude, // 表示纬度信息,正值表示北纬,负值表示南纬。取值范围为-90到90。仅支持WGS84坐标系。
  7.         'longitude': location.longitude, // 表示经度信息,正值表示东经,负值表是西经。取值范围为-180到180。仅支持WGS84坐标系。
  8.         // 指定返回位置信息的最大个数。取值范围为大于等于0,推荐该值小于10。默认值是1。
  9.         'maxItems': 1
  10.       };
  11.       // 逆地址编码转化,获取地址位置描述
  12.       let data = await geoLocationManager.getAddressesFromLocation(reverseGeocodeRequest);
  13.       if (data) {
  14.         if (data[0].locality !== undefined) {
  15.           let res = data[0] as DeatilPositionViewPage
  16.           let placeName = res.placeName
  17.           let countryName = res.countryName
  18.           let provience = placeName.slice(0, placeName.indexOf('省') + 1)
  19.           let city = placeName.slice(placeName.indexOf('省') + 1, placeName.indexOf('市') + 1)
  20.           let area = placeName.slice(placeName.indexOf('市') + 1, placeName.indexOf('区') + 1)
  21.           let deatil = placeName.slice(placeName.indexOf('区') + 1)
  22.           let address = `${countryName} ${provience} ${city} ${area} ${deatil}`
  23.           this.returnInfor = {
  24.             address: address,
  25.             longitude: res.longitude,
  26.             latitude: res.latitude
  27.           }
  28.         }
  29.       }
  30.     }
  31.   };
复制代码
  1. 运行使用代码块
  2. @Entry
  3. @Component
  4. export struct Page1 {
  5.   @State returnInfor: returnDeatilPosition = {
  6.     address: '',
  7.     longitude: 0,
  8.     latitude: 0
  9.   }
  10.   //判断是否为首次请求
  11.   step = 0
  12.   
  13.   //写入上面三个方法
  14.   build() {
  15.     RelativeContainer() {
  16.      Button(this.returnInfor)
  17.        .onclick(async()=>{await this.onClickGetLocation()})
  18.     }
  19.     .height('100%')
  20.     .width('100%')
  21.   }
  22. }
复制代码
题目描述


  • 我们在一些场景下可能会需要拉起用户的拨号界面,以下是关于拉起拨号的方案总结。
   值得注意的是如果这里是混合开辟需要的功能,我们可以把该方法写在.onLoadIntercept((event) => {})这个方法里面。具体相关使用自行查阅官方文档,较为简朴不做赘述。
  办理方案:

  1. import { call, observer } from '@kit.TelephonyKit';
  2. import { BusinessError } from '@kit.BasicServicesKit';
  3. // 调用查询能力接口
  4. @Entry
  5. @Component
  6. struct callphone {
  7.   build() {
  8.     Text('1111').onClick(()=>{
  9.       let isSupport = call.hasVoiceCapability();
  10.       if (isSupport) {
  11.         // 如果设备支持呼叫能力,则继续跳转到拨号界面,并显示拨号的号码
  12.         call.makeCall("4009609206", (err: BusinessError) => {
  13.         });
  14.       }
  15.     })
  16.   }
  17. }
复制代码
题目描述


  • 我们在一些场景下可能会需要用到系统分享本领,以下是关于系统分享的方案总结。
办理方案:

  1. async share(ctx: Context, url: string, title: string) {
  2.     let shareData: systemShare.SharedData = new systemShare.SharedData({
  3.       utd: uniformTypeDescriptor.UniformDataType.HYPERLINK,
  4.       content: url,
  5.       title: title,
  6.       description: '分享此链接',
  7.     });
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

惊落一身雪

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表