热搜:
编辑导语:关于移动端可拖动Banner,我们应该看到过许多,但是对于如何上手操作去实现这项功能,却很少有人知道或者实践过。今天,本文作者通过实际操作为我们演示了如何通过Axure实现移动端可拖动Banner。

我们用Axure做移动端原型时经常需要做Banner,今天来做一个可以拖动切换的Banner。

一、原型要求

  1. Banner图每3秒自动向左滚动切换;
  2. 拖动Banner图切换(大幅度拖动切换,小幅度不切换,拖动过程中不切换,拖动停止时切换);
  3. 点击标签切换到对应页面;
  4. 每次切换后,重新等待3秒再自动切换。

二、实现原理

  1. 利用动态面板的“载入时”-“设置面板状态”实现循环自动切换;
  2. 利用“设置面板状态”打断循环自动切换。

三、动手制作

1、首先准备几张用来做Banner的图片,这里找了5张400*225的图片;

2、在页面上放入一个动态面板(尺寸400*225),改名“Banner面板”,添加空状态state2至state5;

3、Banner面板的state1内放入一个动态面板,尺寸与Banner面板一致,改名“拖动面版”;

4、在拖动面板的state1内,(0,0)(-400,0)(400,0)各放一个400*225的图片图片元件;

5、将3个图片元件Ctrl+G组合,改名“Banner图”;

6、在页面上放入一个动态面板(尺寸400*50),改名“Banner标签”,添加空状态state2至state5;

7、在Banner标签的state1内放入一个400*50的矩形,填充颜色改成线性半透明,填充文字并调整好位置,改名“标题文字”;再放入1个20*20的按钮,白色边线白色文字透明填充底色,填入数字1,元件选中样式改为黑色字体白色填充底色,改名“标签按钮”;

8、对Banner面板的交互

(1)载入时:

1)设置面板状态

  1. Banner面板,状态:下一项并向后循环,进入动画:向左滑动 500ms,更多选项:循环间隔3000ms,首个状态延时3000ms后切换;
  2. Banner标签,状态:下一项并向后循环,进入动画:逐渐 500ms,更多选项:循环间隔3000ms,首个状态延时3000ms后切换。

这时候可以先预览一下,面板已经可以自动切换了,只是state2至state5里面没有原件,看起来就空空如也。

9、对拖动面板的互动

(1)拖动开始时:

  1. 设置面板状态:Banner面板,状态为停止循环
  2. 设置面板状态:Banner标签,状态为停止循环

(2)拖动时

移动:Banner图,跟随水平拖动,边界:左侧<=0,右侧>=400(保证向左和向右都最多拖动一张图的距离)。

(3)拖动结束时

1)情形1:值TotalDragX <= -100 (向左横向拖动1/4页面宽度时)

  1. 移动:Banner图到达(-800,0),动画:线性300ms (看起来切换到下一个状态);
  2. 设置面板状态:Banner标签,状态:下一项并向后循环,进入动画:逐渐 300ms;
  3. 等待:300ms (等待上面的移动动画结束);
  4. 设置面板状态:Banner面板到下一项并向后循环 (真正切换到下一个状态);
  5. 移动:Banner图回拖动前位置(元件归位);
  6. 触发事件:Banner面板的载入时(重新开始自动切换)。

2)情形2:TotalDragX >= 100 (向右横向拖动1/4页面宽度时)

  1. 移动:Banner图到达(0,0),动画:线性300ms (看起来切换到上一个状态);
  2. 设置面板状态:Banner标签,状态:上一项并向后循环,进入动画:逐渐 300ms;
  3. 等待:300ms (等待上面的移动动画结束);
  4. 设置面板状态:Banner面板到上一项并向后循环 (真正切换到上一个状态);
  5. 移动:Banner图回拖动前位置(元件归位);
  6. 触发事件:Banner面板的载入时(重新开始自动切换)。

3)情形3:(左右拖动不足1/4页面宽度时)

  1. 移动:Banner图回拖动前位置,动画:线性300ms;
  2. 触发事件:Banner面板的载入时(重新开始自动切换)。

10、将拖动面板复制到Banner面板的state2 至 state5。

11、对Banner标签的互动:

(1)state1内的标签按钮 单击时:

  1. 设置面板状态:Banner面板 到 state1,进入动画:向左滑动500ms;
  2. 设置面板状态:Banner标签 到 state1,进入动画:逐渐500ms;
  3. 触发事件:Banner面板 载入时。

(2)将标签按钮复制4个,文字分别改为2 – 5,并将互动中的Banner面板和Banner标签都的设置面板状态改为state2 – state5。

(3)将state1内的标题文字和5个标签按钮复制到Banner标签的state2 – state5,将state1的标签按钮1设为选中,将state2的标签按钮2设为选中,以此类推;再修改各个state中的标题文字。

12、将我们最初准备好的图片,放到Banner面板内的对应状态里的拖动面板里面的图片原件,比如state1里的Banner图,中间放1号图片,右边放2号图片,左边放5号图片;state2里的Banner图,中间放2号图片,右边放3号图片,左边放1号图片,以此类推。

13、现在我们就把可以拖动的高保真Banner做好了,赶紧F5预览一下吧。

原型链接:https://no5f2n.axshare.com