1# image-animator
2
3图片帧动画播放器。
4
5> **说明:**
6>
7> 该组件从从API version 4 开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
8
9
10## 子组件
11
12不支持。
13
14
15## 属性
16
17| 名称                  | 类型                       | 默认值   | 必填 | 描述                                                         |
18| --------------------- | -------------------------- | -------- | ---- | ------------------------------------------------------------ |
19| images                | Array&lt;ImageFrame&gt;    | -        | 是   | 设置图片帧信息集合。每一帧的帧信息包含图片路径、图片大小和图片位置信息。目前支持以下图片格式:png、jpg和bmp。ImageFrame的详细说明请见表1。<br/>**说明:**<br/>1.使用时需要使用数据绑定的方式,如images&nbsp;=&nbsp;{{images}},js中声明相应变量:images:&nbsp;[{src:&nbsp;"/common/heart-rate01.png"},&nbsp;{src:&nbsp;"/common/heart-rate02.png"}]。<br/>2.部分轻量级设备不支持原图片格式的解析。所以,在应用编译阶段,图片会被直接编译为可解析的位图(总字节数约:图片长x宽x4),并打包在应用安装包里,这会增加安装包的大小。因此,在使用图片资源时,应尽量控制图片的分辨率,尺寸越大的图片对于空间的占用越明显。 |
20| iteration             | number&nbsp;\|&nbsp;string | infinite | 否   | 设置帧动画播放次数。number表示固定次数,infinite枚举表示无限次数播放。 |
21| reverse               | boolean                    | false    | 否   | 设置播放顺序。false表示从第1张图片播放到最后1张图片;&nbsp;true表示从最后1张图片播放到第1张图片。 |
22| fixedsize             | boolean                    | true     | 否   | 设置图片大小是否固定为组件大小。&nbsp;true表示图片大小与组件大小一致,此时设置图片的width&nbsp;、height&nbsp;、top&nbsp;和left属性是无效的。false表示每一张图片的&nbsp;width&nbsp;、height&nbsp;、top和left属性都要单独设置。 |
23| duration              | string                     | -        | 是   | 设置单次播放时长。单位支持[s(秒)\|ms(毫秒)],默认单位为ms。&nbsp;duration为0时,不播放图片。&nbsp;值改变只会在下一次循环开始时生效。 |
24| fillmode<sup>5+</sup> | string                     | forwards | 否   | 指定帧动画执行结束后的状态。可选项有:<br/>-&nbsp;none:恢复初始状态。<br/>-&nbsp;forwards:保持帧动画结束时的状态(在最后一个关键帧中定义)。 |
25| id                    | string                     | -        | 否   | 组件的唯一标识。                                             |
26| style                 | string                     | -        | 否   | 组件的样式声明。                                             |
27| class                 | string                     | -        | 否   | 组件的样式类,用于引用样式表。                               |
28| ref                   | string                     | -        | 否   | 用来指定指向子元素的引用信息,该引用将注册到父组件的$refs&nbsp;属性对象上。 |
29
30  **表1** ImageFrame说明
31
32| 名称     | 类型             | 默认值  | 必填   | 描述               |
33| ------ | -------------- | ---- | ---- | ---------------- |
34| src    | &lt;uri&gt;    | -    | 是    | 图片路径。            |
35| width  | &lt;length&gt; | 0    | 否    | 图片宽度。            |
36| height | &lt;length&gt; | 0    | 否    | 图片高度。            |
37| top    | &lt;length&gt; | 0    | 否    | 图片相对于组件左上角的纵向坐标。 |
38| left   | &lt;length&gt; | 0    | 否    | 图片相对于组件左上角的横向坐标。 |
39
40
41## 事件
42
43| 名称                 | 参数                                | 描述          |
44| ------------------ | --------------------------------- | ----------- |
45| stop               | -                                 | 帧动画结束时触发。   |
46| click              | -                                 | 点击动作触发该事件。  |
47| longpress          | -                                 | 长按动作触发该事件。  |
48| swipe<sup>5+</sup> | [SwipeEvent](js-lite-common-events.md) | 组件上快速滑动后触发。 |
49
50
51## 样式
52
53| 名称                                 | 类型                                       | 默认值   | 必填   | 描述                                       |
54| ---------------------------------- | ---------------------------------------- | ----- | ---- | ---------------------------------------- |
55| width                              | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | -     | 否    | 设置组件自身的宽度。<br/><br/>未设置时组件宽度默认为0。        |
56| height                             | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | -     | 否    | 设置组件自身的高度。<br/><br/>未设置时组件高度默认为0。        |
57| padding                            | &lt;length&gt;                           | 0     | 否    | 使用简写属性设置所有的内边距属性。<br/>&nbsp;&nbsp;该属性可以有1到4个值:<br/>-&nbsp;指定一个值时,该值指定四个边的内边距。<br/>-&nbsp;指定两个值时,第一个值指定上下两边的内边距,第二个指定左右两边的内边距。<br/>-&nbsp;指定三个值时,第一个指定上边的内边距,第二个指定左右两边的内边距,第三个指定下边的内边距。<br/>-&nbsp;指定四个值时分别为上、右、下、左边的内边距(顺时针顺序)。 |
58| padding-[left\|top\|right\|bottom] | &lt;length&gt;                           | 0     | 否    | 设置左、上、右、下内边距属性。                          |
59| margin                             | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | 0     | 否    | 使用简写属性设置所有的外边距属性,该属性可以有1到4个值。<br/>-&nbsp;只有一个值时,这个值会被指定给全部的四个边。<br/>-&nbsp;两个值时,第一个值被匹配给上和下,第二个值被匹配给左和右。<br/>-&nbsp;三个值时,第一个值被匹配给上,&nbsp;第二个值被匹配给左和右,第三个值被匹配给下。<br/>-&nbsp;四个值时,会依次按上、右、下、左的顺序匹配&nbsp;(即顺时针顺序)。 |
60| margin-[left\|top\|right\|bottom]  | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | 0     | 否    | 设置左、上、右、下外边距属性。                          |
61| border-width                       | &lt;length&gt;                           | 0     | 否    | 使用简写属性设置元素的所有边框宽度。                       |
62| border-color                       | &lt;color&gt;                            | black | 否    | 使用简写属性设置元素的所有边框颜色。                       |
63| border-radius                      | &lt;length&gt;                           | -     | 否    | border-radius属性是设置元素的外边框圆角半径。            |
64| background-color                   | &lt;color&gt;                            | -     | 否    | 设置背景颜色。                                  |
65| opacity<sup>5+</sup>               | number                                   | 1     | 否    | 元素的透明度,取值范围为0到1,1表示为不透明,0表示为完全透明。        |
66| display                            | string                                   | flex  | 否    | 确定一个元素所产生的框的类型,可选值为:<br/>-&nbsp;flex:弹性布局。<br/>-&nbsp;none:不渲染此元素。 |
67| [left\|top]                        | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>6+</sup> | -     | 否    | left\|top确定元素的偏移位置。<br/>-&nbsp;left属性规定元素的左边缘。该属性定义了定位元素左外边距边界与其包含块左边界之间的偏移。<br/>-&nbsp;top属性规定元素的顶部边缘。该属性定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移。 |
68
69
70## 方法
71
72| 名称       | 参数   | 描述                                       |
73| -------- | ---- | ---------------------------------------- |
74| start    | -    | 开始播放图片帧动画。再次调用,重新从第1帧开始播放。               |
75| pause    | -    | 暂停播放图片帧动画。                               |
76| stop     | -    | 停止播放图片帧动画。                               |
77| resume   | -    | 继续播放图片帧。                                 |
78| getState | -    | 获取播放状态。可能值有:<br/>-&nbsp;playing:播放中<br/>-&nbsp;paused:已暂停<br/>-&nbsp;stopped:已停止。 |
79
80
81## 示例
82
83
84```html
85<!-- xxx.hml -->
86<div class="container">
87  <image-animator class="animator" ref="animator" images="{{frames}}" duration="1s" />
88  <div class="btn-box">
89    <input class="btn" type="button" value="start" @click="handleStart" />
90    <input class="btn" type="button" value="stop" @click="handleStop" />
91    <input class="btn" type="button" value="pause" @click="handlePause" />
92    <input class="btn" type="button" value="resume" @click="handleResume" />
93  </div>
94</div>
95```
96
97
98```css
99/* xxx.css */
100.container {
101  flex-direction: column;
102  justify-content: center;
103  align-items: center;
104  left: 0px;
105  top: 0px;
106  width: 454px;
107  height: 454px;
108}
109.animator {
110  width: 70px;
111  height: 70px;
112}
113.btn-box {
114  width: 264px;
115  height: 120px;
116  flex-wrap: wrap;
117  justify-content: space-around;
118  align-items: center;
119}
120.btn {
121  border-radius: 8px;
122  width: 120px;
123  margin-top: 8px;
124}
125```
126
127
128```js
129//xxx.js
130export default {
131  data: {
132    frames: [
133      {
134        src: "/common/asserts/heart78.png",
135      },
136      {
137        src: "/common/asserts/heart79.png",
138      },
139      {
140        src: "/common/asserts/heart80.png",
141      },
142      {
143        src: "/common/asserts/heart81.png",
144      },
145      {
146        src: "/common/asserts/heart82.png",
147      },
148      {
149        src: "/common/asserts/heart83.png",
150      },
151      {
152        src: "/common/asserts/heart84.png",
153      },
154      {
155        src: "/common/asserts/heart85.png",
156      },
157      {
158        src: "/common/asserts/heart86.png",
159      },
160      {
161        src: "/common/asserts/heart87.png",
162      },
163      {
164        src: "/common/asserts/heart88.png",
165      },
166      {
167        src: "/common/asserts/heart89.png",
168      },
169      {
170        src: "/common/asserts/heart90.png",
171      },
172      {
173        src: "/common/asserts/heart91.png",
174      },
175      {
176        src: "/common/asserts/heart92.png",
177      },
178      {
179        src: "/common/asserts/heart93.png",
180      },
181      {
182        src: "/common/asserts/heart94.png",
183      },
184      {
185        src: "/common/asserts/heart95.png",
186      },
187      {
188        src: "/common/asserts/heart96.png",
189      },
190    ],
191  },
192  handleStart() {
193    this.$refs.animator.start();
194  },
195  handlePause() {
196    this.$refs.animator.pause();
197  },
198  handleResume() {
199    this.$refs.animator.resume();
200  },
201  handleStop() {
202    this.$refs.animator.stop();
203  },
204};
205```
206
207![image-animator](figures/image-animator-lite.gif)
208