微信小程序实现带刻度尺滑块功能

前端之家收集整理的这篇文章主要介绍了微信小程序实现带刻度尺滑块功能前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

效果

场景

当一屏显示不下,例如年龄体重选择,金额选择等大区间需要的选择器,相比自带的picker要直观一些。

思路:

先画一个scrollView 2 装进canvas

lineTo画刻度线段,lineTo+fill画出三角形游标,fillText描绘文本标签

通过bindscroll监听刻度尺触摸事件

渲染取值到页面

基本布局

实现bindscroll方法

描绘刻度

属性 context.setLineWidth(1); // 描线 context.stroke(); // 描绘文本标签 context.setFontSize(fontSize); context.fillText('0',origion.x - fontSize / 2,fontSize); context.draw();

遍历刻度

效果表现为页面加载很卡,lineWidth得到的线很粗 context.beginPath(); // 绘制同上,不再赘述 ... // 关闭一个路径,它是可选的,调用过了beginPath,不关闭也没有影响,保险起见,加上它 context.closePath(); }

切记要调用context.beginPath();

描绘游标

画带一个绿色的正三角形作为游标,注意游标是悬浮不动的,所以另起一个cancas来装它。当然它不是必须的,偷个懒ps一张三角形的png代替也无妨,甚至刻度其实也可以用生成的。

定义刻度默认初值

绑定scroll-left参数,相当于iOS里了UIScrollView的contentOffset,手动让偏移到默认初值对应的坐标位置。

适配最小值

当业务场景需要做数据验证,例如金额要>0,年龄要大于18岁等,就得适配极值。

同时要修正刻度线的x轴坐标

标签 context.fillText(i == 0 ? ' ' + i : i,origion.x + (i - minValue) * ratio - fontSize / 2,fontSize);

最终js代码

标签字体大小 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,fontSize); } context.closePath(); } // 2.4 绘制到context context.draw(); },drawCursor: function () { /* 定义变量 */ // 定义三角形顶点 TODO x var center = {x: app.screenWidth / 2,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) } });

以上所述是小编给大家介绍的微信小程序实现带刻度尺滑块功能。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

猜你在找的微信小程序相关文章