摘要: 与自带的slider不同的是,它是通过手势滑动标尺得到取值,而不是通过滑动滑块本身。

效果图
场景
当一屏显示不下,例如年龄体重选择,金额选择等大区间需要的选择器,相比自带的picker要直观一些。
思路:
先画一个scrollView 2 装进canvas
lineTo画刻度线段,lineTo+fill画出三角形游标,fillText描绘文本标签
通过bindscroll刻度尺触摸事件
渲染取值到页面
基本布局
<scroll-view scroll-x="true" bindscroll="bindscroll"> <canvas canvas-id="canvas" id="canvas"></canvas> </scroll-view>
实现bindscroll方法
bindscroll: function (e) {
// deltaX 水平位置偏移位,每次滑动一次触发一次,所以需要记录从第一次触发滑动起,一共滑动了多少距离
deltaX += e.detail.deltaX;
console.log(deltaX)
}
描绘刻度
const context = wx.createCanvasContext('canvas-ruler');
// 移动到原点
context.moveTo(origion.x, origion.y);
// 画线到刻度高度
context.lineTo(origion.x, origion.y - heightDecimal);
// 设置属性
context.setLineWidth(1);
// 描线
context.stroke();
// 描绘文本标签
context.setFontSize(fontSize);
context.fillText('0', origion.x - fontSize / 2, fontSize);
context.draw();
遍历刻度
for (var i = 0; i <= maxValue; i++) {
// 开始一个路径,这条非常重要,否则会重复绘制之前的刻度n次,效果表现为页面加载很卡,lineWidth得到的线很粗
context.beginPath();
// 绘制同上,不再赘述
...
// 关闭一个路径,它是可选的,调用过了beginPath,不关闭也没有影响,保险起见,加上它
context.closePath();
}
切记要调用context.beginPath();
描绘游标
drawCursor: function () {
/* 定义变量 */
// 定义三角形顶点 TODO x
var center = {x: app.screenWidth / 2, y: 5};
// 定义三角形边长
var length = 20;
// 左端点
var left = {x: center.x - length / 2, y: center.y + length / 2 * Math.sqrt(3)};
// 右端点
var right = {x: center.x + length / 2, y: center.y + length / 2 * Math.sqrt(3)};
// 初始化context
const context = wx.createCanvasContext('canvas-cursor');
context.moveTo(center.x, center.y);
context.lineTo(left.x, left.y);
context.lineTo(right.x, right.y);
// fill()填充而不是stroke()描边,于是省去手动回归原点,context.lineTo(center.x, center.y);
context.setFillStyle('#48c23d');
context.fill();
context.draw();
}
画带一个绿色的正三角形作为游标,注意游标是悬浮不动的,所以另起一个cancas来装它。当然它不是必须的,偷个懒ps一张三角形的png代替也无妨,甚至刻度其实也可以用<view style="background: gray; width: 2px;">加绝对定位来生成的。
定义刻度默认初值
that.setData({
scrollLeft: (currentValue - minValue) * ratio
});
<scroll-view scroll-x="true" bindscroll="bindscroll" scroll-left="{{scrollLeft}}">
绑定scroll-left参数,相当于iOS里了UIScrollView的contentOffset,手动让偏移到默认初值对应的坐标位置。
适配最小值
当业务场景需要做数据验证,例如金额要>0,年龄要大于18岁等,就得适配极值。
that.setData({
amount: Math.floor(- deltaX / 10 + minValue)
});
同时要修正刻度线的x轴坐标
// 2.2 画刻度线 context.moveTo(origion.x + (i - minValue) * ratio, origion.y); // 画线到刻度高度,10的位数就加高 context.lineTo(origion.x + (i - minValue) * ratio, origion.y - (i % ratio == 0 ? heightDecimal : heightDigit)); // 2.3 描绘文本标签 context.fillText(i == 0 ? ' ' + i : i, origion.x + (i - minValue) * ratio - fontSize / 2, fontSize);
最终js代码
var that;
var deltaX = 0;
var minValue = 1;
var app = getApp();
Page({
data: {
value: 0,
canvasHeight: 80
},
onLoad: function (options) {
that = this;
// 绘制标尺
that.drawRuler();
// 绘制三角形游标
that.drawCursor();
},
drawRuler: function() {
/* 1.定义变量 */
// 1.1 定义原点与终点,x轴方向起点与终点各留半屏空白
var origion = {x: app.screenWidth / 2, y: that.data.canvasHeight};
var end = {x: app.screenWidth / 2, y: that.data.canvasHeight};
// 1.2 定义刻度线高度
var heightDecimal = 50;
var heightDigit = 25;
// 1.3 定义文本标签字体大小
var fontSize = 20;
// 1.4 最小刻度值
// 已经定义在全局,便于bindscroll访问
// 1.5 总刻度值
var maxValue = 200;
// 1.6 当前刻度值
var currentValue = 20;
// 1.7 每个刻度所占位的px
var ratio = 10;
// 1.8 画布宽度
var canvasWidth = maxValue * ratio + app.screenWidth - minValue * ratio;
// 设定scroll-view初始偏移
that.setData({
canvasWidth: canvasWidth,
scrollLeft: (currentValue - minValue) * ratio
});
/* 2.绘制 */
// 2.1初始化context
const context = wx.createCanvasContext('canvas-ruler');
// 遍历maxValue
for (var i = 0; i <= maxValue; i++) {
context.beginPath();
// 2.2 画刻度线
context.moveTo(origion.x + (i - minValue) * ratio, origion.y);
// 画线到刻度高度,10的位数就加高
context.lineTo(origion.x + (i - minValue) * ratio, origion.y - (i % ratio == 0 ? heightDecimal : heightDigit));
// 设置属性
context.setLineWidth(2);
// 10的位数就加深
context.setStrokeStyle(i % ratio == 0 ? 'gray' : 'darkgray');
// 描线
context.stroke();
// 2.3 描绘文本标签
context.setFillStyle('gray');
if (i % ratio == 0) {
context.setFontSize(fontSize);
// 为零补一个空格,让它看起来2位数,页面更整齐
context.fillText(i == 0 ? ' ' + i : i, origion.x + (i - minValue) * ratio - fontSize / 2, fontSize);
}
context.closePath();
}
// 2.4 绘制到context
context.draw();
},
drawCursor: function () {
/* 定义变量 */
// 定义三角形顶点 TODO x
var center = {x: app.screenWidth / 2, y: 5};
// 定义三角形边长
var length = 20;
// 左端点
var left = {x: center.x - length / 2, y: center.y + length / 2 * Math.sqrt(3)};
// 右端点
var right = {x: center.x + length / 2, y: center.y + length / 2 * Math.sqrt(3)};
// 初始化context
const context = wx.createCanvasContext('canvas-cursor');
context.moveTo(center.x, center.y);
context.lineTo(left.x, left.y);
context.lineTo(right.x, right.y);
// fill()填充而不是stroke()描边,于是省去手动回归原点,context.lineTo(center.x, center.y);
context.setFillStyle('#48c23d');
context.fill();
context.draw();
},
bindscroll: function (e) {
// deltaX 水平位置偏移位,每次滑动一次触发一次,所以需要记录从第一次触发滑动起,一共滑动了多少距离
deltaX += e.detail.deltaX;
// 数据绑定
that.setData({
value: Math.floor(- deltaX / 10 + minValue)
});
console.log(deltaX)
}
});
以上所述是小编给大家介绍的微信小程序实现带刻度尺滑块功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# 微信小程序滑块
# 角形
# 遍历
# 而不是
# 它是
# 画线
# 自带
# 绑定
# 小编
# 装进
# 的是
# 滑块
# 过了
# 也没
# 在此
# 可以用
# 这条
# 不动
# 给大家
# 就得
# 可选
相关文章:
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
北京专业网站制作设计师招聘,北京白云观官方网站?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
如何解决ASP生成WAP建站中文乱码问题?
定制建站价位费用解析与套餐推荐全攻略
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
宝塔面板创建网站无法访问?如何快速排查修复?
如何通过虚拟主机快速搭建个人网站?
c++ stringstream用法详解_c++字符串与数字转换利器
网站制作软件有哪些,制图软件有哪些?
制作网站的基本流程,设计网站的软件是什么?
如何快速启动建站代理加盟业务?
ui设计制作网站有哪些,手机UI设计网址吗?
建站之星2.7模板:企业网站建设与h5定制设计专题
音响网站制作视频教程,隆霸音响官方网站?
网站制作公司排行榜,抖音怎样做个人官方网站
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何在IIS7上新建站点并设置安全权限?
h5在线制作网站电脑版下载,h5网页制作软件?
微信小程序 input输入框控件详解及实例(多种示例)
安云自助建站系统如何快速提升SEO排名?
如何快速搭建高效简练网站?
如何解决VPS建站LNMP环境配置常见问题?
如何在IIS中新建站点并解决端口绑定冲突?
如何在宝塔面板中创建新站点?
宿州网站制作公司兴策,安徽省低保查询网站?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
佛山企业网站制作公司有哪些,沟通100网上服务官网?
如何通过服务器快速搭建网站?完整步骤解析
宝塔新建站点报错如何解决?
如何高效生成建站之星成品网站源码?
如何通过FTP服务器快速搭建网站?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
如何通过IIS搭建网站并配置访问权限?
如何通过可视化优化提升建站效果?
如何在IIS管理器中快速创建并配置网站?
表情包在线制作网站免费,表情包怎么弄?
个人网站制作流程图片大全,个人网站如何注销?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何用低价快速搭建高质量网站?
如何通过虚拟主机快速完成网站搭建?
黑客如何通过漏洞一步步攻陷网站服务器?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
香港服务器部署网站为何提示未备案?
教学网站制作软件,学习*后期制作的网站有哪些?
建站主机系统SEO优化与智能配置核心关键词操作指南
为什么Go需要go mod文件_Go go mod文件作用说明
广州美橙建站如何快速搭建多端合一网站?
建站之星代理平台如何选择最佳方案?
建站之星如何实现PC+手机+微信网站五合一建站?
*请认真填写需求信息,我们会在24小时内与您取得联系。