1e41f4b71Sopenharmony_ci# image-animator
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ci>  **说明:**
4e41f4b71Sopenharmony_ci>  从API version 4开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
5e41f4b71Sopenharmony_ci
6e41f4b71Sopenharmony_ci图片帧动画播放器。
7e41f4b71Sopenharmony_ci
8e41f4b71Sopenharmony_ci
9e41f4b71Sopenharmony_ci## 子组件
10e41f4b71Sopenharmony_ci
11e41f4b71Sopenharmony_ci不支持。
12e41f4b71Sopenharmony_ci
13e41f4b71Sopenharmony_ci
14e41f4b71Sopenharmony_ci## 属性
15e41f4b71Sopenharmony_ci
16e41f4b71Sopenharmony_ci除支持[通用属性](js-components-common-attributes.md)外,还支持如下属性:
17e41f4b71Sopenharmony_ci
18e41f4b71Sopenharmony_ci| 名称                     | 类型                         | 默认值      | 必填   | 描述                                       |
19e41f4b71Sopenharmony_ci| ---------------------- | -------------------------- | -------- | ---- | ---------------------------------------- |
20e41f4b71Sopenharmony_ci| images                 | Array&lt;ImageFrame&gt;    | -        | 是    | 设置图片帧信息集合。每一帧的帧信息包含图片路径、图片大小和图片位置信息。目前支持以下图片格式:png、jpg。ImageFrame的详细说明请见表 ImageFrame说明。<br/>使用时需要使用数据绑定的方式:<br>- hml文件中引用图片资源:`images = {{images}}`,<br>- js文件中声明相应变量:<br>`images: [{src: "/common/heart-rate01.png",duration:"100"}]`。从API Version 6 开始,支持配置每一帧图片的时长,单位毫秒。 |
21e41f4b71Sopenharmony_ci| predecode<sup>6+</sup> | number                     | 0        | 否    | 是否启用预解码,默认值为0,即不启用预解码,如该值设为2,则播放当前页时会提前加载后面两张图片至缓存以提升性能。 |
22e41f4b71Sopenharmony_ci| iteration              | number&nbsp;\|&nbsp;string | infinite | 否    | 设置帧动画播放次数。number表示固定次数,infinite枚举表示无限次数播放。 |
23e41f4b71Sopenharmony_ci| reverse                | boolean                    | false    | 否    | 设置播放顺序。false表示从第1张图片播放到最后1张图片;&nbsp;true表示从最后1张图片播放到第1张图片。 |
24e41f4b71Sopenharmony_ci| fixedsize              | boolean                    | true     | 否    | 设置图片大小是否固定为组件大小。&nbsp;true表示图片大小与组件大小一致,此时设置图片的width&nbsp;、height&nbsp;、top&nbsp;和left属性是无效的。false表示每一张图片的&nbsp;width&nbsp;、height&nbsp;、top和left属性都要单独设置。 |
25e41f4b71Sopenharmony_ci| duration               | string                     | -        | 是    | 设置单次播放时长。单位支持[s(秒)\|ms(毫秒)],默认单位为ms。&nbsp;duration为0时,不播放图片。&nbsp;值改变只会在下一次循环开始时生效,当images中设置了单独的duration后,该属性设置无效。 |
26e41f4b71Sopenharmony_ci| fillmode<sup>5+</sup>  | string                     | forwards | 否    | 指定帧动画执行结束后的状态。可选项有:<br/>-&nbsp;none:恢复初始状态。<br/>-&nbsp;forwards:保持帧动画结束时的状态(在最后一个关键帧中定义)。 |
27e41f4b71Sopenharmony_ci
28e41f4b71Sopenharmony_ci**表1** ImageFrame说明
29e41f4b71Sopenharmony_ci
30e41f4b71Sopenharmony_ci| 名称                    | 类型             | 默认值  | 必填   | 描述                     |
31e41f4b71Sopenharmony_ci| --------------------- | -------------- | ---- | ---- | ---------------------- |
32e41f4b71Sopenharmony_ci| src                   | &lt;uri&gt;    | -    | 是    | 图片路径,图片格式支持svg、png、jpg和heif。 |
33e41f4b71Sopenharmony_ci| width                 | &lt;length&gt; | 0    | 否    | 图片宽度。                  |
34e41f4b71Sopenharmony_ci| height                | &lt;length&gt; | 0    | 否    | 图片高度。                  |
35e41f4b71Sopenharmony_ci| top                   | &lt;length&gt; | 0    | 否    | 图片相对于组件左上角的纵向坐标。       |
36e41f4b71Sopenharmony_ci| left                  | &lt;length&gt; | 0    | 否    | 图片相对于组件左上角的横向坐标。       |
37e41f4b71Sopenharmony_ci| duration<sup>6+</sup> | number         | -    | 否    | 每一帧图片的播放时长,单位毫秒。       |
38e41f4b71Sopenharmony_ci
39e41f4b71Sopenharmony_ci
40e41f4b71Sopenharmony_ci## 样式
41e41f4b71Sopenharmony_ci
42e41f4b71Sopenharmony_ci支持[通用样式](js-components-common-styles.md)。
43e41f4b71Sopenharmony_ci
44e41f4b71Sopenharmony_ci
45e41f4b71Sopenharmony_ci## 事件
46e41f4b71Sopenharmony_ci
47e41f4b71Sopenharmony_ci除支持[通用事件](js-components-common-events.md)外,还支持如下事件:
48e41f4b71Sopenharmony_ci
49e41f4b71Sopenharmony_ci| 名称     | 参数   | 描述        |
50e41f4b71Sopenharmony_ci| ------ | ---- | --------- |
51e41f4b71Sopenharmony_ci| start  | -    | 帧动画启动时触发。 |
52e41f4b71Sopenharmony_ci| pause  | -    | 帧动画暂停时触发。 |
53e41f4b71Sopenharmony_ci| stop   | -    | 帧动画结束时触发。 |
54e41f4b71Sopenharmony_ci| resume | -    | 帧动画恢复时触发。 |
55e41f4b71Sopenharmony_ci
56e41f4b71Sopenharmony_ci
57e41f4b71Sopenharmony_ci## 方法
58e41f4b71Sopenharmony_ci
59e41f4b71Sopenharmony_ci支持[通用方法](js-components-common-methods.md)外,还支持如下方法:
60e41f4b71Sopenharmony_ci
61e41f4b71Sopenharmony_ci| 名称       | 参数   | 描述                                       |
62e41f4b71Sopenharmony_ci| -------- | ---- | ---------------------------------------- |
63e41f4b71Sopenharmony_ci| start    | -    | 开始播放图片帧动画。再次调用,重新从第1帧开始播放。               |
64e41f4b71Sopenharmony_ci| pause    | -    | 暂停播放图片帧动画。                               |
65e41f4b71Sopenharmony_ci| stop     | -    | 停止播放图片帧动画。                               |
66e41f4b71Sopenharmony_ci| resume   | -    | 继续播放图片帧。                                 |
67e41f4b71Sopenharmony_ci| getState | -    | 获取播放状态。<br/>-&nbsp;playing:播放中<br/>-&nbsp;paused:已暂停<br/>-&nbsp;stopped:已停止。 |
68e41f4b71Sopenharmony_ci
69e41f4b71Sopenharmony_ci
70e41f4b71Sopenharmony_ci## 示例
71e41f4b71Sopenharmony_ci
72e41f4b71Sopenharmony_ci```html
73e41f4b71Sopenharmony_ci<!-- xxx.hml -->
74e41f4b71Sopenharmony_ci<div class="container">
75e41f4b71Sopenharmony_ci  <image-animator class="animator" ref="animator" images="{{frames}}" duration="1s" />
76e41f4b71Sopenharmony_ci  <div class="btn-box">
77e41f4b71Sopenharmony_ci    <input class="btn" type="button" value="start" @click="handleStart" />
78e41f4b71Sopenharmony_ci    <input class="btn" type="button" value="stop" @click="handleStop" />
79e41f4b71Sopenharmony_ci    <input class="btn" type="button" value="pause" @click="handlePause" />
80e41f4b71Sopenharmony_ci    <input class="btn" type="button" value="resume" @click="handleResume" />
81e41f4b71Sopenharmony_ci  </div>
82e41f4b71Sopenharmony_ci</div>
83e41f4b71Sopenharmony_ci```
84e41f4b71Sopenharmony_ci
85e41f4b71Sopenharmony_ci```css
86e41f4b71Sopenharmony_ci/* xxx.css */
87e41f4b71Sopenharmony_ci.container {
88e41f4b71Sopenharmony_ci  flex-direction: column;
89e41f4b71Sopenharmony_ci  justify-content: center;
90e41f4b71Sopenharmony_ci  align-items: center;
91e41f4b71Sopenharmony_ci  left: 0px;
92e41f4b71Sopenharmony_ci  top: 0px;
93e41f4b71Sopenharmony_ci  width: 454px;
94e41f4b71Sopenharmony_ci  height: 454px;
95e41f4b71Sopenharmony_ci}
96e41f4b71Sopenharmony_ci.animator {
97e41f4b71Sopenharmony_ci  width: 70px;
98e41f4b71Sopenharmony_ci  height: 70px;
99e41f4b71Sopenharmony_ci}
100e41f4b71Sopenharmony_ci.btn-box {
101e41f4b71Sopenharmony_ci  width: 264px;
102e41f4b71Sopenharmony_ci  height: 120px;
103e41f4b71Sopenharmony_ci  flex-wrap: wrap;
104e41f4b71Sopenharmony_ci  justify-content: space-around;
105e41f4b71Sopenharmony_ci  align-items: center;
106e41f4b71Sopenharmony_ci}
107e41f4b71Sopenharmony_ci.btn {
108e41f4b71Sopenharmony_ci  border-radius: 8px;
109e41f4b71Sopenharmony_ci  width: 120px;
110e41f4b71Sopenharmony_ci  margin-top: 8px;
111e41f4b71Sopenharmony_ci}
112e41f4b71Sopenharmony_ci```
113e41f4b71Sopenharmony_ci
114e41f4b71Sopenharmony_ci```js
115e41f4b71Sopenharmony_ci//xxx.js
116e41f4b71Sopenharmony_ciexport default {
117e41f4b71Sopenharmony_ci  data: {
118e41f4b71Sopenharmony_ci    frames: [
119e41f4b71Sopenharmony_ci      {
120e41f4b71Sopenharmony_ci        src: "/common/asserts/heart78.png",
121e41f4b71Sopenharmony_ci      },
122e41f4b71Sopenharmony_ci      {
123e41f4b71Sopenharmony_ci        src: "/common/asserts/heart79.png",
124e41f4b71Sopenharmony_ci      },
125e41f4b71Sopenharmony_ci      {
126e41f4b71Sopenharmony_ci        src: "/common/asserts/heart80.png",
127e41f4b71Sopenharmony_ci      },
128e41f4b71Sopenharmony_ci      {
129e41f4b71Sopenharmony_ci        src: "/common/asserts/heart81.png",
130e41f4b71Sopenharmony_ci      },
131e41f4b71Sopenharmony_ci      {
132e41f4b71Sopenharmony_ci        src: "/common/asserts/heart82.png",
133e41f4b71Sopenharmony_ci      },
134e41f4b71Sopenharmony_ci      {
135e41f4b71Sopenharmony_ci        src: "/common/asserts/heart83.png",
136e41f4b71Sopenharmony_ci      },
137e41f4b71Sopenharmony_ci      {
138e41f4b71Sopenharmony_ci        src: "/common/asserts/heart84.png",
139e41f4b71Sopenharmony_ci      },
140e41f4b71Sopenharmony_ci      {
141e41f4b71Sopenharmony_ci        src: "/common/asserts/heart85.png",
142e41f4b71Sopenharmony_ci      },
143e41f4b71Sopenharmony_ci      {
144e41f4b71Sopenharmony_ci        src: "/common/asserts/heart86.png",
145e41f4b71Sopenharmony_ci      },
146e41f4b71Sopenharmony_ci      {
147e41f4b71Sopenharmony_ci        src: "/common/asserts/heart87.png",
148e41f4b71Sopenharmony_ci      },
149e41f4b71Sopenharmony_ci      {
150e41f4b71Sopenharmony_ci        src: "/common/asserts/heart88.png",
151e41f4b71Sopenharmony_ci      },
152e41f4b71Sopenharmony_ci      {
153e41f4b71Sopenharmony_ci        src: "/common/asserts/heart89.png",
154e41f4b71Sopenharmony_ci      },
155e41f4b71Sopenharmony_ci      {
156e41f4b71Sopenharmony_ci        src: "/common/asserts/heart90.png",
157e41f4b71Sopenharmony_ci      },
158e41f4b71Sopenharmony_ci      {
159e41f4b71Sopenharmony_ci        src: "/common/asserts/heart91.png",
160e41f4b71Sopenharmony_ci      },
161e41f4b71Sopenharmony_ci      {
162e41f4b71Sopenharmony_ci        src: "/common/asserts/heart92.png",
163e41f4b71Sopenharmony_ci      },
164e41f4b71Sopenharmony_ci      {
165e41f4b71Sopenharmony_ci        src: "/common/asserts/heart93.png",
166e41f4b71Sopenharmony_ci      },
167e41f4b71Sopenharmony_ci      {
168e41f4b71Sopenharmony_ci        src: "/common/asserts/heart94.png",
169e41f4b71Sopenharmony_ci      },
170e41f4b71Sopenharmony_ci      {
171e41f4b71Sopenharmony_ci        src: "/common/asserts/heart95.png",
172e41f4b71Sopenharmony_ci      },
173e41f4b71Sopenharmony_ci      {
174e41f4b71Sopenharmony_ci        src: "/common/asserts/heart96.png",
175e41f4b71Sopenharmony_ci      },
176e41f4b71Sopenharmony_ci    ],
177e41f4b71Sopenharmony_ci  },
178e41f4b71Sopenharmony_ci  handleStart() {
179e41f4b71Sopenharmony_ci    this.$refs.animator.start();
180e41f4b71Sopenharmony_ci  },
181e41f4b71Sopenharmony_ci  handlePause() {
182e41f4b71Sopenharmony_ci    this.$refs.animator.pause();
183e41f4b71Sopenharmony_ci  },
184e41f4b71Sopenharmony_ci  handleResume() {
185e41f4b71Sopenharmony_ci    this.$refs.animator.resume();
186e41f4b71Sopenharmony_ci  },
187e41f4b71Sopenharmony_ci  handleStop() {
188e41f4b71Sopenharmony_ci    this.$refs.animator.stop();
189e41f4b71Sopenharmony_ci  },
190e41f4b71Sopenharmony_ci};
191e41f4b71Sopenharmony_ci```
192e41f4b71Sopenharmony_ci
193e41f4b71Sopenharmony_ci![zh-cn_image_0000001127284946](figures/zh-cn_image_0000001127284946.gif)
194