diff --git a/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-1.jpg b/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-1.jpg
new file mode 100644
index 0000000000000000000000000000000000000000..9a2140166f2056e424976046655e5480903f2c0f
Binary files /dev/null and b/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-1.jpg differ
diff --git a/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-2.jpg b/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-2.jpg
new file mode 100644
index 0000000000000000000000000000000000000000..01285cbbaff67c9b1e99c8eb7ae384889ad99bb1
Binary files /dev/null and b/zh-cn/application-dev/reference/arkui-ts/figures/image-matrix-2.jpg differ
diff --git a/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001592882500.gif b/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001592882500.gif
new file mode 100644
index 0000000000000000000000000000000000000000..ccdd2b1aa8255ce173bc923f6686bdfb99e61ce3
Binary files /dev/null and b/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001592882500.gif differ
diff --git a/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001607845173.gif b/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001607845173.gif
new file mode 100644
index 0000000000000000000000000000000000000000..f312df91ae0f7fd8cd8520904a11ddaccd7c58e4
Binary files /dev/null and b/zh-cn/application-dev/reference/arkui-ts/figures/zh-cn_image_0000001607845173.gif differ
diff --git a/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-image.md b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-image.md
index 6163a9cc3a097bc2b1e30a10f5a139301d7a7af5..4e4158658ff7940b443f618a3bb944c8f048a791 100644
--- a/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-image.md
+++ b/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-image.md
@@ -1,6 +1,6 @@
# Image
-图片组件,支持本地图片和网络图片的渲染展示。
+Image为图片组件,常用于在应用中显示图片。Image支持加载[PixelMap](../apis/js-apis-image.md#pixelmap7)、[ResourceStr](ts-types.md#resourcestr)和[DrawableDescriptor](../apis/js-apis-arkui-drawableDescriptor.md#drawabledescriptor)类型的数据源,支持png、jpg、bmp、svg和gif类型的图片格式。
> **说明:**
>
@@ -21,77 +21,122 @@
Image(src: PixelMap | ResourceStr | DrawableDescriptor)
-通过图片数据源获取图片,用于后续渲染展示。Image组件加载图片失败或图片尺寸为0时,图片组件大小自动为0,不跟随父组件的布局约束。
+通过图片数据源获取图片,用于后续渲染展示。
+
+Image组件加载图片失败或图片尺寸为0时,图片组件大小自动为0,不跟随父组件的布局约束。
从API version 9开始,该接口支持在ArkTS卡片中使用。
**参数:**
-| 参数名 | 参数类型 | 必填 | 参数描述 |
-| ---- | ---------------------------------------- | ---- | ---------------------------------------- |
-| src | [PixelMap](../apis/js-apis-image.md#pixelmap7) \|ResourceStr\| [DrawableDescriptor](../apis/js-apis-arkui-drawableDescriptor.md#drawabledescriptor) | 是 | 图片的数据源,支持本地图片和网络图片。
当使用相对路径引用图片资源时,例如`Image("common/test.jpg")`,不支持跨包/跨模块调用该Image组件,建议使用`$r`方式来管理需全局使用的图片资源。
\- 支持的图片格式包括png、jpg、bmp、svg和gif。
\- 支持`Base64`字符串。格式`data:image/[png\|jpeg\|bmp\|webp];base64,[base64 data]`, 其中`[base64 data]`为`Base64`字符串数据。
\- 支持`datashare://`路径前缀的字符串,用于访问通过data ability提供的图片路径。
\- 支持file:///data/storage路径前缀的字符串,用于读取本应用安装目录下files文件夹下的图片资源。需要保证目录包路径下的文件有可读权限。
\- 支持[DrawableDescriptor](../apis/js-apis-arkui-drawableDescriptor.md#drawabledescriptor)对象
- 详细使用方法可参考[显示图片](../../ui/arkts-graphics-display.md)
**说明:**
- ArkTS卡片上支持gif图片格式动效,但仅在显示时播放一次。
- ArkTS卡片上不支持`http://`等网络相关路径前缀、`datashare://`路径前缀以及`file://data/storage`路径前缀的字符串
- ArkTS卡片上不支持 [PixelMap](../apis/js-apis-image.md#pixelmap7)类型 |
+| 参数名 | 参数类型 | 必填 | 参数描述 |
+| ------ | ------------------------------------------------------------ | ---- | ------------------------------------------------------------ |
+| src | [PixelMap](../apis/js-apis-image.md#pixelmap7) \| [ResourceStr](ts-types.md#resourcestr)\| [DrawableDescriptor](../apis/js-apis-arkui-drawableDescriptor.md#drawabledescriptor) | 是 | 图片的数据源,支持本地图片和网络图片,引用方式请参考[加载图片资源](../../ui/arkts-graphics-display.md#加载图片资源)。
1. PixelMap格式为像素图,常用于图片编辑的场景。
2. ResourceStr包含Resource和string格式。
string格式可用于加载网络图片和本地图片,常用于加载网络图片。当使用相对路径引用本地图片时,例如Image("common/test.jpg"),不支持跨包/跨模块调用该Image组件,建议使用Resource格式来管理需全局使用的图片资源。
- 支持`Base64`字符串。格式`data:image/[png\|jpeg\|bmp\|webp];base64,[base64 data]`, 其中`[base64 data]`为`Base64`字符串数据。
- 支持file://路径前缀的字符串。用于读取本应用安装目录下files文件夹下的图片资源。需要保证目录包路径下的文件有可读权限。
Resource格式可以跨包/跨模块访问资源文件,是访问本地图片的推荐方式。
3. 当传入资源id或name为普通图片时,生成DrawableDescriptor对象。
**说明:**
- ArkTS卡片上支持gif图片格式动效,但仅在显示时播放一次。
- ArkTS卡片上不支持http://等网络相关路径前缀和file://路径前缀的字符串。
- ArkTS卡片上不支持 [PixelMap](../apis/js-apis-image.md#pixelmap7)类型。 |
## 属性
-除支持[通用属性](ts-universal-attributes-size.md)外,还支持以下属性:
-
-| 名称 | 参数类型 | 描述 |
-| ------------------------ | ---------------------------------------- | ---------------------------------------- |
-| alt | string \| [Resource](ts-types.md#resource类型) | 加载时显示的占位图,支持本地图片。
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| objectFit | [ImageFit](ts-appendix-enums.md#imagefit) | 设置图片的缩放类型。
默认值:ImageFit.Cover
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| objectRepeat | [ImageRepeat](ts-appendix-enums.md#imagerepeat) | 设置图片的重复样式。
默认值:ImageRepeat.NoRepeat
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。 |
-| interpolation | [ImageInterpolation](#imageinterpolation) | 设置图片的插值效果,即减轻低清晰度图片在放大显示的时候出现的锯齿问题,仅针对图片放大插值。
默认值:ImageInterpolation.None
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。
PixelMap资源不支持该属性。 |
-| renderMode | [ImageRenderMode](#imagerendermode) | 设置图片渲染的模式。
默认值:ImageRenderMode.Original
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。 |
-| sourceSize | {
width: number,
height: number
} | 设置图片裁剪尺寸,将原始图片解码成pixelMap,指定尺寸的图片,单位为px。
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
PixelMap资源和SVG图片不支持该属性。 |
-| matchTextDirection | boolean | 设置图片是否跟随系统语言方向,在RTL语言环境下显示镜像翻转显示效果。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| fitOriginalSize | boolean | 图片组件尺寸未设置时,其显示尺寸是否跟随图源尺寸。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| fillColor | [ResourceColor](ts-types.md#resourcecolor) | 填充颜色。设置的填充颜色会覆盖在图片上。仅对svg图源生效,设置后会替换svg图片的fill颜色。
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| autoResize | boolean | 是否需要在图片解码过程中对图源做resize操作,该操作会根据显示区域的尺寸决定用于绘制的图源尺寸,有利于减少内存占用。
默认值:true
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| syncLoad8+ | boolean | 设置是否同步加载图片,默认是异步加载。同步加载时阻塞UI线程,不会显示占位图。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| copyOption9+ | [CopyOptions](ts-appendix-enums.md#copyoptions9) | 设置图片是否可复制(SVG图片不支持复制)。
当copyOption设置为非CopyOptions.None时,支持使用长按、鼠标右击、快捷组合键'CTRL+C'等方式进行复制。
默认值:CopyOptions.None
该接口支持在ArkTS卡片中使用。 |
-| colorFilter9+ | [ColorFilter](ts-types.md#colorfilter9) | 给图像设置颜色滤镜效果。
该接口支持在ArkTS卡片中使用。 |
-| draggable(deprecated) | boolean | 设置默认拖拽效果。(不能和[onDragStart](ts-universal-events-drag-drop.md)事件同时使用。)
默认值:false
该接口支持在ArkTS卡片中使用。
**说明:**
从 API version 9 开始支持,从 API version 10 开始废弃,建议使用通用属性[draggable](ts-universal-events-drag-drop.md)替代。 |
+属性的详细使用指导请参考[添加属性](../../ui/arkts-graphics-display.md#添加属性)。除支持[通用属性](ts-universal-attributes-size.md)外,还支持以下属性:
+
+| 名称 | 参数类型 | 描述 |
+| -------------------------------- | ------------------------------------------------------- | ------------------------------------------------------------ |
+| alt | string \| [Resource](ts-types.md#resource类型) | 加载时显示的占位图,支持本地图片(png、jpg、bmp、svg和gif类型),不支持网络图片。
默认值:null
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| objectFit | [ImageFit](ts-appendix-enums.md#imagefit) | 设置图片的缩放类型。
默认值:ImageFit.Cover
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| objectRepeat | [ImageRepeat](ts-appendix-enums.md#imagerepeat) | 设置图片的重复样式。从中心点向两边重复,剩余空间不足放下一张图片时会截断。
默认值:ImageRepeat.NoRepeat
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。 |
+| interpolation | [ImageInterpolation](#imageinterpolation) | 设置图片的插值效果,即减轻低清晰度图片在放大显示的时候出现的锯齿问题,仅针对图片放大插值。
默认值:ImageInterpolation.None
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。
PixelMap资源不支持该属性。 |
+| renderMode | [ImageRenderMode](#imagerendermode) | 设置图片的渲染模式为原色或黑白。
默认值:ImageRenderMode.Original
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg类型图源不支持该属性。 |
+| sourceSize | {
width: number,
height: number
} | 设置图片解码尺寸,降低图片的分辨率,常用于需要让图片显示尺寸比组件尺寸更小的场景。和ImageFit.None配合使用时可在组件内显示小图。
单位:px
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
仅在目标尺寸小于图源尺寸时生效。
svg类型图源不支持该属性。
PixelMap资源不支持该属性。 |
+| matchTextDirection | boolean | 设置图片是否跟随系统语言方向,在RTL语言环境下显示镜像翻转显示效果。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| fitOriginalSize | boolean | 图片组件尺寸未设置时,其显示尺寸是否跟随图源尺寸。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| fillColor | [ResourceColor](ts-types.md#resourcecolor) | 设置填充颜色,设置后填充颜色会覆盖在图片上。
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
仅对svg图源生效,设置后会替换svg图片的填充颜色。 |
+| autoResize | boolean | 设置图片解码过程中是否对图源自动缩放。设置为true时,组件会根据显示区域的尺寸决定用于绘制的图源尺寸,有利于减少内存占用。如原图大小为1920x1080,而显示区域大小为200x200,则图片会自动解码到200x200的尺寸,大幅度节省图片占用的内存。
默认值:true
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| syncLoad8+ | boolean | 设置是否同步加载图片,默认是异步加载。同步加载时阻塞UI线程,不会显示占位图。
默认值:false
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
建议加载尺寸较小的本地图片时将syncLoad设为true,因为耗时较短,在主线程上执行即可。 |
+| copyOption9+ | [CopyOptions](ts-appendix-enums.md#copyoptions9) | 设置图片是否可复制。
当copyOption设置为非CopyOptions.None时,支持使用长按、鼠标右击、快捷组合键'CTRL+C'等方式进行复制。
默认值:CopyOptions.None
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
svg图片不支持复制。 |
+| colorFilter9+ | [ColorFilter](ts-types.md#colorfilter9) | 给图像设置颜色滤镜效果,入参为一个的4x5的RGBA转换矩阵。
矩阵第一行表示R(红色)的向量值,第二行表示G(绿色)的向量值,第三行表示B(蓝色)的向量值,第四行表示A(透明度)的向量值,4行分别代表不同的RGBA的向量值。
RGBA值分别是0和1之间的浮点数字,当矩阵对角线值为1时,保持图片原有色彩。
**计算规则:**
如果输入的滤镜矩阵为:
![image-matrix-1](figures/image-matrix-1.jpg)
像素点为[R, G, B, A]
则过滤后的颜色为 [R’, G’, B’, A’]
![image-matrix-2](figures/image-matrix-2.jpg)
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+| draggable(deprecated) | boolean | 设置组件默认拖拽效果,设置为true时,组件可拖拽。
不能和[onDragStart](ts-universal-events-drag-drop.md)事件同时使用。
默认值:false
**说明:**
从 API version 9 开始支持,从 API version 10 开始废弃,建议使用通用属性[draggable](ts-universal-events-drag-drop.md)替代。 |
> **说明:**
>
-> 使用快捷组合键对Image组件复制的前提是,该组件必须处于获焦状态。将Image组件的属性focusable设置为true,即可使用TAB键将焦点切换到Image组件上,再将Image组件的focusOnTouch属性设置为true,即可实现点击获焦。
-> 图片设置svg图源时,支持的标签范围有限,目前支持的svg标签包括svg、rect、circle、ellipse、path、line、polyline、polygon。
+> - 使用快捷组合键对Image组件复制时,Image组件必须处于[获焦状态](../../ui/arkts-common-events-focus-event.md#设置组件是否获焦)。Image组件默认不获焦,需将[focusable](ts-universal-attributes-focus.md)属性设置为true,即可使用TAB键将焦点切换到组件上,再将[focusOnTouch](ts-universal-attributes-focus.md)属性设置为true,即可实现点击获焦。
+> - 图片设置为svg图源时,当前支持的标签是svg、rect、circle、ellipse、path、line、polyline和polygon。
-### ImageInterpolation
+## ImageInterpolation
从API version 9开始,该接口支持在ArkTS卡片中使用。
-| 名称 | 描述 |
-| ------ | ------------------------- |
-| None | 不使用插值图片数据。 |
-| High | 插值图片数据的使用率高,可能会影响图片渲染的速度。 |
-| Medium | 插值图片数据的使用率中。 |
-| Low | 插值图片数据的使用率低。 |
+| 名称 | 描述 |
+| ------ | ---------------------------------------------------- |
+| None | 不使用图片插值。 |
+| High | 高图片插值,插值质量最高,可能会影响图片渲染的速度。 |
+| Medium | 中图片插值。 |
+| Low | 低图片插值。 |
-### ImageRenderMode
+## ImageRenderMode
从API version 9开始,该接口支持在ArkTS卡片中使用。
-| 名称 | 描述 |
-| -------- | --------------------- |
-| Original | 按照原图进行渲染,包括颜色。 |
-| Template | 将图片渲染为模板图片,忽略图片的颜色信息。 |
+| 名称 | 描述 |
+| -------- | -------------- |
+| Original | 原色渲染模式。 |
+| Template | 黑白渲染模式。 |
## 事件
除支持[通用事件](ts-universal-events-click.md)外,还支持以下事件:
-| 名称 | 功能描述 |
-| ---------------------------------------- | ---------------------------------------- |
-| onComplete(callback: (event?: { width: number, height: number,
componentWidth: number, componentHeight: number,
loadingStatus: number ,contentWidth10+: number,
contentHeight10+: number, contentOffsetX10+: number,
contentOffsetY10+: number}) => void) | 图片成功加载时触发该回调,返回成功加载的图片尺寸。
- width:图片的宽,单位为像素。
- height:图片的高,单位为像素。
- componentWidth:组件的宽,单位为像素。
- componentHeight:组件的高,单位为像素。
- loadingStatus:图片加载成功的状态。
- contentWidth:图片实际绘制的宽度,单位为像素。
- contentHeight:图片实际绘制的高度,单位为像素。
- contentOffsetX:实际绘制内容相对于组件自身的x轴偏移,单位为像素。
- contentOffsetY:实际绘制内容相对于组件自身的y轴偏移,单位为像素。
从API version 9开始,该接口支持在ArkTS卡片中使用。
**说明:**
loadingStatus返回的状态值为0时,代表图片加载失败;返回的状态值为1时,代表图片加载成功, API version 10新增属性仅在loadingStatus返回1时有效。 |
-| onError(callback: (event?: { componentWidth: number, componentHeight: number , message9+: string }) => void) | 图片加载出现异常时触发该回调。
- componentWidth:组件的宽,单位为像素。
- componentHeight:组件的高,单位为像素。
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
-| onFinish(event: () => void) | 当加载的源文件为带动效的svg图片时,当svg动效播放完成时会触发这个回调,如果动效为无限循环动效,则不会触发这个回调。
从API version 9开始,该接口支持在ArkTS卡片中使用。 |
+### onComplete
+
+onComplete(callback: (event?: { width: number, height: number, componentWidth: number, componentHeight: number, loadingStatus: number,contentWidth: number, contentHeight: number, contentOffsetX: number, contentOffsetY: number}) => void) }) => void)
+
+图片数据加载成功和解码成功时均触发该回调,返回成功加载的图片尺寸。
+
+从API version 9开始,该接口支持在ArkTS卡片中使用。
+
+**参数:**
+
+| 参数名 | 类型 | 说明 |
+| ---------------------------- | ------ | ------------------------------------------------------------ |
+| width | number | 图片的宽。
单位:像素 |
+| height | number | 图片的高。
单位:像素 |
+| componentWidth | number | 组件的宽。
单位:像素 |
+| componentHeight | number | 组件的高。
单位:像素 |
+| loadingStatus | number | 图片加载成功的状态值。
**说明:**
返回的状态值为0时,表示图片数据加载成功。返回的状态值为1时,表示图片解码成功。 |
+| contentWidth10+ | number | 图片实际绘制的宽度。
单位:像素
**说明:**
仅在loadingStatus返回1时有效。 |
+| contentHeight10+ | number | 图片实际绘制的高度。
单位:像素
**说明:**
仅在loadingStatus返回1时有效。 |
+| contentOffsetX10+ | number | 实际绘制内容相对于组件自身的x轴偏移。
单位:像素
**说明:**
仅在loadingStatus返回1时有效。 |
+| contentOffsetY10+ | number | 实际绘制内容相对于组件自身的y轴偏移。
单位:像素
**说明:**
仅在loadingStatus返回1时有效。 |
+
+
+### onError
+
+onError(callback: (event?: { componentWidth: number, componentHeight: number , message: string }) => void)
+
+图片加载异常时触发该回调。
+
+从API version 9开始,该接口支持在ArkTS卡片中使用。
+
+**参数:**
+
+| 参数名 | 类型 | 说明 |
+| -------------------- | ------ | ------------------------- |
+| componentWidth | number | 组件的宽。
单位:像素 |
+| componentHeight | number | 组件的高。
单位:像素 |
+| message9+ | string | 报错信息。 |
+
+
+### onFinish
+
+onFinish(event: () => void)
+
+当加载的源文件为带动效的svg格式图片时,svg动效播放完成时会触发这个回调。如果动效为无限循环动效,则不会触发这个回调。
+
+仅支持svg格式的图片。
+
+从API version 9开始,该接口支持在ArkTS卡片中使用。
## 示例
-### 图片加载
+### 加载基本类型图片
-加载显示不同类型的图片,并设置图片的缩放类型。
overlay属性用于设置图片的遮罩文本,具体使用可参考[浮层](ts-universal-attributes-overlay.md)。
```ts
@Entry
@@ -100,178 +145,70 @@ struct ImageExample1 {
build() {
Column() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Start }) {
- Row({ space: 5 }) {
- Image($r('app.media.example_png'))
- .width(110).height(110).border({ width: 1 })
+ Row() {
+ // 加载png格式图片
+ Image($r('app.media.ic_camera_master_ai_leaf'))
+ .width(110).height(110).margin(15)
.overlay('png', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.example_gif'))
- .width(110).height(110).border({ width: 1 })
+ // 加载gif格式图片
+ Image($r('app.media.loading'))
+ .width(110).height(110).margin(15)
.overlay('gif', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
}
-
- Row({ space: 5 }) {
- Image($r('app.media.example_svg'))
- .width(110).height(110).border({ width: 1 })
+ Row() {
+ // 加载svg格式图片
+ Image($r('app.media.ic_camera_master_ai_clouded'))
+ .width(110).height(110).margin(15)
.overlay('svg', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.example_jpg'))
- .width(110).height(110).border({ width: 1 })
+ // 加载jpg格式图片
+ Image($r('app.media.ic_public_favor_filled'))
+ .width(110).height(110).margin(15)
.overlay('jpg', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- }.margin({ top: 25, bottom: 10 })
+ }
}
}.height(320).width(360).padding({ right: 10, top: 10 })
}
}
```
-![zh-cn_image_0000001250492613](figures/zh-cn_image_0000001250492613.gif)
+![zh-cn_image_0000001592882500](figures/zh-cn_image_0000001592882500.gif)
+### 加载网络图片
+加载网络图片时,默认网络超时是5分钟,建议使用alt配置加载时的占位图。如果需要更灵活的网络配置,可以使用[HTTP](../../connectivity/http-request.md)工具包发送网络请求,接着将返回的数据解码为Image组件中的`PixelMap`,图片开发可参考[图片处理](../../media/image-overview.md)。
-### 网络图片
-
-加载网络图片时,默认网络超时是5分钟,建议使用alt配置加载时的占位图。如果需要更灵活的网络配置,可以使用SDK中提供的[HTTP](../../connectivity/http-request.md)工具包发送网络请求,接着将返回的数据解码为Image组件中的`PixelMap`,图片开发可参考[图片处理](../../media/image-overview.md)。代码如下。
-
-```tsx
-// @ts-nocheck
-import http from '@ohos.net.http';
-import ResponseCode from '@ohos.net.http'
-import image from '@ohos.multimedia.image'
-
-
-@Entry
-@Component
-struct Index {
-
- // 先创建一个PixelMap状态变量用于接收网络图片
- @State image: PixelMap = undefined
-
- build() {
- Column({space: 10}) {
- Button("获取网络图片")
- .onClick(() => {
- this.httpRequest()
- })
- Image(this.image).height(100).width(100)
- }
- .width('100%')
- .height('100%')
- .padding(10)
- }
-
- // 网络图片请求方法
- private httpRequest() {
- let httpRequest = http.createHttp()
-
- httpRequest.request(
- "https://www.example.com/xxx.png", // 请填写一个具体的网络图片地址
- (error, data) => {
- if(error) {
- console.log("error code: " + error.code + ", msg: " + error.message)
- } else {
- let code = data.responseCode
- if(ResponseCode.ResponseCode.OK == code) {
- let imageSource = image.createImageSource(data.result)
- let options = {alphaType: 0, // 透明度
- editable: false, // 是否可编辑
- pixelFormat: 3, // 像素格式
- scaleMode: 1, // 缩略值
- size: {height: 100, width: 100}} // 创建图片大小
- imageSource.createPixelMap(options).then((pixelMap) => {
- this.image = pixelMap
- })
- } else {
- console.log("response code: " + code)
- }
- }
- }
- )
- }
-}
-```
-
-**说明**:网络图片加载的请求方式、超时、额外请求参数等配置可以参考HTTP工具包中关于[`request()`](../../reference/apis/js-apis-http.md)请求方法的细节。
-
-### 设置属性
+使用网络图片时,需要申请权限ohos.permission.INTERNET。具体申请方式请参考[权限申请声明](../../security/accesstoken-guidelines.md)。
```ts
@Entry
@Component
struct ImageExample2 {
-
build() {
Column({ space: 10 }) {
- Text('renderMode').fontSize(12).fontColor(0xcccccc).width('96%').height(30)
- Row({ space: 50 }) {
- Image($r('app.media.img_example'))
- .renderMode(ImageRenderMode.Original).width(100).height(100)
- .border({ width: 1 })
- .overlay('Original', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.img_example'))
- .renderMode(ImageRenderMode.Template).width(100).height(100)
- .border({ width: 1 })
- .overlay('Template', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- }
-
- Text('alt').fontSize(12).fontColor(0xcccccc).width('96%').height(30)
- Image('')
- .alt($r('app.media.Image_none'))
- .width(100).height(100).border({ width: 1 })
-
- Text('sourceSize').fontSize(12).fontColor(0xcccccc).width('96%')
- Row({ space: 50 }) {
- Image($r('app.media.img_example'))
- .sourceSize({
- width: 150,
- height: 150
- })
- .objectFit(ImageFit.ScaleDown).width('25%').aspectRatio(1)
- .border({ width: 1 })
- .overlay('w:150 h:150', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.img_example'))
- .sourceSize({
- width: 200,
- height: 200
- })
- .objectFit(ImageFit.ScaleDown).width('25%').aspectRatio(1)
- .border({ width: 1 })
- .overlay('w:200 h:200', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- }
-
- Text('objectRepeat').fontSize(12).fontColor(0xcccccc).width('96%').height(30)
- Row({ space: 5 }) {
- Image($r('app.media.ic_health_heart'))
- .width(120).height(125).border({ width: 1 })
- .objectRepeat(ImageRepeat.XY).objectFit(ImageFit.ScaleDown)
- .overlay('ImageRepeat.XY', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.ic_health_heart'))
- .width(110).height(125).border({ width: 1 })
- .objectRepeat(ImageRepeat.Y).objectFit(ImageFit.ScaleDown)
- .overlay('ImageRepeat.Y', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- Image($r('app.media.ic_health_heart'))
- .width(110).height(125).border({ width: 1 })
- .objectRepeat(ImageRepeat.X).objectFit(ImageFit.ScaleDown)
- .overlay('ImageRepeat.X', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
- }
- }.height(150).width('100%').padding({ right: 10 })
+ Image("https://www.example.com/xxx.png")// 直接加载网络地址,请填写一个具体的网络图片地址
+ .alt($r('app.media.icon'))// 使用alt,在网络图片加载成功前使用占位图
+ .width(100)
+ .height(100)
+ }
}
}
```
-![zh-cn_image_0000001205812616](figures/zh-cn_image_0000001205812616.png)
-### 事件调用
+### 为图片添加事件
+
```ts
@Entry
@Component
struct ImageExample3 {
- @State widthValue: number = 0
- @State heightValue: number = 0
- private on: Resource = $r('app.media.image_on')
- private off: Resource = $r('app.media.image_off')
- private on2off: Resource = $r('app.media.image_on2off')
- private off2on: Resource = $r('app.media.image_off2on')
- @State src: Resource = this.on
+ @State widthValue: number = 0;
+ @State heightValue: number = 0;
+ private on: Resource = $r('app.media.image_on');
+ private off: Resource = $r('app.media.image_off');
+ private on2off: Resource = $r('app.media.image_on2off');
+ private off2on: Resource = $r('app.media.image_off2on');
+ @State src: Resource = this.on;
build() {
Column() {
@@ -298,7 +235,7 @@ struct ImageExample3 {
offset: { x: 0, y: 20 }
})
}
- // 为图片添加点击事件,点击完成后加载特定图片。
+ // 为图片添加点击事件,点击完成后加载特定图片
Image(this.src)
.width(120).height(120)
.onClick(() => {
@@ -321,144 +258,4 @@ struct ImageExample3 {
}
```
-![zh-cn_image_0000001205972610](figures/zh-cn_image_0000001205972610.gif)
-
-### 渲染沙箱路径图片
-
-```ts
-import fileio from '@ohos.fileio';
-import fs from '@ohos.file.fs';
-import context from '@ohos.app.ability.common';
-
-@Entry
-@Component
-struct LoadImageExample {
- @State resourcesPath: string = ''
- @State sandboxPath: string = ''
- context: context.UIAbilityContext = getContext(this) as context.UIAbilityContext
-
- build() {
- Column() {
- Button('读取沙箱图片')
- .margin({ bottom: 10, top: 10 })
- .onClick(() => {
- this.sandboxPath = this.context.getApplicationContext().filesDir + '/icon.png'
- console.log(`读取沙箱图片=========>${this.sandboxPath}`)
- let fd = fs.openSync(this.sandboxPath, 0o100)
- console.log(`create file========>${fd}`)
- let srcPath = this.context.bundleCodeDir + '/entry/resources/base/media/icon.png'
- console.log('mySrcpath' + srcPath)
- fileio.copyFileSync(srcPath, this.sandboxPath) // 复制图片到沙箱路径
- this.sandboxPath = 'file://' + this.context.getApplicationContext().filesDir + '/icon.png'
- })
- Button('读取资源图片')
- .margin({ bottom: 10 })
- .onClick(() => {
- this.resourcesPath = 'file://' + this.context.bundleCodeDir + '/entry/resources/base/media/icon.png'
- })
- Text(`资源图片路径:${this.resourcesPath}`)
- .fontSize(20)
- .margin({ bottom: 10 })
- Image(this.resourcesPath)
- .width(100)
- .height(100)
- .colorFilter([
- 0.30, 0.59, 0.11, 0, 0,
- 0.30, 0.59, 0.11, 0, 0,
- 0.30, 0.59, 0.11, 0, 0,
- 0, 0, 0, 1.0, 0
- ])
- Text(`沙箱图片路径:${this.sandboxPath}`)
- .fontSize(20)
- .margin({ bottom: 10 })
- Image(this.sandboxPath)
- .width(100)
- .height(100)
- }
- .width('100%').height('100%')
- }
-}
-```
-
-### 为图片增加滤镜
-
-```ts
-// xxx.ets
-@Entry
-@Component
-struct colorFilterExample {
- @State colorFilterR: number = 0
- @State colorFilterG: number = 0
- @State colorFilterB: number = 0
- @State colorFilterA: number = 0
-
- build() {
- Row() {
- Column() {
- Image($r('app.media.sky'))
- .width(200)
- .height(200)
- Image($r('app.media.sky'))
- .width(200)
- .height(200)
- .colorFilter([
- this.colorFilterR, 0, this.colorFilterR, 0, 0,
- 0, this.colorFilterG, this.colorFilterG, 0, 0,
- this.colorFilterB, 0, this.colorFilterB, 0, 0,
- 0, 0, this.colorFilterA, 0, 0
- ])
-
- Row() {
- Text('R')
- Slider({
- min: 0,
- max: 1,
- step: 0.01
- })
- .onChange((valueR) => {
- this.colorFilterR = valueR
- })
- }
-
- Row() {
- Text('G')
- Slider({
- min: 0,
- max: 1,
- step: 0.01
- })
- .onChange((valueG) => {
- this.colorFilterG = valueG
- })
- }
-
- Row() {
- Text('B')
- Slider({
- min: 0,
- max: 1,
- step: 0.01
- })
- .onChange((valueB) => {
- this.colorFilterB = valueB
- })
- }
-
- Row() {
- Text('A')
- Slider({
- min: 0,
- max: 1,
- step: 0.01
- })
- .onChange((valueA) => {
- this.colorFilterA = valueA
- })
- }
- }.width('90%').alignItems(HorizontalAlign.Center)
- }.height('100%').width('100%').justifyContent(FlexAlign.Center)
- }
-}
-```
-
-![colorFilter](figures/colorFilter.gif)
\ No newline at end of file
+![zh-cn_image_0000001607845173](figures/zh-cn_image_0000001607845173.gif)
\ No newline at end of file
diff --git a/zh-cn/application-dev/ui/arkts-graphics-display.md b/zh-cn/application-dev/ui/arkts-graphics-display.md
index 111cc1576008265d0c9854a1c958eb84ab43bd9c..87c8dd307cbf0141424c8706c21e744b7ecdaa08 100644
--- a/zh-cn/application-dev/ui/arkts-graphics-display.md
+++ b/zh-cn/application-dev/ui/arkts-graphics-display.md
@@ -9,7 +9,7 @@ Image通过调用接口来创建,接口调用形式如下:
```ts
-Image(src: string | Resource | media.PixelMap)
+Image(src: PixelMap | ResourceStr | DrawableDescriptor)
```
@@ -70,9 +70,9 @@ Image支持加载存档图、多媒体像素图两种类型。
Image($rawfile('snap'))
```
-- 媒体库datashare
+- 媒体库file://data/storage
- 支持datashare://路径前缀的字符串,用于访问通过媒体库提供的图片路径。
+ 支持file://路径前缀的字符串,用于访问通过媒体库提供的图片路径。
1. 调用接口获取图库的照片url。
@@ -124,7 +124,7 @@ Image支持加载存档图、多媒体像素图两种类型。
2. 从媒体库获取的url格式通常如下。
```ts
- Image('file://media/5')
+ Image('file://media/Photos/5')
.width(200)
```
@@ -146,6 +146,7 @@ PixelMap是图片解码后的像素图,具体用法请参考[图片开发指
```
2. 引用多媒体。
+
请求网络图片请求,解码编码PixelMap。
1. 引用网络权限与媒体库权限。
@@ -272,7 +273,216 @@ struct MyComponent {
}
```
-![zh-cn_image_0000001511421240](figures/zh-cn_image_0000001511421240.png)
+![zh-cn_image_0000001622804833](figures/zh-cn_image_0000001622804833.png)
+
+
+### 图片插值
+
+当原图分辨率较低并且放大显示时,图片会模糊出现锯齿。这时可以使用interpolation属性对图片进行插值,使图片显示得更清晰。
+
+
+```ts
+@Entry
+@Component
+struct Index {
+ build() {
+ Column() {
+ Row() {
+ Image($r('app.media.grass'))
+ .width('40%')
+ .interpolation(ImageInterpolation.None)
+ .borderWidth(1)
+ .overlay("Interpolation.None", { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ .margin(10)
+ Image($r('app.media.grass'))
+ .width('40%')
+ .interpolation(ImageInterpolation.Low)
+ .borderWidth(1)
+ .overlay("Interpolation.Low", { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ .margin(10)
+ }.width('100%')
+ .justifyContent(FlexAlign.Center)
+
+ Row() {
+ Image($r('app.media.grass'))
+ .width('40%')
+ .interpolation(ImageInterpolation.Medium)
+ .borderWidth(1)
+ .overlay("Interpolation.Medium", { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ .margin(10)
+ Image($r('app.media.grass'))
+ .width('40%')
+ .interpolation(ImageInterpolation.High)
+ .borderWidth(1)
+ .overlay("Interpolation.High", { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ .margin(10)
+ }.width('100%')
+ .justifyContent(FlexAlign.Center)
+ }
+ .height('100%')
+ }
+}
+```
+
+![zh-cn_image_0000001643127365](figures/zh-cn_image_0000001643127365.png)
+
+
+### 设置图片重复样式
+
+通过objectRepeat属性设置图片的重复样式方式,重复样式请参考[ImageRepeat](../reference/arkui-ts/ts-appendix-enums.md#imagerepeat)枚举说明。
+
+
+```ts
+@Entry
+@Component
+struct MyComponent {
+ build() {
+ Column({ space: 10 }) {
+ Row({ space: 5 }) {
+ Image($r('app.media.ic_public_favor_filled_1'))
+ .width(110)
+ .height(115)
+ .border({ width: 1 })
+ .objectRepeat(ImageRepeat.XY)
+ .objectFit(ImageFit.ScaleDown)
+ // 在水平轴和竖直轴上同时重复绘制图片
+ .overlay('ImageRepeat.XY', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ Image($r('app.media.ic_public_favor_filled_1'))
+ .width(110)
+ .height(115)
+ .border({ width: 1 })
+ .objectRepeat(ImageRepeat.Y)
+ .objectFit(ImageFit.ScaleDown)
+ // 只在竖直轴上重复绘制图片
+ .overlay('ImageRepeat.Y', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ Image($r('app.media.ic_public_favor_filled_1'))
+ .width(110)
+ .height(115)
+ .border({ width: 1 })
+ .objectRepeat(ImageRepeat.X)
+ .objectFit(ImageFit.ScaleDown)
+ // 只在水平轴上重复绘制图片
+ .overlay('ImageRepeat.X', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ }
+ }.height(150).width('100%').padding(8)
+ }
+}
+```
+
+![zh-cn_image_0000001593444112](figures/zh-cn_image_0000001593444112.png)
+
+
+### 设置图片渲染模式
+
+通过renderMode属性设置图片的渲染模式为原色或黑白。
+
+
+```ts
+@Entry
+@Component
+struct MyComponent {
+ build() {
+ Column({ space: 10 }) {
+ Row({ space: 50 }) {
+ Image($r('app.media.example'))
+ // 设置图片的渲染模式为原色
+ .renderMode(ImageRenderMode.Original)
+ .width(100)
+ .height(100)
+ .border({ width: 1 })
+ // overlay是通用属性,用于在组件上显示说明文字
+ .overlay('Original', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ Image($r('app.media.example'))
+ // 设置图片的渲染模式为黑白
+ .renderMode(ImageRenderMode.Template)
+ .width(100)
+ .height(100)
+ .border({ width: 1 })
+ .overlay('Template', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
+ }
+ }.height(150).width('100%').padding({ top: 20,right: 10 })
+ }
+}
+```
+
+![zh-cn_image_0000001593293100](figures/zh-cn_image_0000001593293100.png)
+
+
+### 设置图片解码尺寸
+
+通过sourceSize属性设置图片解码尺寸,降低图片的分辨率。
+
+原图尺寸为1280\*960,该示例将图片解码为150\*100和400\*400。
+
+
+```ts
+@Entry
+@Component
+struct Index {
+ build() {
+ Column() {
+ Row({ space: 20 }) {
+ Image($r('app.media.example'))
+ .sourceSize({
+ width: 150,
+ height: 150
+ })
+ .objectFit(ImageFit.ScaleDown)
+ .width('25%')
+ .aspectRatio(1)
+ .border({ width: 1 })
+ .overlay('width:150 height:150', { align: Alignment.Bottom, offset: { x: 0, y: 40 } })
+ Image($r('app.media.example'))
+ .sourceSize({
+ width: 400,
+ height: 400
+ })
+ .objectFit(ImageFit.ScaleDown)
+ .width('25%')
+ .aspectRatio(1)
+ .border({ width: 1 })
+ .overlay('width:400 height:400', { align: Alignment.Bottom, offset: { x: 0, y: 40 } })
+ }.height(150).width('100%').padding(20)
+
+ }
+ }
+}
+```
+
+![zh-cn_image_0000001593769844](figures/zh-cn_image_0000001593769844.png)
+
+
+### 为图片添加滤镜效果
+
+通过colorFilter修改图片的像素颜色,为图片添加滤镜。
+
+
+```ts
+@Entry
+@Component
+struct Index {
+ build() {
+ Column() {
+ Row() {
+ Image($r('app.media.example'))
+ .width('40%')
+ .margin(10)
+ Image($r('app.media.example'))
+ .width('40%')
+ .colorFilter(
+ [1, 1, 0, 0, 0,
+ 0, 1, 0, 0, 0,
+ 0, 0, 1, 0, 0,
+ 0, 0, 0, 1, 0])
+ .margin(10)
+ }.width('100%')
+ .justifyContent(FlexAlign.Center)
+ }
+ }
+}
+```
+
+![zh-cn_image_0000001643171357](figures/zh-cn_image_0000001643171357.png)
### 同步加载图片
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593293100.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593293100.png
new file mode 100644
index 0000000000000000000000000000000000000000..219903664ec5a078311c94aea36d400d378bb999
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593293100.png differ
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593444112.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593444112.png
new file mode 100644
index 0000000000000000000000000000000000000000..e9542d910023d1105619589525c50312eff59e9b
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593444112.png differ
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593769844.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593769844.png
new file mode 100644
index 0000000000000000000000000000000000000000..2d55f958227b92833b2fe4e4e5b65a5535b7b807
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001593769844.png differ
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001622804833.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001622804833.png
new file mode 100644
index 0000000000000000000000000000000000000000..1dcef5d17c1a081235b1ce2fb61878675a1c15ab
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001622804833.png differ
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643127365.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643127365.png
new file mode 100644
index 0000000000000000000000000000000000000000..c93a6e87b1d4f5eb0da5a6bb993285d2d742d8f0
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643127365.png differ
diff --git a/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643171357.png b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643171357.png
new file mode 100644
index 0000000000000000000000000000000000000000..b9680fe616ccf50248ecd353256f336e2cb23bf1
Binary files /dev/null and b/zh-cn/application-dev/ui/figures/zh-cn_image_0000001643171357.png differ