赞
踩
开发者在应用FA中通过调用流转任务管理服务、分布式任务调度的接口,实现多端协同。
主要流程如下:
下面以设备A(本地设备)和设备B(远端设备)为例,进行场景介绍:
流转任务管理服务提供的注册、解注册、显示设备列表、上报业务状态是实现多端协同的前提。开发者使用分布式服务平台提供的连接和断开连接PA、启动远程FA、启动和关闭PA的能力,可实现自定义的多端协同体验。
接口名 | 描述 |
---|---|
void register(String bundleName, ExtraParams parameter, IContinuationDeviceCallback deviceCallback, RequestCallback requestCallback) | 注册并连接到流转任务管理服务,并获取对应的注册token。 参数说明:
ExtraParams说明:
jsonParams说明:
注册后,通过RequestCallback的onResult回调知道执行是否成功,返回值为<0时为失败;其他情况,表示成功,并返回本次流转任务的唯一标识token。 当用户选择设备后,通过deviceCallback定义的onConnected回调获取设备的deviceID、类型、名称。 |
void unregister(int token, RequestCallback requestCallback) | 从流转任务管理服务解注册,传入注册时获取的token进行解注册。 执行后,通过RequestCallback的onResult回调知道执行是否成功。 |
void updateConnectStatus(int token, String deviceId, int status, RequestCallback requestCallback) | 通知流转任务管理服务更新当前用户程序的连接状态,并在流转任务管理服务界面展示给用户。token、deviceId参数来自于注册流转任务管理服务的回调。status参数可以为IDLE、CONNECTING、CONNECTED、DIS_CONNECTING。如果有错误,需要上报errorCode。 执行后,通过RequestCallback的onResult回调知道执行是否成功。 |
void showDeviceList(int token, ExtraParams parameter, RequestCallback requestCallback) | 显示组网内可选择设备列表信息。该接口提供手动显示设备列表的能力,parameter参数可以指定设备过滤的条件,用于手动多端协同,支持的过滤条件与register接口相同。token参数来自于注册流转任务管理服务的回调。 执行后,通过RequestCallback的onResult回调知道执行是否成功。 |
void disconnect() | 在应用退出时,主动调用断开和流转任务管理服务的连接。 |
接口名 | 描述 |
---|---|
void onConnected(ContinuationDeviceInfo deviceInfo) | 当用户从选择设备列表选择设备时调用,返回设备ID、设备类型和设备名称供开发者使用。 |
void onDisconnected(String deviceId) | 当流转任务管理服务断开连接设备时调用。 |
接口名 | 描述 |
---|---|
void onResult(int result) | 与流转任务管理服务交互成功时调用。当作为注册流转任务管理服务的回调对象时,注册成功后给用户程序返回对应的token。 |
接口名 | 描述 |
---|---|
IContinuationRegisterManager getContinuationRegisterManager() | 获取流转任务管理服务注册服务管理类,可以与流转任务管理服务进行交互,包括注册/解注册,更新设备连接状态,显示可选择设备列表等。 |
void startAbility(Intent intent) | 提供启动指定设备上FA和PA的能力,Intent中指定待启动FA/PA的设备deviceId、bundleName和abilityName。若不指定设备deviceId,则无法跨设备调用PA。类似地,在启动FA时,也需要开发者指定启动FA的设备deviceId、bundleName和abilityName。 分布式服务平台还会提供与上述功能相对应的断开远程PA的连接和关闭远程PA的接口,相关的参数与连接、启动的接口类似。 |
boolean connectAbility(Intent intent, IAbilityConnection conn) | 提供连接指定设备上PA的能力,Intent中指定待连接PA的设备deviceId、bundleName和abilityName。当连接成功后,通过在conn定义的onAbilityConnectDone回调中获取对端PA的服务代理,两者的连接关系则由conn维护。 |
boolean stopAbility(Intent intent) | 提供关闭远程PA的能力,Intent中指定待关闭PA的设备deviceId、bundleName和abilityName。 |
void terminateAbility() | 提供关闭当前FA/PA的能力,调用该接口将开始销毁调用的FA/PA。 |
void disconnectAbility(IAbilityConnection conn) | 提供断开远程PA连接能力,conn需要指定为connectAbility连接指定设备上PA时,传入的IAbilityConnection对象。 |
接口名 | 描述 |
---|---|
void onAbilityConnectDone(ElementName element, IRemoteObject remote, int resultCode) | 当连接Service服务成功时调用,可使用返回的IRemoteObject对象与连接的Service服务通信。 |
void onAbilityDisconnectDone(ElementName element, int resultCode) | 当已连接的Service服务被异常关闭时调用。 |
接口名 | 描述 |
---|---|
void initDistributedEnvironment(String deviceId, IInitCallBack callback) | 初始化分布式服务平台。其中deviceId指明设备Id;callback指明初始化分布式环境状态回调,参考IInitCallBack接口描述。 |
void unInitDistributedEnvironment(String deviceId, IInitCallBack callback) | 不再使用分布式服务平台。 |
接口名 | 描述 |
---|---|
void onInitSuccess(String deviceId) | 成功回调。 |
void onInitFailure(String deviceId, int errorCode) | 失败回调。 |
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。