成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果

最近公司有一個(gè)項(xiàng)目的需要做出旋鈕的效果,旋鈕有十個(gè)檔,根據(jù)手指旋轉(zhuǎn)切換,旋轉(zhuǎn)時(shí)接近最近的檔會(huì)有吸附效果,具體效果如下:

從事溫江服務(wù)器租用,服務(wù)器租用,云主機(jī),虛擬空間,域名申請(qǐng),CDN,網(wǎng)絡(luò)代維等服務(wù)。

基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果

html部分代碼:

<div class="_touch">
 <div class="round_box" ref="box" @touchstart="touchStart" @touchmove="touchMove">
  <div v-if="able" >
   <div class="round_right" ref="right" :>
    <div class="round_info"></div>
   </div>
   <div class="round_num">{{level}}</div>
  </div>
 </div>
</div>

less樣式部分代碼:

._touch {
 padding-top: 48px;
 .round_box {
  position: relative;
  width: 54%;
  padding-top: 54%;
  margin: 0 auto;
  background-image: url(../../assets/img/round_box.png);
  background-size: auto 100%;
  background-position: center top;
  background-repeat: no-repeat;
  .round_right {
   width: 8%;
   height: 27%;
   position: absolute;
   left: 46%;
   top: 23%;
   transform-origin: 50% 100%;
   -webkit-transform-origin: 50% 100%;
   z-index: 2;
   .round_info {
    background: linear-gradient(#858585, #b3b3b3);
    background: -webkit-gradient(#858585, #b3b3b3);
    background: -moz-linear-gradient(#858585, #b3b3b3);
    width: 100%;
    padding-top: 100%;
    border-radius: 100%;
   }
  }
  .round_num {
   display: inline-block;
   position: absolute;
   z-index: 1;
   text-align: center;
   width: 30%;
   top: 38%;
   left: 35%;
   font-size: 2.4em;
   font-weight: 900;
   background: linear-gradient(#b0b0b0, #c8c8c8);
   background: -webkit-gradient(#b0b0b0, #c8c8c8);
   -webkit-background-clip: text;
   background-clip: text;
   -webkit-text-fill-color: transparent;
   text-fill-color: transparent;
  }
 }
}

js部分代碼:

methods: {
 ......,
 touchStart(e) {
  e.preventDefault();
  e.stopPropagation();
  let round_box = this.$refs.box;
  var w = round_box.offsetWidth / 2;
  var h = round_box.offsetHeight / 2;
  this.px = round_box.getBoundingClientRect().left + w;
  this.py = round_box.getBoundingClientRect().top + h;
 },
 touchMove(e) {
  e.preventDefault();
  e.stopPropagation();
  this.getAngle(e.changedTouches[0].clientX, e.changedTouches[0].clientY);
 },
 touchEnd(e) {
  e.preventDefault();
  e.stopPropagation();
 },
 resetAngle(angle) {
  let list = [
   { angle: 0, level: 5 },
   { angle: 36, level: 6 },
   { angle: 72, level: 7 },
   { angle: 108, level: 8 },
   { angle: 144, level: 9 },
   { angle: 180, level: 10 },
   { angle: 216, level: 1 },
   { angle: 252, level: 2 },
   { angle: 288, level: 3 },
   { angle: 324, level: 4 },
   { angle: 360, level: 5 }
  ];
  let result = list.filter(function(currentVal, index, arr) {
   return Math.abs(angle - currentVal.angle) <= 18;
  });
  this.angle = result[0].angle;
  this.level = result[0].level;
 },
 getAngle(mx, my) {
  var px = this.px;
  var py = this.py;
  var x = Math.abs(px - mx);
  var y = Math.abs(py - my);
  var z = Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2));
  var cos = y / z;
  var radina = Math.acos(cos); //用反三角函數(shù)求弧度
  var angle = Math.floor(180 / (Math.PI / radina)); //將弧度轉(zhuǎn)換成角度
  if (mx > px && my > py) {
   //鼠標(biāo)在第四象限
   angle = 180 - angle;
  }
  if (mx == px && my > py) {
   //鼠標(biāo)在y軸負(fù)方向上
   angle = 180;
  }
  if (mx > px && my == py) {
   //鼠標(biāo)在x軸正方向上
   angle = 90;
  }
  if (mx < px && my > py) {
   //鼠標(biāo)在第三象限
   angle = 180 + angle;
  }
  if (mx < px && my == py) {
   //鼠標(biāo)在x軸負(fù)方向
   angle = 270;
  }
  if (mx < px && my < py) {
   //鼠標(biāo)在第二象限
   angle = 360 - angle;
  }
  this.angle = angle;
  this.$nextTick(function() {
   this.resetAngle(this.angle);
  });
 },
......

主要的思路是根據(jù)監(jiān)聽 .round_box 元素的 touchmove 事件獲取手指相對(duì)于圓心這條直線的旋轉(zhuǎn)角度(transform : rotate),

并把旋轉(zhuǎn)角度同步到水平居中于 .round_box 容器,底邊框中心與 .round_box重合的元素 : .round_right 上,使它相對(duì)于

.round_box的圓心旋轉(zhuǎn)即可。

注:.round_box圓心如下:

基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果

注:.round_right 元素如下:

基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果

總結(jié)

以上所述是小編給大家介紹的基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!

分享標(biāo)題:基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果
分享路徑:http://jinyejixie.com/article4/posdie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站網(wǎng)站制作、建站公司、用戶體驗(yàn)、搜索引擎優(yōu)化、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
长寿区| 三门县| 福海县| 鄂托克旗| 兴安县| 遵义市| 蓬安县| 天峨县| 和静县| 怀集县| 理塘县| 南陵县| 峨边| 汶上县| 鄂托克前旗| 云和县| 平山县| 波密县| 嫩江县| 平果县| 手机| 望城县| 阜南县| 永州市| 福鼎市| 绥江县| 吕梁市| 阳新县| 平邑县| 台江县| 柳林县| 济阳县| 青浦区| 海林市| 普兰店市| 邵阳县| 南安市| 恩施市| 同江市| 顺义区| 江口县|