harmony 鸿蒙@ohos.app.ability.FenceExtensionContext (FenceExtensionContext) (System API)
@ohos.app.ability.FenceExtensionContext (FenceExtensionContext) (System API)
The FenceExtensionContext class defines the context for FenceExtensionAbility objects. Inherited from ExtensionContext, this class provides the configuration information of FenceExtensionAbility objects and the API for starting them.
NOTE
The initial APIs of this module are supported since API version 14. Newly added APIs will be marked with a superscript to indicate their earliest API version. The APIs of this module can be used only in the stage model. The APIs provided by this module are system APIs.
Modules to Import
import { FenceExtensionContext } from '@kit.LocationKit';
Usage
Before using FenceExtensionContext, you must first obtain a FenceExtensionAbility instance.
import { FenceExtensionAbility, FenceExtensionContext } from '@kit.LocationKit';
class MyFenceExtensionAbility extends FenceExtensionAbility {
onCreate() {
let fenceExtensionContext: FenceExtensionContext = this.context;
}
}
FenceExtensionContext.startAbility
startAbility(want: Want): Promise<void>
Starts an ability. This API uses a promise to return the result. It can be called only by the main thread.
System API: This is a system API.
System capability: SystemCapability.Location.Location.Geofence
Parameters
Name | Type | Mandatory | Description |
---|---|---|---|
want | Want | Yes | Want information about the target ability. |
Returns
Type | Description |
---|---|
Promise<void> | Promise used to return the result. |
Error codes
ID | Error Message |
---|---|
202 | The application is not system-app, can not use system-api. |
401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. 3.Parameter verification failed. |
16000001 | The specified ability does not exist. |
16000002 | Incorrect ability type. |
16000004 | Can not start invisible component. |
16000005 | The specified process does not have the permission. |
16000006 | Cross-user operations are not allowed. |
16000008 | The crowdtesting application expires. |
16000009 | An ability cannot be started or stopped in Wukong mode. |
16000011 | The context does not exist. |
16000050 | Internal error. |
16000053 | The ability is not on the top of the UI. |
16000055 | Installation-free timed out. |
16200001 | The caller has been released. |
16300003 | The target application is not self application. |
For details about the error codes, see Ability Error Codes.
Example
import { FenceExtensionAbility, geoLocationManager } from '@kit.LocationKit';
import { BusinessError } from '@kit.BasicServicesKit';
import { Want } from '@kit.AbilityKit';
export class MyFenceExtensionAbility extends FenceExtensionAbility {
onFenceStatusChange(transition: geoLocationManager.GeofenceTransition, additions: Record<string, string>): void {
// Receive the geofence status change event and process the service logic.
console.info(`on geofence transition,id:${transition.geofenceId},event:${transition.transitionEvent},additions:${JSON.stringify(additions)}`);
let want: Want = {
bundleName: "com.example.myapp",
abilityName: "MyServiceExtensionAbility"
};
try {
this.context.startAbility(want)
.then(() => {
// Carry out normal service processing.
console.info('startAbility succeed');
})
.catch((error: BusinessError) => {
// Process service logic errors.
console.info('startAbility failed, error.code: ' + JSON.stringify(error.code) +
' error.message: ' + JSON.stringify(error.message));
});
} catch (paramError) {
// Process input parameter errors.
let code = (paramError as BusinessError).code;
let message = (paramError as BusinessError).message;
console.info('startAbility failed, error.code: ' + JSON.stringify(code) +
' error.message: ' + JSON.stringify(message));
}
}
}
你可能感兴趣的鸿蒙文章
harmony 鸿蒙Location Kit Error Codes
harmony 鸿蒙@ohos.app.ability.FenceExtensionAbility (FenceExtensionAbility)
harmony 鸿蒙@ohos.app.ability.FenceExtensionContext (FenceExtensionContext)
harmony 鸿蒙@ohos.geoLocationManager (Geolocation Manager) (System API)
harmony 鸿蒙@ohos.geoLocationManager (Geolocation Manager)
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦