赞
踩
开发者需要重写app.js/app.ets中的生命周期回调函数,开发者通过DevEco Studio开发平台创建PageAbility时,DevEco Studio会在app.js/app.ets中默认生成onCreate()和onDestroy()方法,其他方法需要开发者自行实现。接口说明参见前述章节,创建PageAbility示例如下:
export default { onCreate() { console.info('Application onCreate') }, onDestroy() { console.info('Application onDestroy') }, onShow() { console.info('Application onShow') }, onHide() { console.info('Application onHide') }, onActive() { console.info('Application onActive') }, onInactive() { console.info('Application onInactive') }, onNewWant() { console.info('Application onNewWant') }, }
PageAbility创建成功后,其abilities相关的配置项在config.json中体现,一个名字为MainAbility的config.json配置文件示例如下:
{ "abilities": [ { "skills": [ { "entities": [ "entity.system.home" ], "actions": [ "action.system.home" ] } ], "orientation": "unspecified", "visible": true, "srcPath": "MainAbility", "name": ".MainAbility", "srcLanguage": "ets", "icon": "$media:icon", "description": "$string:MainAbility_desc", "formsEnabled": false, "label": "$string:MainAbility_label", "type": "page", "launchType": "singleton" } ] }
FA模型中,可以通过featureAbility的getContext接口获取应用上下文,进而使用上下文提供的能力。
表1 featureAbility接口说明
接口名 | 接口描述 |
---|---|
getContext() | 获取应用上下文。 |
通过getContext获取应用上下文并获取分布式目录的示例如下:
import featureAbility from '@ohos.ability.featureAbility' import fileIo from '@ohos.fileio' (async () => { let dir: string try { console.info('Begin to getOrCreateDistributedDir') dir = await featureAbility.getContext().getOrCreateDistributedDir() console.info('distribute dir is ' + dir) } catch (error) { console.error('getOrCreateDistributedDir failed with ' + error) } let fd: number; let path = dir + "/a.txt"; fd = fileIo.openSync(path, 0o2 | 0o100, 0o666); fileIo.close(fd); })()
PageAbility相关的能力通过featureAbility提供,启动本地Ability通过featureAbility中的startAbility接口实现。
表1 featureAbility接口说明
接口名 | 接口描述 |
---|---|
startAbility(parameter: StartAbilityParameter) | 启动Ability。 |
startAbilityForResult(parameter: StartAbilityParameter) | 启动Ability,并在该Ability被销毁时返回执行结果。 |
如下示例通过startAbility显式启动PageAbility。启动Ability的参数包含want,关于want的说明详见对象间信息传递载体Want,相应的,隐式启动与显式启动也不在此赘述。
import featureAbility from '@ohos.ability.featureAbility' (async () => { try { console.info('Begin to start ability') let param = { want: { bundleName: "com.example.myapplication", moduleName: "entry", abilityName: "com.example.myapplication.MainAbility" } } await featureAbility.startAbility(param) console.info(`Start ability succeed`) } catch (error) { console.error('Start ability failed with ' + error) } })()
停止PageAbility通过featureAbility中的terminateSelf接口实现。
表1 featureAbility接口说明
接口名 | 接口描述 |
---|---|
terminateSelf() | 停止Ability。 |
terminateSelfWithResult(parameter: AbilityResult) | 设置该PageAbility停止时返回给调用者的结果及数据并停止Ability。 |
如下示例展示了停止Ability的方法。
import featureAbility from '@ohos.ability.featureAbility'
(async () => {
try {
console.info('Begin to terminateSelf')
await featureAbility.terminateSelf()
console.info('terminateSelf succeed')
}
catch (error) {
console.error('terminateSelf failed with ' + error)
}
})()
当PageAbility的启动模式设置为单例时(具体设置方法和典型场景示例见PageAbility的启动模式,缺省情况下是单实例模式),若PageAbility已被拉起,再次启动PageAbility会触发onNewWant回调(即非首次拉起)。应用开发者可以通过want传递启动参数,例如开发者希望指定页面启动PageAbility,可以通过want中的parameters参数传递pages信息,具体示例代码如下:
调用方PageAbility的app.ets中或者page中,使用startAbility再次拉起PageAbility,通过want中的uri参数传递页面信息:
import featureAbility from '@ohos.ability.featureAbility'; async function restartAbility() { let wantInfo = { bundleName: "com.sample.MyApplication", abilityName: "MainAbility", parameters: { page: "pages/second" } }; featureAbility.startAbility({ want: wantInfo }).then((data) => { console.info('restartAbility success.'); }); }
在目标端PageAbility的onNewWant回调中获取包含页面信息的want参数:
export default {
onNewWant(want) {
globalThis.newWant = want
}
}
在目标端页面的自定义组件中获取包含页面信息的want参数并根据uri做路由处理:
import router from '@ohos.router' @Entry @Component struct Index { @State message: string = 'Router Page' newWant = undefined onPageShow() { console.info('Index onPageShow') let newWant = globalThis.newWant if (newWant.hasOwnProperty("page")) { router.push({ url: newWant.page }); globalThis.newWant = undefined } } build() { Row() { Column() { Text(this.message) .fontSize(50) .fontWeight(FontWeight.Bold) } .width('100%') } .height('100%') } }
当PageAbility的启动模式设置为标准模式或为首次启动单例模式的PageAbility时(具体设置方法和典型场景示例见PageAbility的启动模式),在调用方PageAbility中,通过want中的parameters参数传递要启动的指定页面的pages信息,调用startAbility()方法启动PageAbility。被调用方可以在onCreate中使用featureAbility的getWant方法获取want,再通过调用router.push实现启动指定页面。
调用方的页面中实现按钮点击触发startAbility方法启动目标端PageAbility,startAbility方法的入参want中携带指定页面信息,示例代码如下:
import featureAbility from '@ohos.ability.featureAbility' @Entry @Component struct Index { @State message: string = 'Hello World' build() { // ... Button("startAbility") .onClick(() => { featureAbility.startAbility({ want: { bundleName: "com.exm.myapplication", abilityName: "com.exm.myapplication.MainAbility", parameters: { page: "pages/page1" } } }).then((data) => { console.info("startAbility finish"); }).catch((err) => { console.info("startAbility failed errcode:" + err.code) }) }) // ... Button("page2") .onClick(() => { featureAbility.startAbility({ want: { bundleName: "com.exm.myapplication", abilityName: "com.exm.myapplication.MainAbility", parameters: { page: "pages/page2" } } }).then((data) => { console.info("startAbility finish"); }).catch((err) => { console.info("startAbility failed errcode:" + err.code) }) }) // ... } }
目标端PageAbility的onCreate生命周期回调中通过featureAbility的getWant方法获取want,并对参数进行解析,实现指定页面拉起:
import featureAbility from '@ohos.ability.featureAbility'; import router from '@ohos.router'; export default { onCreate() { featureAbility.getWant().then((want) => { if (want.parameters.page) { router.push({ url: want.parameters.page }) } }) }, onDestroy() { // ... }, }
应用需要获取用户的隐私信息或使用系统能力时,例如获取位置信息、使用相机拍摄照片或录制视频等,需要向用户申请授权。
在开发过程中,首先需要明确涉及的敏感权限并在config.json中声明需要的权限,同时通过接口requestPermissionsFromUser以动态弹窗的方式向用户申请授权。
在config.json声明需要的权限,在module下添加"reqPermissions",并写入对应权限。
如申请访问日历权限,需要申请ohos.permission.READ_CALENDAR权限,配置方式请参阅访问控制授权申请指导。
对应config.json文件的示例代码如下所示:
{
"module": {
// ...
"reqPermissions": [
{
"name": "ohos.permission.READ_CALENDAR"
// ...
}
]
}
}
通过动态弹窗向用户申请授权:
import featureAbility from '@ohos.ability.featureAbility';
let context = featureAbility.getContext();
let permissions: Array<string> = ['ohos.permission.READ_CALENDAR']
context.requestPermissionsFromUser(permissions, 1).then((data) => {
console.info("Succeed to request permission from user with data: " + JSON.stringify(data))
}).catch((error) => {
console.info("Failed to request permission from user with error: " + JSON.stringify(error))
})
一般情况下,应用中的界面跳转由用户触发,应用本身通过startAbility启动跳转其他界面。
PageAbility作为可见Ability,可以通过startAbility启动有界面的且对外可见的Ability。
应用可通过在config.json中设置"abilities"中的"visible"属性设置Ability是否可由其他应用的组件启动,"visible"属性的具体参数和意义如下表所示。
表1 visible属性说明
属性名称 | 描述 | 是否可缺省 |
---|---|---|
visible | 表示Ability是否可以被其他应用调用。true:该Ability可以被任何应用调用。false:该Ability只能被同一应用的其他组件调用。 | 可缺省,缺省时默认属性值为"false"。 |
如果需设置当前Ability可由任何应用访问,对应config.json文件的示例代码如下所示:
{
"module": {
// ...
"abilities": [
{
"visible": "true",
// ...
}
]
}
}
如果应用中的Ability包含skills过滤器,建议此属性设置为"true",以允许其他应用通过隐式调用启动该Ability。如果此属性设为"false",其他应用尝试启动该Ability时系统会返回PERMISSION_DENIED。这种情况下系统应用可以通过申请START_INVISIBLE_ABILITY权限启动visible为false的组件,例如系统桌面、语音助手、搜索助手等。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。