作品名称:拖动滑块确定评分区间效果
作品编号:Case005
软件版本:Axure9
作品类型:交互案例
滑块拖动效果是原型设计中比较常见的交互效果,今天我们以豆瓣的评分区间筛选组件为例来讲讲如何在Axure中实现拖动滑块确定评分区间的交互。
原型预览链接:
http://daisyaxure.com/demo/Case005
请复制以上链接至电脑浏览器查看效果(附源文件下载链接)
- 交互效果说明 -
1.滑块及评分数值跟随鼠标拖动沿水平方向移动,移动范围不能超出灰色背景条两端。
2.拖动滑块时,橙色的进度条宽度随着滑块的拖动而变化。
3.评分数值的坐标始终与滑块一致,且数值要随着滑块拖动在「0-10」的范围内变化。
效果预览:
- 元件准备 -
1.拖入一个【矩形】元件,设置元件宽度:300px,高度:6px,圆角半径:6,填充颜色:#EEEEEE,命名为「BackGround」;
复制一个「BackGround」出来,置于「BackGround」上方,填充颜色:#FFB444,命名为「ProgressBar」;
2.拖入一个【圆形】元件,设置大小为:28px*28px,线段宽度:1px,线段颜色#A2A2A2;
在此【圆形】元件上方拖入一个【文本标签】,设置字体颜色:#999999,字体大小:12px,文本内容:“0分”,命名为「Min」;
将上述两个元件选中点击右键转换为动态面板,命名为「LeftSlider」;
3.复制一个「LeftSlider」出来,命名为「RightSlider」;
双击进入动态面板修改文本标签的文本内容为:“10分",命名为「Max」。
将上述元件按照图示位置进行调整,所有元件准备完毕。
- 添加交互 -
第一步 给滑块「LeftSlider」和「RightSlider」添加拖动交互。
1.给左侧的滑块「LeftSlider」添加【拖动时】的交互,【移动】「LeftSlider」【跟随水平拖动】。
做完这步滑块已经可以跟随鼠标水平拖动了,但是我们还需要限制滑块左右拖动的范围。
「LeftSlider」的滑动范围向左不能超过其初始位置,向右不能超过右侧滑块「RightSlider」的左坐标;滑动范围即灰色背景条「BackGround」的左坐标和滑块「RightSlider」左坐标之间的距离。
2.点击【更多选项】-【添加边界】,设置边界值【左侧≥[[background.left]]】,【右侧≤[[rightslider.left]]】。
边界值需要借助局部变量获取,点击【添加局部变量】,设置局部变量「backGround」【=】【元件】「BackGround」;
点击【插入变量函数】值为[[background.left]];
同理可获取右侧的边界值,具体数值参考下图。
3.同样给右侧的滑块「RightSlider」添加同样的交互,数值如下图所示。
完成这一步后,拖动滑块已经可以在设定的范围内滑动了。
第二步 添加橙色滑动条「ProgressBar」宽度随着滑块拖动而变化的交互。
橙色的滑动条的宽度为右侧滑块「RightSlider」的左坐标减去左侧滑块「LeftSlider」的左坐标。
1.给左侧滑块「LeftSlider」添加【移动时】的交互,目标为橙色滑动条「ProgressBar」的宽度,数值为[[rightslider.left-leftslider.left]],同样需要结合局部变量获取对象,锚点为右侧;
2.给右侧滑块「RightSlider」添加相同的交互,区别为锚点为左侧。
第三步 设置「Min」「Max」文本标签的评分数值随着滑块拖动而变化。
1.给左侧的动态面板「LeftSlider」添加【移动时】的交互,设置「Min」的【文本】值为
[[math.ceil((This.left-background.left)/background.width*10)]]分
左侧滑块滑动的宽度=左侧滑块的左坐标-灰色背景条的左坐标
左侧评分分值=左侧滑块滑动的宽度/灰色背景条的宽度*10 ;
math.ceil(x)函数为向上取整函数,返回大于或等于参数x,并且与之最接近的整数。
2.同样给右侧的动态面板「RightSlider」添加【移动时】的交互,设置「Max」的【文本】值为
[[10-math.ceil((background.right-This.right)/background.width*10)]]分
添加完成后就完成整个交互了,如果还有不清楚的地方,可在文章开头点击预览链接中的下载按钮,下载源文件查看交互细节。