HarmonyOS 鸿蒙获取微信授权和持续获取位置信息

获取授权
PermissionManager.ets

import { BusinessError } from "@kit.BasicServicesKit";
import { abilityAccessCtrl, bundleManager, PermissionRequestResult, Permissions, common ,Want} from "@kit.AbilityKit";/*** 查询是否有单个权限* @param permission 单个权限字符串* @returns*/
export async function checkAccessToken(permission: Permissions): Promise<boolean> {let atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager();let grantStatus: abilityAccessCtrl.GrantStatus = abilityAccessCtrl.GrantStatus.PERMISSION_DENIED;// 获取应用程序的accessTokenIDlet tokenId: number = 0;try {let bundleInfo: bundleManager.BundleInfo = await bundleManager.getBundleInfoForSelf(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION);let appInfo: bundleManager.ApplicationInfo = bundleInfo.appInfo;tokenId = appInfo.accessTokenId;} catch (error) {let err: BusinessError = error as BusinessError;console.error(`Failed to get bundle info for self. Code is ${err.code}, message is ${err.message}`);}// 校验应用是否被授予权限try {grantStatus = await atManager.checkAccessToken(tokenId, permission);} catch (error) {let err: BusinessError = error as BusinessError;console.error(`Failed to check access token. Code is ${err.code}, message is ${err.message}`);}return grantStatus === abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED;
}/*** 用于UIAbility拉起弹框请求用户授权* 如果用户拒绝授权,将无法再次拉起弹窗,需要用户在系统应用“设置”的界面中手动授予权限。* @param permissions 权限数组* @returns*/
export async function requestPermissions(permissions: Permissions []): Promise<boolean> {const context = getContext();let atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager();let ret = true;try {let data: PermissionRequestResult = await atManager.requestPermissionsFromUser(context, permissions);let grantStatus: Array<number> = data.authResults;let permissions1 = data.permissions;let length: number = grantStatus.length;for (let i = 0; i < length; i++) {if (grantStatus[i] === 0) {ret = trueconsole.log(`${permissions1} permissions is success`);break;} else {console.log(`${permissions1} permissions is failed`);ret = false;}}} catch (e) {console.log(e.message);ret = false;}return ret;
}export async function openPermissionSettingsPage() {// 获取上下文const context = getContext() as common.UIAbilityContext// 获取包信息const bundleInfo = bundleManager.getBundleInfoForSelfSync(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION)// Want信息配置let wantInfo: Want = {bundleName: 'com.huawei.hmos.settings',abilityName: 'com.huawei.hmos.settings.MainAbility',uri: 'application_info_entry',parameters: {// 按照包名打开对应设置页pushParams: bundleInfo.name}}// 打开系统设置页context.startAbility(wantInfo)
}

获取定位
LocationService.ets

import { geoLocationManager } from '@kit.LocationKit';
import { AuthUtil } from './AuthUtil';
import { Permissions } from '@kit.AbilityKit';
import {checkAccessToken, requestPermissions,openPermissionSettingsPage} from  './PermissionManager'export default class LocationService {private locationCallback!: (location: geoLocationManager.Location) => void;async  requestLocationPermission(sucessPermission: (bol:boolean) => void) {const locationPermissions: Permissions[] = ['ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'];try {// 检查定位权限是否已经授予const hasPermission = await checkAccessToken(locationPermissions[0]);console.log('hasPermission', hasPermission);if (hasPermission) {console.log('定位权限已经授予');sucessPermission(true)} else {console.log('定位权限未授予,请求权限');const isGranted = await requestPermissions(locationPermissions);if (isGranted) {console.log('定位权限请求成功');sucessPermission(true)} else {console.log('定位权限请求失败,需要用户手动授予权限');openPermissionSettingsPage();}}} catch (error) {console.error('定位权限请求失败:', error);openPermissionSettingsPage();}
}//// public async requestLocationPermission( sucessPermission: (bol:boolean) => void) {//   const locationPermissions: Permissions[] = ['ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'];// 根据实际权限名称修改//   try {//     // 检查定位权限是否已经授予//     const hasPermission = PermissionManager.checkAccessToken(locationPermissions);//     if (hasPermission) {//       console.log('定位权限已经授予');//       // 继续其他业务逻辑//       sucessPermission(true)//     } else {//       console.log('定位权限未授予,请求权限');//       // 请求定位权限//       await PermissionManager.requestPermissions(locationPermissions);//       console.log('定位权限请求成功');//       // 继续其他业务逻辑//       sucessPermission(true)//     }//   } catch (error) {//     console.error('定位权限请求失败:', error);//     sucessPermission(false)//     // 引导用户到系统设置页面手动开启权限//     PermissionManager.openPermissionSettingsPage();//   }// }/*** 开启持续定位* @param onStart 开启定位的回调函数* @param onLocationUpdate 位置更新的回调函数*/public openContinuousLocation(onStart: () => void,onLocationUpdate: (location: geoLocationManager.Location) => void) {this.requestLocationPermission((bol)=>{if(bol){let request: geoLocationManager.ContinuousLocationRequest = {'interval': 1,'locationScenario': geoLocationManager.UserActivityScenario.NAVIGATION}this.locationCallback = (location: geoLocationManager.Location): void => {console.log('定位信息: ' + JSON.stringify(location));onLocationUpdate(location);};try {geoLocationManager.on('locationChange', request, this.locationCallback);onStart(); // 调用开启定位的回调函数} catch (err) {console.error("开启持续定位错误: " + JSON.stringify(err));}}else{onStart(); // 调用开启定位的回调函数}})}/*** 关闭持续定位* @param onStop 关闭定位的回调函数*/public closeContinuousLocation(onStop: () => void) {console.log('关闭持续定位');try {geoLocationManager.off('locationChange', this.locationCallback);onStop(); // 调用关闭定位的回调函数} catch (err) {console.error('关闭持续定位错误: ' + err);}}}

调用,必须封装的closeContinuousLocation才生效

import LocationService from '../../Util/LocationService'OpenContinuosLocation() {// 开启持续定位this.locationService.openContinuousLocation(() => {console.log('定位已开启');this.calculateDrivingInfo(null)},(location) => {console.log('位置更新: ' + JSON.stringify(location));});}/*** 关闭持续定位*/ClosedContinuosLocation() {console.log(' 定位关闭 ClosedContinuosLocation')// 关闭持续定位this.locationService.closeContinuousLocation(() => {console.log('定位已关闭');});}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/52635.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每天一个数据分析题(五百零二)- 分割式聚类算法

以下哪个选项是分割式聚类算法? A. K-Means。 B. Centroid Method C. Ward’s Method D. 以上皆非 数据分析认证考试介绍&#xff1a;点击进入 题目来源于CDA模拟题库 点击此处获取答案 数据分析专项练习题库 内容涵盖Python&#xff0c;SQL&#xff0c;统计学&#…

【9月持续更新】国内ChatGPT-4o中文镜像网站整理~

以前我也是通过官网使用&#xff0c;但是经常被封号&#xff0c;就非常不方便&#xff0c;后来有朋友推荐国内工具&#xff0c;用了一阵之后&#xff0c;发现&#xff1a;稳定方便&#xff0c;用着也挺好的。 最新的 GPT-4o、4o mini&#xff0c;可搭配使用~ 1、 最新模型科普&…

Revit 2025.2新增功能及安装教程和下载

Revit 2025.2 带来了许多新功能和改进&#xff0c;增强了BIM工作流程。以下是主要的新功能&#xff1a; 项目浏览器标签功能&#xff1a;新增的标签功能使得用户可以通过标签过滤浏览器列表&#xff0c;这对大型项目非常有用&#xff0c;减少了滚动和点击次数​。 链接管理对…

若依将登录用户的userId自动加载到查询中

点击搜索&#xff0c;会将登录用户的userId作为搜索条件&#xff0c;去查询。 新版本自动存储了userId&#xff0c;我们不用改&#xff0c;只要知道如何引用。 前端使用 在对应的vue文件&#xff0c;查询queryParams 加查询的值 然后参考他的 添加store import store from &…

PDM系统多少钱一般?一文详细了解三品PDM系统报价

在现代企业的数字化转型过程中&#xff0c;PDM产品数据管理软件扮演着至关重要的角色。PDM软件是一种应用于管理产品全生命周期的软件工具&#xff0c;涵盖了产品设计、工艺流程、生产制造、销售和维护等多个环节。随着技术的不断进步和市场的日益竞争&#xff0c;PDM软件的价格…

零基础学PLC的指令-沿指令(2)

扫描操作数的信号上升沿&#xff1a; 在触点分配的 "IN" 位上检测到正跳变&#xff08;0->1&#xff09;时&#xff0c;该触点的状态为 TRUE。该触点逻辑状态随后与能流输入状态组合以设置能流输出状态。P 触点可以放置在程序段中除分支结尾外的任何位置。 扫描…

switch语句

除了if语句外&#xff0c;C语⾔还提供了switch语句来实现分⽀结构。switch 语句是⼀种特殊形式的 if...else 结构&#xff0c;⽤于判断条件有多个结果的情况。 语法 //switch (expression) //{ // case value1: statement // case value2: statement // default: st…

AOP思想

什么是AOP AOP&#xff1a;Aspect oriented programming 面向切面编程&#xff0c;AOP 是 OOP&#xff08;面向对象编程&#xff09;的一种延续。 解决&#xff1a;在不改变原有业务逻辑的情况下&#xff0c;增强横切逻辑代码&#xff0c;根本上解耦合&#xff0c;避免横切逻…

大规模预训练语言模型的参数高效微调

人工智能咨询培训老师叶梓 转载标明出处 大规模预训练语言模型&#xff08;PLMs&#xff09;在特定下游任务上的微调和存储成本极高&#xff0c;这限制了它们在实际应用中的可行性。为了解决这一问题&#xff0c;来自清华大学和北京人工智能研究院的研究团队探索了一种优化模型…

四川凭什么能成为中国的战略腹地?

四川因其独特的地理位置、丰富的资源、雄厚的工业基础、庞大的人口及复杂多样的地形等&#xff0c;就在今年1月份的时候&#xff0c;国务院正式批复了一份重磅文件&#xff0c;四川被国务院正式定位为战略腹地&#xff0c;即全体中国人的退路和国家的备份省。 那么四川凭什么能…

【论文阅读】ColabFold: making protein folding accessible to all

论文阅读:ColabFold: making protein folding accessible to all (2022) 1、背景 研究问题:这篇文章要解决的问题是如何让蛋白质折叠预测对所有人开放,特别是那些没有强大计算资源的研究人员。 研究难点:该问题的研究难点包括:构建多样化的多序列比对(MSA)需要大量计…

半导体行业急招:基板/模拟ic/数字IC设计/robot工程师,薪资最高90K*16薪!

本周半导体行业急招岗位推荐&#xff0c;基板设计、模拟ic设计&#xff0c;robot工程师、数字IC设计等高薪岗位招人啦&#xff0c;月薪最高90K&#xff0c;还有16薪&#xff0c;还不快来&#xff01;&#xff01; 抓紧投递&#xff0c;早投早入职&#xff01; &#x1f447;点…

STM32(F103ZET6)第四课:串口中断

目录 需求一、串口中断过程与作用二、中断实现流程1.中断优先级分组2.配置串口中断 三、需求的实现 需求 1.设备上电后四个灯灭。 2.按下KEY1&#xff0c;LED1灯亮&#xff0c;同时串口发送“LED1灯亮”。 3.再次按下KEY1&#xff0c;LED1灯灭&#xff0c;同时串口发送“LED1灯…

CPU、MPU、MCU、SOC分别是什么?

CPU、MPU、MCU和SoC都是与微电子和计算机科学相关的术语&#xff0c;它们在功能定位、应用场景以及处理能力等方面有所区别。具体如下&#xff1a; CPU&#xff1a;CPU是中央处理单元的缩写&#xff0c;它通常指计算机内部负责执行程序指令的芯片。CPU是所有类型计算机&#x…

android studio 新建java工程, 安卓新建项目,android studio2024 如何新建java项目

主要解决&#xff0c;新增安卓工程&#xff0c;没有java选项 1. 点击左上角FIle -> New -> 2. 选择 no activity 选项&#xff0c; 然后next 3. langua 就可以选择java 了。name自己定义项目名称&#xff0c;项目存储地址&#xff0c;包名。 配置完成选择finish. 4. fin…

Rust Web框架怎么选?

在最新的web框架基准测试中 https://www.techempower.com/benchmarkshttps://web-frameworks-benchmark.netlify.app/result?lrust 除去一些没有发布分支或者已经很少维护或者不是rust写的框架外&#xff0c;可以看到Axum、Actix-web是目前性能最好的两款后端框架&#xff0…

python,json数据格式,pyecharts模块,pycharm中安装pyecharts

json数据格式 JSON是一种轻量级的数据交互格式 可以按照JSON指定的格式去组织和封装数据 JSON本质上是一个带有特定格式的字符串 主要功能&#xff1a; json就是一种在各个编程语言中流通的数据格式&#xff0c;负责不同编程语言中的数据传递和交互. 类似于&#xff1a; 国…

手撕python之基本数据类型以及变量

​​​​​​1.基础概念 python就是将不同的数据划分成了不同的类型 就像我们生活中的数据有数字、字符等数据一样 小知识点&#xff1a; 注释&#xff1a;# 全体注释&#xff1a;AltF3 取消注释&#xff1a;AltF4 2.数值类型 数值类型概括 数值类型分为三种&#xff…

Spark-第八周

表关联 1. spark sql 常用的join 几种实现 SparkSQL中的三种Join及其具体实现&#xff08;broadcast join、shuffle hash join和sort merge join&#xff09;_broadcastjoin-CSDN博客 【Spark的五种Join策略解析】_broadcastnestedloopjoin-CSDN博客 2.Spark 自适应执行计划…

JavaWeb JavaScript ⑤ JS常见对象

某一瞬间&#xff0c;是平静的自我接纳 —— 24.8.27 一、数组 1.创建数组的四种方式 ① new Array() 创建空数组 ② new Array(5) 创建数组时给定长度 ③ new Array(ele1,ele2,…,elen); 创建数组时给定元素值 ④ [ele1,ele2,…,elen] 相当于…