文章出處

效果圖:

所需圖片素材:

這張圖是pointer.png的位置的。

turntable-bg.jpg這張是轉盤背景圖,在背景位置。

這張是turntable.png位置的。  

 

需要這三張圖片,如果要實現一下,直接另存這三圖片引入進去即可。如果不會請修改成對應的圖片名字,放到同一個文件下。

 

基本原理:

1,通過設置CSS樣式的position屬性,z-index屬性等實現背景圖,轉盤圖與指針圖的層疊擺放;

2,通過設置元素style.transform = "rotate(0deg)"實現旋轉效果。

 

完整代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta name="description" content="">
 6     <meta name="author" content="熊仔其人">
 7     <title>轉盤抽獎效果</title>
 8     <!-- 這里是css部分 -->
 9     <style>
10         #bg {
11             width: 650px;
12             height: 600px;
13             margin: 0 auto;
14             background: url(turntable-bg.jpg) no-repeat;
15             position: relative;
16         }
17 
18         img[src^="pointer"] {
19             position: absolute;
20             z-index: 10;
21             top: 155px;
22             left: 247px;
23         }
24 
25         img[src^="turntable"] {
26             position: absolute;
27             z-index: 5;
28             top: 60px;
29             left: 116px;
30             transition: all 4s;
31         }
32     </style>
33 </head>
34 <body>
35     <!-- 這里是HTML結構部分 --> 
36     <div id="bg"><img src="pointer.png" alt="pointer"><img src="turntable.png" alt="turntable"></div>  
37     <!-- 這里是js部分 -->
38     <script>
39         var oPointer = document.getElementsByTagName("img")[0];
40         var oTurntable = document.getElementsByTagName("img")[1];
41         var cat = 51.4; //總共7個扇形區域,每個區域約51.4度
42         var num = 0; //轉圈結束后停留的度數
43         var offOn = true; //是否正在抽獎
44         oPointer.onclick = function () {
45             if (offOn) {
46                 oTurntable.style.transform = "rotate(0deg)";
47                 offOn = !offOn;
48                 ratating();
49             }
50         }
51         //旋轉
52         function ratating() {
53             var timer = null;
54             var rdm = 0; //隨機度數
55             clearInterval(timer);
56             timer = setInterval(function () {
57                 if (Math.floor(rdm / 360) < 3) { rdm = Math.floor(Math.random() * 3600); }
58                 else {
59                     oTurntable.style.transform = "rotate(" + rdm + "deg)";
60                     clearInterval(timer);
61                     setTimeout(function () {
62                         offOn = !offOn;
63                         num = rdm % 360;
64                         if (num <= cat * 1) { alert("4999元"); console.log("rdm=" + rdm + ",num=" + num + "" + "4999元"); }
65                         else if (num <= cat * 2) { alert("50元"); console.log("rdm=" + rdm + ",num=" + num + "" + "50元"); }
66                         else if (num <= cat * 3) { alert("10元"); console.log("rdm=" + rdm + ",num=" + num + "" + "10元"); }
67                         else if (num <= cat * 4) { alert("5元"); console.log("rdm=" + rdm + ",num=" + num + "" + "5元"); }
68                         else if (num <= cat * 5) { alert("免息服務"); console.log("rdm=" + rdm + ",num=" + num + "" + "免息服務"); }
69                         else if (num <= cat * 6) { alert("提交白金"); console.log("rdm=" + rdm + ",num=" + num + "" + "提交白金"); }
70                         else if (num <= cat * 7) { alert("未中獎"); console.log("rdm=" + rdm + ",num=" + num + "" + "未中獎"); }
71                     }, 4000);
72                 }
73             }, 30);
74         }
75     </script>
76 </body>
77 </html>

 

css和HTML代碼不多,主要是為了實現過渡設置,還有為了實現層疊而使用position定位,讓元素脫離文檔流,js代碼在于獲取元素和事件的點擊,點擊指針會旋轉,所以要給指針加個點擊事件,然后是判斷旋轉是否停止,如果沒有就點擊也不能調用函數ratating(),這個函數執行轉盤的旋轉和判斷指針停在什么位置,然后彈出相應的內容,而函數里實現旋轉的過程,是獲取轉盤的元素,然后使用js控制css的屬性-transform:rotate(),我們不是使用過這個屬性在css里直接使它實現旋轉的效果嗎?就是和偽類選擇器:hover及過渡屬性一起使用去實現的,那么因為css實現不了數字的運算和鼠標點擊,所以讓js去實現且控制css屬性,實現到點擊旋轉這個功能,然而定時器的使用暫時不說,思路就是使用js實現數字的運算和鼠標的點擊及css屬性的控制達到旋轉的效果。
Math.random()是隨機數的生成,Math.floor()向下取整。

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()