基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果
最近公司有一個(gè)項(xiàng)目的需要做出旋鈕的效果,旋鈕有十個(gè)檔,根據(jù)手指旋轉(zhuǎn)切換,旋轉(zhuǎn)時(shí)接近最近的檔會(huì)有吸附效果,具體效果如下:

html部分代碼:
<div class="_touch">
<div class="round_box" ref="box" @touchstart="touchStart" @touchmove="touchMove">
<div v-if="able" style="position:absolute;width:100%;height:100%;top:0;left:0;">
<div class="round_right" ref="right" :style="{ transform: 'rotate(' + angle +'deg)' }">
<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)聽(tīng) .round_box 元素的 touchmove 事件獲取手指相對(duì)于圓心這條直線的旋轉(zhuǎn)角度(transform : rotate),
并把旋轉(zhuǎn)角度同步到水平居中于 .round_box 容器,底邊框中心與 .round_box重合的元素 : .round_right 上,使它相對(duì)于
.round_box的圓心旋轉(zhuǎn)即可。
注:.round_box圓心如下:

注:.round_right 元素如下:

總結(jié)
以上所述是小編給大家介紹的基于vue實(shí)現(xiàn)移動(dòng)端圓形旋鈕插件效果,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
js網(wǎng)頁(yè)中的(運(yùn)行代碼)功能實(shí)現(xiàn)思路
網(wǎng)頁(yè)中的"運(yùn)行代碼"是一個(gè)很方便的功能,可以直接看到代碼的效果,感興趣的朋友不妨參考下,或許對(duì)你學(xué)習(xí)js有所幫助,好了花不多說(shuō)切入正題2013-02-02
JavaScript深入V8引擎以及編寫(xiě)優(yōu)化代碼的5個(gè)技巧
這篇文章主要介紹了JavaScript深入V8引擎以及編寫(xiě)優(yōu)化代碼的5個(gè)技巧,JavaScript引擎是執(zhí)行 JavaScript 代碼的程序或解釋器。JavaScript引擎可以實(shí)現(xiàn)為標(biāo)準(zhǔn)解釋器,或者以某種形式將JavaScript編譯為字節(jié)碼的即時(shí)編譯器。,需要的朋友可以參考下2019-06-06
layui 監(jiān)聽(tīng)表格復(fù)選框選中值的方法
今天小編就為大家分享一篇layui 監(jiān)聽(tīng)表格復(fù)選框選中值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
JavaScript實(shí)現(xiàn)數(shù)據(jù)可視化圖表的示例代碼
這篇文章主要介紹了如何使用JavaScript創(chuàng)建實(shí)時(shí)數(shù)據(jù)可視化圖表,我們將使用流行的圖表庫(kù),如Chart.js,來(lái)展示如何將實(shí)時(shí)數(shù)據(jù)動(dòng)態(tài)呈現(xiàn)在圖表中,感興趣的可以了解下2024-01-01

