亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

微信小程序實現帶刻度尺滑塊功能

2019-11-19 16:59:37
字體:
來源:轉載
供稿:網友

摘要: 與自帶的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)  }});

以上所述是小編給大家介紹的微信小程序實現帶刻度尺滑塊功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久999精品免费| 91久久久亚洲精品| 欧美精品激情视频| 97视频在线观看视频免费视频| 精品久久久久久中文字幕| 日本亚洲精品在线观看| 国产精品电影观看| www高清在线视频日韩欧美| 日本亚洲精品在线观看| 91精品国产精品| 欧美男插女视频| 欧美激情视频在线免费观看 欧美视频免费一| 国产成人精品免费视频| 欧美丰满片xxx777| 国产999精品久久久影片官网| 深夜福利日韩在线看| 欧美日本啪啪无遮挡网站| 92国产精品视频| 国产成人精品免费视频| 久久久久久国产精品三级玉女聊斋| 亚洲激情视频在线播放| 亚洲激情视频在线| 欧洲亚洲女同hd| 国产精品视频最多的网站| 欧美在线视频观看| 国产成人精品视频在线观看| 久久精品国产亚洲精品| 57pao成人永久免费视频| 热门国产精品亚洲第一区在线| 久久国产精品视频| 欧美国产日韩中文字幕在线| 国内精品在线一区| xxxxx成人.com| 精品国偷自产在线视频| 欧美国产日韩一区二区三区| 成人xxxxx| 亚洲精品国产免费| 欧美日韩中文字幕日韩欧美| 日韩av有码在线| 亚洲美女av电影| 欧美一区亚洲一区| 91国产精品视频在线| 精品久久久久久中文字幕一区奶水| 久久久久久久av| 精品自在线视频| 91精品久久久久久久久| 国产精品美女久久久久久免费| 国模gogo一区二区大胆私拍| 中文字幕一区二区三区电影| 97精品一区二区三区| 欧美一区二区三区图| 亚洲免费电影在线观看| 午夜精品99久久免费| 国外日韩电影在线观看| 国产精品久久久久aaaa九色| www.欧美三级电影.com| 欧洲中文字幕国产精品| 欧美成年人视频网站欧美| 亚洲国产成人av在线| 久久精品成人欧美大片古装| 欧美日韩美女在线| 人人爽久久涩噜噜噜网站| 国产深夜精品福利| 久久久久久国产| 亚洲激情在线视频| 久久人人爽人人爽爽久久| 日本高清不卡的在线| 亚洲美女精品久久| 日韩av黄色在线观看| 日韩视频在线一区| 91午夜理伦私人影院| 国产精品日韩欧美大师| 久久香蕉频线观| 亚洲精品成人免费| 国产成人jvid在线播放| 亚洲电影av在线| 国产精品极品美女粉嫩高清在线| 国产日韩综合一区二区性色av| 亚洲第一视频网| 日韩av在线播放资源| 日本成人免费在线| 日韩电影在线观看中文字幕| 欧美黑人视频一区| 青青草国产精品一区二区| 亚洲自拍欧美色图| 97香蕉久久夜色精品国产| 国产ts人妖一区二区三区| 日韩高清中文字幕| 亚洲一区国产精品| 97久久伊人激情网| 伊人久久五月天| 国产精品网站视频| 国产高清视频一区三区| 91免费人成网站在线观看18| 久久久视频在线| 亚洲大胆人体av| 国产精品流白浆视频| 欧美一区二区视频97| 久久偷看各类女兵18女厕嘘嘘| 伊是香蕉大人久久| 日本高清视频一区| 欧美亚洲国产精品| 亚洲欧洲激情在线| 国产在线高清精品| 色婷婷av一区二区三区久久| 久久久久久高潮国产精品视| 国产成人综合亚洲| 亚洲精品视频网上网址在线观看| 久久精品99国产精品酒店日本| 国产精品亚洲综合天堂夜夜| 久久久久久av| 亚洲人成网站色ww在线| 亚洲欧洲在线视频| 亚洲成年人在线| 国产日韩精品综合网站| 成人黄色短视频在线观看| 日韩欧美在线观看| 亚洲欧洲在线免费| 亚洲精品成人av| 日韩av电影在线免费播放| 亚洲国产黄色片| 日韩精品免费电影| 欧美成年人在线观看| 国产精欧美一区二区三区| 久久夜色精品国产亚洲aⅴ| 91精品久久久久久| 久久久女人电视剧免费播放下载| 欧美激情一区二区三区高清视频| 久久久久久久影视| 国产精自产拍久久久久久| 91免费精品国偷自产在线| 国产成人精品午夜| 欧美日韩电影在线观看| 一区二区三区高清国产| 日韩国产一区三区| 精品国产欧美成人夜夜嗨| 精品久久久久久久久久久久久久| 欧美精品在线免费| 国产精品视频免费观看www| 韩国一区二区电影| 亚洲国产精品一区二区久| 精品日本美女福利在线观看| 精品一区二区三区四区在线| 国产日本欧美一区| 国产成人精品一区二区| 亚洲国产精品系列| 中文字幕无线精品亚洲乱码一区| 国产福利精品av综合导导航| 亚洲区一区二区| 97国产一区二区精品久久呦| 久久激情视频免费观看| 亚洲高清不卡av| 日韩最新免费不卡| 中文字幕av一区二区三区谷原希美| 91精品国产91久久久久久吃药| 久色乳综合思思在线视频| 久久久久久久91| 色婷婷av一区二区三区在线观看| 精品久久久久久国产| 欧美一级片免费在线| 97人人爽人人喊人人模波多| 欧美成人免费视频| 中文字幕综合一区| 亚洲精品中文字幕女同|