diff --git a/zh-cn/application-dev/reference/arkui-ts/Readme-CN.md b/zh-cn/application-dev/reference/arkui-ts/Readme-CN.md index 5e6a2f5391219050a68f8e9048466d21c3be798b..fac811e748ba045bd78f38a530618f3aa24c10df 100644 --- a/zh-cn/application-dev/reference/arkui-ts/Readme-CN.md +++ b/zh-cn/application-dev/reference/arkui-ts/Readme-CN.md @@ -74,6 +74,7 @@ - [Toggle](ts-basic-components-toggle.md) - [TextClock](ts-basic-components-textclock.md) - [Web](ts-basic-components-web.md) + - [Xcomponent](ts-basic-components-xcomponent.md) - 容器组件 - [AlphabetIndexer](ts-container-alphabet-indexer.md) - [Badge](ts-container-badge.md) diff --git a/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-xcomponent.md b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-xcomponent.md new file mode 100644 index 0000000000000000000000000000000000000000..d4aedb95f8a93932bee05d11344dc578d42e71d2 --- /dev/null +++ b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-xcomponent.md @@ -0,0 +1,116 @@ +# XComponent + + > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** + > 该组件从API Version 8 开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 + + 可用于EGL/OpenGLES和媒体数据写入,并显示在XComponent组件。 + +## 权限列表 + + 无 + +## 子组件 + + 不支持。 + +## 接口 + + XComponent\(value: {id: string, type: string, libraryname?: string, controller?: XComponentController}\) + + - 参数 + + | 名称 | 参数类型 | 必填 | 描述 | + | ----------- | --------------------------------------------- | ---- | ------------------------------------------------------------ | + | id | string | 是 | 组件的唯一标识,支持最大的字符串长度128。 | + | type | string | 是 | 用于指定XComponent组件类型,可选值为:
-surface:组件内容单独送显,直接合成到屏幕。
-component:组件内容与其他组件合成后统一送显。
component类型在OpenHarmony 3.1 Release版本仅为接口定义,暂不支持使用。接口将在OpenHarmony 3.1 MR版本中提供使用支持。 | + | libraryname | string | 否 | 应用Native层编译输出动态库名称。 | + | controller | [XComponentController](#XComponentController) | 否 | 给组件绑定一个控制器,通过控制器调用组件方法。 | + + +## 事件 + +| 名称 | 功能描述 | +| ------------------------------- | ------------------------ | +| onLoad(context?: object) => void | 插件加载完成时回调事件。 | +| onDestroy() => void | 插件卸载完成时回调事件。 | + +## XComponentController + +xcomponent 组件的控制器,可以将此对象绑定至XComponent组件,然后通过控制器带调用组件方法。 + +### 创建对象 + +``` +xcomponentController: XComponentController = new XComponentController() +``` + +### getXComponentSurfaceId + +getXComponentSurfaceId(): string + +获取XComponent对应Surface的ID,供@ohos接口使用,比如camera相关接口。 + + - 返回值 + + | 类型 | 描述 | + | ------ | --------------------------- | + | string | XComponent持有Surface的ID。 | + +### setXComponentSurfaceSize + +setXComponentSurfaceSize(value: {surfaceWidth: number, surfaceHeight: number}): void + +设置XComponent持有Surface的宽度和高度。 + +- 参数 + + | 参数名 | 参数类型 | 必填 | 默认值 | 描述 | + | ------------- | -------- | ---- | ------ | ----------------------------- | + | surfaceWidth | number | 是 | - | XComponent持有Surface的宽度。 | + | surfaceHeight | number | 是 | - | XComponent持有Surface的高度。 | + +### getXComponentContext + +getXComponentContext(): Object + +获取XComponent实例对象的context。 + +- 返回值 + + | 类型 | 描述 | + | ------ | ------------------------------------------------------------ | + | Object | 获取XComponent实例对象的context,context包含的具体接口方法由开发者自定义。 | + +## 示例 + +提供surface类型XComponent,支持相机预览等能力。 + +``` +import camera from '@ohos.multimedia.camera'; +@Entry +@Component +struct PreviewArea { + private surfaceId : string ='' + xcomponentController: XComponentController = new XComponentController() + build() { + Row() { + XComponent({ + id: 'xcomponent', + type: 'surface', + controller: this.xcomponentController + }) + .onLoad(() => { + this.xcomponentController.setXComponentSurfaceSize({surfaceWidth:1920,surfaceHeight:1080}); + this.surfaceId = this.xcomponentController.getXComponentSurfaceId(); + camera.createPreviewOutput(this.surfaceId).then((previewOutput) => { + console.log('Promise returned with the PreviewOutput instance'); + }) + }) + .width('640px') + .height('480px') + } + .backgroundColor(Color.Black) + .position({x: 0, y: 48}) + } +} +``` \ No newline at end of file diff --git a/zh-cn/application-dev/reference/arkui-ts/ts-basic-components.md b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components.md index bd0363da802f007410fe5fafe209016c81ab90c3..5e19ebf33efffbcac9e972e65124ff8052cdbb04 100644 --- a/zh-cn/application-dev/reference/arkui-ts/ts-basic-components.md +++ b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components.md @@ -39,3 +39,4 @@ - **[Select](ts-basic-components-select.md)** - **[TextClock](ts-basic-components-textClock.md)** +- **[Xcomponent](ts-basic-components-xcomponent.md)** \ No newline at end of file