跳到主要内容

跨设备互通开发指导

跨设备互通提供相机、扫描以及图库(图片和视频)的跨设备调用能力,例如:平板或2in1设备可以调用手机的相机、扫描、图库等功能。从API 6.1.0(23)开始,TV、手机、平板或2in1设备可调用具备如下能力的远程设备:支持拍照、扫描及图库(图片与视频)能力的手机和平板,支持图库(图片与视频)能力的2in1设备。

场景介绍

您通过此能力实现跨设备交互,可以使用其他设备的相机、扫描和图库功能。

约束与限制

需同时满足以下条件,才能使用该功能:

  • 设备限制

    • 本端设备:HarmonyOS版本为HarmonyOS NEXT及以上的平板或2in1设备。
    • 远端设备:HarmonyOS版本为HarmonyOS NEXT及以上、具有相机能力的手机或平板设备。
  • 使用限制

    • 双端设备需要登录同一华为账号。
    • 跨设备互通API支持根据特定调用策略调用设备。调用策略:2in1设备可以调用平板和手机,平板可以调用手机,并且在6.1.0(23)之后支持TV、手机、平板或2in1设备调用支持拍照、扫描、选择图库中图片与视频能力的手机,支持拍照、扫描、选择图库中图片与视频能力的平板,以及支持选择图库中图片与视频能力的2in1设备。
    • 本端和远端设备需要打开WLAN和蓝牙开关。条件允许时,推荐本端和远端设备接入同一个局域网,可提升唤醒相机的速度。
    • 若在跨设备调用视频选择器时遇到资源加载异常,建议在调用前确认本端和远端的设备调用能力是否匹配、系统状态是否正常,并在稳定环境下重试操作。

接口说明

在开发具体功能前,请先查阅参考文档

接口名描述
createCollaborationServiceMenuItems设备列表选择器,用于获取组网内具有对应跨设备互通能力的设备列表。
CollaborationServiceStateDialog弹窗组件,用于提示对端业务状态。

开发步骤

  1. 导入模块。

    import { createCollaborationServiceMenuItems, CollaborationServiceStateDialog, CollaborationServiceFilter } from '@kit.ServiceCollaborationKit';

    createCollaborationServiceMenuItems是设备列表菜单项模块,传入CollaborationServiceFilter的能力枚举值;CollaborationServiceStateDialog是状态提示框模块。

  2. 在Menu中调用createCollaborationServiceMenuItems添加设备列表选择器,在菜单项内显示设备列表。

    在调用createCollaborationServiceMenuItems前,需了解:

    • 该方法需要在Menu组件内调用。
    • 该方法是自定义构建函数,您在使用前需要先了解@Builder
  3. 传入Array类型的CollaborationServiceFilter枚举值即可使用对应能力,目前支持ALL、TAKE_PHOTO、SCAN_DOCUMENT、IMAGE_PICKER、VIDEO_PICKER和IMAGE_VIDEO_PICKER。

    ALL为预留值,匹配跨端拍照、文档扫描和图库选择器,功能将在后续拓展,TAKE_PHOTO匹配跨设备拍照能力,SCAN_DOCUMENT匹配跨设备扫描能力,IMAGE_PICKER匹配跨设备图库能力,VIDEO_PICKER匹配视频选择器,IMAGE_VIDEO_PICKER匹配图片和视频选择器。

    @Builder
    MyTestMenu() {
    Menu() {
    createCollaborationServiceMenuItems([CollaborationServiceFilter.ALL])
    }
    }
  4. 在build方法中添加弹窗组件CollaborationServiceStateDialog,用于提示远端相机拍摄状态和回传数据,需要实现其中的onState方法。CollaborationServiceStateDialog是全局的提示框,不会对原有布局产生影响。

  5. 为弹窗组件绑定和实现onState方法,用于接收和处理照片数据。

    回调函数的传入参数stateCode是完成状态,buffer是回传的数据内容,可通过状态和数据内容结合自身的业务逻辑实现onState方法。

    CollaborationServiceStateDialog({
    onState: (stateCode: number, bufferType: string, buffer: ArrayBuffer):void => this.doInsertPicture(stateCode, bufferType, buffer)
    })

跨设备互通完整示例

通过以下示例,您可以完成一次调用对端相机拍摄的操作。

import {
createCollaborationServiceMenuItems,
CollaborationServiceStateDialog,
CollaborationServiceFilter
} from '@kit.ServiceCollaborationKit';
import { image } from '@kit.ImageKit';
import { hilog } from '@kit.PerformanceAnalysisKit';

@Entry
@Component
struct Index {
@State picture: PixelMap | undefined = undefined;

@Builder
MyTestMenu() {
Menu() {
createCollaborationServiceMenuItems([CollaborationServiceFilter.ALL])
}
}

build() {
Column({ space: 20 }) {
CollaborationServiceStateDialog({
onState: (stateCode: number, bufferType: string, buffer: ArrayBuffer): void => this.doInsertPicture(stateCode, bufferType, buffer)
})
Button('使用远端设备进行拍照')
.type(ButtonType.Normal)
.borderRadius(10)
.bindMenu(this.MyTestMenu)

if (this.picture) {
Image(this.picture)
.borderStyle(BorderStyle.Dotted)
.borderWidth(1)
.objectFit(ImageFit.Contain)
.height('80%')
.onComplete((event) => {
if (event != undefined) {
hilog.info(0, "MEMOMOCK", "onComplete " + event.loadingStatus)
}
})
}
}
.padding(20)
.width('100%')
.alignItems(HorizontalAlign.Center)
}

doInsertPicture(stateCode: number, bufferType: string, buffer: ArrayBuffer): void {
if (stateCode != 0) {
return
}
if (bufferType == "general.image") {
let imageSource = image.createImageSource(buffer)
imageSource.createPixelMap().then((pixelMap) => {
this.picture = pixelMap;
})
}
}
}

示例代码

跨设备互通