jquery插件實現(xiàn)儀表盤
更新時間:2021年04月26日 10:11:12 作者:阿飛超努力
這篇文章主要為大家詳細(xì)介紹了jquery插件實現(xiàn)儀表盤,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
jquery插件實現(xiàn)儀表盤,供大家參考,具體內(nèi)容如下
做了個簡易的儀表盤,就是很常見的那種碼表,實現(xiàn)沒啥困難,就是需要算一點點位置
實現(xiàn)效果
代碼部分
*{ margin: 0; padding: 0; } .rel{ display: flex; justify-content:center; align-items:center; position: relative; } .bp{ border-radius:50% ; border: 1px solid lightgray; position:relative; display: flex; justify-content: center; align-items: center; transform: rotate(-45deg); } .kd{ position:absolute; width: 100%; font-size: 12px; } .point{ background-color:lightgray; height: 100px; width: 20px; border-radius:100%; transform: rotate(90deg); transform-origin:10px 0px; z-index: 9; position: absolute; transition: all 0.5s; } .kb{ position: absolute; bottom: 20px; font-size: 24px; color: gray; transition: all 0.5s; }
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>做個儀表盤</title> <script src="js/jquery-3.4.1.min.js"></script> <script src="js/zgybp.js"></script> <link href="css/zgybp.css" rel="stylesheet" type="text/css" /> <style> #div{ border: 1px solid lightgray; width: 90%; height: 400px; margin: 20px auto; } </style> </head> <body> <div id="div"></div> </body> </html> <script> var temp = zgybp("div"); setInterval(function(){ var f = Math.floor(Math.random()*101); temp.load(f); },700) </script>
var zgybp = function(id){ var $id = $("#"+id); $id.addClass("rel"); var a = $id.width()>$id.height()?$id.height():$id.width(); $bp = $("<div class='bp'></div>"); $bp.appendTo($id); $bp.css({ "width":a, "height":a }) //繪制刻度,只繪制3/4 270/100=2.7,每一個刻度都是2.7 for(var i =100;i>=0;i--){ $kd = $("<div class='kd'><span class='txt'>-</span></div>"); if(i%5==0){ $kd.find('.txt').text(i) } $kd.appendTo($bp); $kd.css("transform","rotate("+(i*2.7)+"deg)"); } $point = $("<div class='point'></div>") $point.appendTo($bp) $point.css({ "left":a/2, "top":a/2 }) $kb = $("<div class='kb'>0</div>"); $kb.appendTo($id) //然后將表盤轉(zhuǎn)1/8的角度,就差不多了 return{ $id:$id, $bp:$bp, $point:$point, $kb:$kb, load:function(f){ var that = this; f = f<0?0:f>100?100:f; var temp = parseInt(f)*2.7; that.$point.css({ "transform":"rotate("+(90+temp)+"deg)" }) that.draw(f); }, draw:function(f){ var that =this; that.$kb.text(f); } } }
實現(xiàn)思路
- 嗯,看到車上的碼表就想到要實現(xiàn)一下這個儀表盤
- 這個就分為三步,先話表盤,當(dāng)然是只畫3/4,然后就是畫指針并且得定位正確的位置,最后就是根據(jù)輸入的參數(shù)把指針旋轉(zhuǎn)對應(yīng)的位置就行了
- 這里面我都挑最簡單的方法實現(xiàn)了,比如表盤這些啥的,我想全部畫上文字,不過太擠了就變成五個畫一個中間刻度,接著就是指針我是直接畫的div變形的,這里定位我直接用它自己與父容器的flex居中配合的地方,因此這里面有個不好解釋的地方就是將指針從中心點挪到下方或者其他偏離中心點的位置上,想要讓指針對準(zhǔn)正確的刻度,接著算偏轉(zhuǎn)距離的時候就要多一個換算的步驟了,我記得這里面有個啥函數(shù)來著,不過不記得了,所以就沒有為了美觀把指針挪下來了。
- 這里還是記下筆記我之前的transform-origin這個屬性,這個屬性真的很重要的,像是這種畫指針的地方我感覺很有用
- transform-origin: x-axis y-axis z-axis;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jQueryUI 拖放排序遇到滾動條時有可能無法執(zhí)行排序的小bug及解決方案
前些日子不是在做使用Jquery-UI實現(xiàn)一次拖拽多個選中的元素操作嘛,在持續(xù)完善這個組件時遇到了一個關(guān)于拖放排序的bug。今天就著圖片和代碼重現(xiàn)一下,也順便告訴大家如何解決這個問題2016-12-12JQuery控制div外點擊隱藏而div內(nèi)點擊不會隱藏的方法
這篇文章主要介紹了JQuery控制div外點擊隱藏而div內(nèi)點擊不會隱藏的方法,涉及show、hide及stopPropagation等方法的使用技巧,需要的朋友可以參考下2015-01-01javascript異步處理與Jquery deferred對象用法總結(jié)
這篇文章主要介紹了javascript異步處理與Jquery deferred對象用法,結(jié)合實例形式總結(jié)分析了jQuery異步請求處理相關(guān)操作技巧,需要的朋友可以參考下2019-06-06