91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序怎么實現環形進度條

發布時間:2022-06-30 09:57:41 來源:億速云 閱讀:453 作者:iii 欄目:開發技術

本篇內容主要講解“微信小程序怎么實現環形進度條”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“微信小程序怎么實現環形進度條”吧!

index.wxss

.circle {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}

index.wxml

<canvas class="circle"  canvas-id="canvasArcCir"></canvas>
<canvas class="circle"  canvas-id="canvasCircle"></canvas>

index.js

var interval;
var varName;
var ctx = wx.createCanvasContext('canvasArcCir');


Page({

  /**
   * 頁面的初始數據
   */
  data: {
    pitch: 0,
    titleName: "答題結果",
    btn_color: "",
    text: 0,
    accuracy: {},
  },

  /**
   * 生命周期函數--監聽頁面加載
   */
  onLoad: function (options) {
    if (options.correctAndError != null) {
      var accuracyTemp = JSON.parse(options.correctAndError);
      accuracyTemp.time = (accuracyTemp.time / 2).toFixed(1);
    } else {
      var accuracyTemp = {
        questionNumber: 10,
        correctNumber: 7,
        time: 50
      }
    }

    var bgColorTemp = "";
    var bColorTemp = "";
    if ((accuracyTemp.correctNumber / accuracyTemp.questionNumber) < 0.6) {
      bgColorTemp = "linear-gradient(180deg,rgba(255,90,84,1) 0%,rgba(255,152,109,1) 100%)";
      bColorTemp = "#FF5C54"
    } else if ((accuracyTemp.correctNumber / accuracyTemp.questionNumber) < 0.8) {
      bgColorTemp = "linear-gradient(180deg,rgba(250,182,25,1) 0%,rgba(249,206,69,1) 100%)";
      bColorTemp = "#FBC932";
    } else {
      bgColorTemp = "linear-gradient(180deg,rgba(53,168,203,1) 0%,rgba(80,205,219,1) 100%)";
      bColorTemp = "#36A9CB";
    }

    //練習結果-差
    this.setData({
      bgColor: bgColorTemp,
      btBgColor: bgColorTemp,
      tColor: bColorTemp,
      bdColor: bColorTemp,
      accuracy: accuracyTemp
    });
  },

  /**
   * 生命周期函數--監聽頁面初次渲染完成
   */
  onReady: function () {
    var that = this;
    setTimeout(function () {


      //創建并返回繪圖上下文context對象。
      //灰色圓環
      var cxt_arc = wx.createCanvasContext('canvasCircle');
      cxt_arc.setLineWidth(15);
      cxt_arc.setStrokeStyle('#eaeaea');
      cxt_arc.setLineCap('round');
      cxt_arc.beginPath();
      cxt_arc.arc(130, 130, 94, 2.5, 2.2 * Math.PI, false);
      cxt_arc.stroke();
      
      
      //沒有運動的白點
      cxt_arc.beginPath();
      cxt_arc.setStrokeStyle('#fff');
      cxt_arc.setLineCap('round');
      cxt_arc.setLineWidth(5);
      cxt_arc.arc(55, 185, 1, 0, 2 * Math.PI, false);
      cxt_arc.stroke();
      
      
      //虛線中的圓環
      var waste_pce = 20;
      cxt_arc.setLineWidth(18);
      cxt_arc.setStrokeStyle(that.data.tColor);
      cxt_arc.setLineCap('square')
      cxt_arc.beginPath(); //開始一個新的路徑
      cxt_arc.arc(130, 130, 60, 2.5, 2.2 * Math.PI, false); //設置一個原點(106,106),半徑為100的圓的路徑到當前路徑
      cxt_arc.stroke(); //對當前路徑進行描邊
      
      
      //畫50條放射白線實現虛線效果
      cxt_arc.setLineWidth(3);
      cxt_arc.setStrokeStyle('#fff');
      cxt_arc.setLineCap('square');
      cxt_arc.beginPath(); //開始一個新的路徑
      for (var i = 0; i < 50; i++) {
        var x = Math.PI * 2 / 50 * i;
        cxt_arc.moveTo(130, 130);
        cxt_arc.lineTo((130 + Math.sin(x) * 70), (130 + Math.cos(x) * 70));
        cxt_arc.stroke();
      }

      var accuracyTemp = (that.data.accuracy.correctNumber / that.data.accuracy.questionNumber)

      that.drawCircle(accuracyTemp, that.data.tColor);
      
      //設置中間字的坐標
      var x = 130,
        y = 130;
      if (accuracyTemp == 1) {
        x = 125;
        y = 158;
      } else if (accuracyTemp == 0) {
        x = 126;
        y = 140;
      } else {
        x = 126;
        y = 150;
      }
      
      //中間字 數字
      cxt_arc.beginPath();
      cxt_arc.setFontSize(30);
      cxt_arc.setFillStyle(that.data.tColor);
      cxt_arc.textAlign = 'center';
      cxt_arc.fillText(accuracyTemp * 100, x, 135);
      cxt_arc.stroke();
      
      //中間字 %
      cxt_arc.beginPath();
      cxt_arc.setFontSize(10);
      cxt_arc.fillText("%", y, 135);
      cxt_arc.textAlign = 'center';
      cxt_arc.stroke();
      
      //中間字 正確率
      cxt_arc.beginPath();
      cxt_arc.setFontSize(10);
      cxt_arc.setFillStyle("#999999");
      cxt_arc.textAlign = 'center';
      cxt_arc.fillText("正確率", 130, 155);
      cxt_arc.stroke();

      cxt_arc.draw();


    }, 500);
  },
  /**
   * 自定義函數
   */
  drawCircle: function (name, color) {
    this.setData({
      btn_color: color,
      text: name * 100
    })
    clearInterval(varName);

    function drawArc(s, e, x9, y9) {
      //運動環
      ctx.setFillStyle('white');
      ctx.clearRect(0, 0, 200, 200);
      ctx.draw();
      var x = 130,
        y = 130,
        radius = 94;
      ctx.setLineWidth(15);
      ctx.setStrokeStyle(color);
      ctx.setLineCap('round');
      ctx.beginPath();
      ctx.arc(x, y, radius, s, e, false);
      ctx.stroke()
      
      //運動白點
      ctx.beginPath();
      ctx.setStrokeStyle('#fff');
      ctx.setLineCap('round');
      ctx.setLineWidth(5);
      ctx.arc(x9, y9, 1, 0, 2 * Math.PI, false);
      ctx.stroke();
      ctx.draw()


    }
    var step = 0,
      startAngle = 0.8 * Math.PI,//開始弧度
      endAngle = 0;
    var animation_interval = 0,
      n = 600;


    var animation = function () {
      if (step <= n) {

        endAngle = name * (step * 1.4 * Math.PI / n) + 0.8 * Math.PI;//結束弧度
        var L = (1.2*Math.PI + endAngle )*94;//弧長
        var x = (54 - 130) * Math.cos(L / 94) - (185 - 130) * Math.sin(L / 94) + 130; //x坐標
        var y = (54 - 130) * Math.sin(L / 94) + (185 - 130) * Math.cos(L / 94) + 130; //y坐標

        drawArc(startAngle, endAngle, x, y);
        step++;
      } else {
        clearInterval(varName);
      }
    };
    varName = setInterval(animation, animation_interval);
  },

})

效果

微信小程序怎么實現環形進度條

微信小程序怎么實現環形進度條

微信小程序怎么實現環形進度條

到此,相信大家對“微信小程序怎么實現環形進度條”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

固镇县| 兰考县| 醴陵市| 彰化县| 抚州市| 竹北市| 平远县| 宁海县| 连山| 临泉县| 澎湖县| 湖南省| 拜城县| 绍兴市| 将乐县| 措勤县| 扎赉特旗| 合江县| 安顺市| 屏东县| 新营市| 广德县| 永安市| 海城市| 珲春市| 淄博市| 栾城县| 错那县| 平罗县| 惠东县| 扎赉特旗| 浪卡子县| 大姚县| 溧阳市| 罗田县| 驻马店市| 吕梁市| 开远市| 深泽县| 余庆县| 满洲里市|