【每日学点鸿蒙知识】无障碍、getLastLocation、蓝牙问题、卡片大小、关系型数据库等

1、是否有类似无障碍辅助相关的API?

场景描述:锁机app,需要通过无障碍能力辅助检测当前正在打开的app,以及模拟用户操作, 关闭用户想要屏蔽的app

可参考:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/accessibility-kit-V5

2、HarmonyOS 调用geoLocationManager.getLastLocation()方法,报3301200?

在申请了定位权限后,开启定位,但是没有执行回调,日志locationChanger:data并没有打印出来。代码如下:

复制代码
if (result) {
  // 已同意定位权限
  Logger.debug('已同意定位权限申请')
  let requestInfo:geoLocationManager.LocationRequest = {'scenario': geoLocationManager.LocationRequestScenario.NAVIGATION, 'timeInterval': 1, 'distanceInterval': 0, 'maxAccuracy': 0}

  let locationChange = (location:geoLocationManager.Location):void => {
    Logger.debug('locationChanger: data: ' + JSON.stringify(location));
  }

  try {
    geoLocationManager.on('locationChange', requestInfo, locationChange)

    // let location = geoLocationManager.getLastLocation()
    // Logger.debug('LocationBridge => location is : ' + JSON.stringify(location))
  } catch (err) {
    Logger.error('定位异常:',JSON.stringify(err))
  }
}

然后,如果 调用geoLocationManager.getLastLocation()方法,就会报3301200错误

LocationRequest改为这样的配置

复制代码
let requestInfo: geoLocationManager.LocationRequest = {
  'priority': geoLocationManager.LocationRequestPriority.FIRST_FIX,
  'scenario': geoLocationManager.LocationRequestScenario.UNSET,
  'timeInterval': 1,
  'distanceInterval': 0,
  'maxAccuracy': 0
}

3、HarmonyOS 蓝牙相关:gattClientDevice.getServices 方法报2900099?

监听服务端的连接状态修改成监听客户端的状态,gattServer.on修改为gattClientDevice.on

4、卡片不同的规则对应的大小是多少px?

服务卡片按照桌面宫格布局,以手机 4x6 宫格为基础分为 4 种尺寸。在修改手机桌面宫格布局后,微卡片和小卡片仍然按照桌面布局显示,中卡片和大卡片按照宫格最大宽度拉伸。因此在设计时需要考虑到卡片内容的尺寸适配。

服务卡片使用 HarmonyOS 通用界面单位进行开发,在 Java UI 中可以使用虚拟像素(virtual pixels, vp)进行开发,详细规格可参考通用设计规范的介绍。在 Js UI 中由于可以设置 Auto Design 属性,像素(Pixel)与虚拟像素(virtual pixels, vp)具有同等概念,可以不做区分。

参考文档:卡片与基础参数

5、HarmonyOS 关系型数据如何查询表是否存在数据库内?

@ohos.data.relationalStore (关系型数据库) 如何查询数据库内,是否已经存在某一张表?

可以使用数据库语言查询数据库中的数据,在callback中返回结果可以参考:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-data-relationalstore-V5

数据库中查询表

复制代码
SELECT *FROM
INFORMATION_SCHEMA.TABLESWHERE
TABLE_SCHEMA = 'database_name'
AND TABLE_NAME = 'table_name';
相关推荐
mr_LuoWei20094 小时前
python工具:python代码知识库笔记
数据库·python
这周也會开心5 小时前
Redis数据类型的底层实现和数据持久化
数据库·redis·缓存
ん贤5 小时前
一次批量删除引发的死锁,最终我选择不加锁
数据库·安全·go·死锁
数据知道5 小时前
PostgreSQL 核心原理:系统内部的对象寻址机制(OID 对象标识符)
数据库·postgresql
Lionel6895 小时前
鸿蒙Flutter跨平台开发:首页特惠推荐模块的实现
华为·harmonyos
盐焗西兰花5 小时前
鸿蒙学习实战之路-Reader Kit自定义页面背景最佳实践
学习·华为·harmonyos
果粒蹬i5 小时前
【HarmonyOS】DAY10:React Native开发应用品质升级:响应式布局与用户体验优化实践
华为·harmonyos·ux
倔强的石头_5 小时前
关系数据库替换用金仓:数据迁移过程中的完整性与一致性风险
数据库
早點睡3905 小时前
基础入门 React Native 鸿蒙跨平台开发:react-native-flash-message 消息提示三方库适配
react native·react.js·harmonyos
Elastic 中国社区官方博客5 小时前
使用 Groq 与 Elasticsearch 进行智能查询
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索