欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

手機移動端實現(xiàn) jquery和HTML5 Canvas的幸運大獎盤特效

 更新時間:2016年12月06日 14:59:41   投稿:lqh  
這篇文章主要介紹了手機移動端實現(xiàn) jquery和HTML5 Canvas的幸運大獎盤特效的相關(guān)資料,這里附有實現(xiàn)代碼及實現(xiàn)效果圖,需要的朋友可以參考下

HTML5 Canvas的幸運大獎盤特效

            現(xiàn)在好的微信微商或者微信公眾號都有這種大轉(zhuǎn)盤的項目,這里就整理一個,可以參考下。

這是一款基于jquery和HTML5 Canvas的幸運大獎盤特效。該幸運大獎品特效支持移動端,它通過動態(tài)構(gòu)造Canvas元素來生成大獎盤,并通過jquery代碼來隨機獲取獎品。

  使用方法

  HTML結(jié)構(gòu)

  抽獎用的大轉(zhuǎn)盤使用圖片來制作,開始時它們被隱藏。整個抽獎大獎盤放置在一個容器中,控制容器的大小即可以控制獎盤的大小。

XML/HTML代碼
<div class="container"> 
 <img src="images/1.png" id="shan-img" style="display:none;" /> 
 <img src="images/2.png" id="sorry-img" style="display:none;" /> 
 <div class="banner"> 
  <div class="turnplate" style="background-image:url(images/turnplate-bg.png);background-size:100% 100%;"> 
   <canvas class="item" id="wheelcanvas" width="422px" height="422px"></canvas> 
   <img class="pointer" src="images/turnplate-pointer.png"/> 
  </div> 
 </div> 
</div> 

  CSS樣式

  為大獎盤添加下面的CSS樣式:

CSS代碼

.banner{display:block;width:95%;margin-left:auto;margin-right:auto;margin-bottom: 20px;} 
.banner .turnplate{display:block;width:100%;position:relative;} 
.banner .turnplate canvas.item{width:100%;} 
.banner .turnplate img.pointer{position:absolute;width:31.5%;height:42.5%;left:34.6%;top:23%;} 

  JavaScript

  整個大獎盤的jquery實現(xiàn)代碼如下:

JavaScript代碼

var turnplate={ 
  restaraunts:[],    //大轉(zhuǎn)盤獎品名稱 
  colors:[],     //大轉(zhuǎn)盤獎品區(qū)塊對應(yīng)背景顏色 
  outsideRadius:192,   //大轉(zhuǎn)盤外圓的半徑 
  textRadius:155,    //大轉(zhuǎn)盤獎品位置距離圓心的距離 
  insideRadius:68,   //大轉(zhuǎn)盤內(nèi)圓的半徑 
  startAngle:0,    //開始角度 
    
  bRotate:false    //false:停止;ture:旋轉(zhuǎn) 
}; 
  
$(document).ready(function(){ 
 //動態(tài)添加大轉(zhuǎn)盤的獎品與獎品區(qū)域背景顏色 
 turnplate.restaraunts = ["50M免費流量包", "10金幣", "謝謝參與", "5金幣", "10M免費流量包", "20M免費流量包", "20金幣 ", "30M免費流量包", "100M免費流量包", "2金幣"]; 
 turnplate.colors = ["#FFF4D6", "#FFFFFF", "#FFF4D6", "#FFFFFF","#FFF4D6", "#FFFFFF", "#FFF4D6", "#FFFFFF","#FFF4D6", "#FFFFFF"]; 
  
   
 var rotateTimeOut = function (){ 
  $('#wheelcanvas').rotate({ 
   angle:0, 
   animateTo:2160, 
   duration:8000, 
   callback:function (){ 
    alert('網(wǎng)絡(luò)超時,請檢查您的網(wǎng)絡(luò)設(shè)置!'); 
   } 
  }); 
 }; 
  
 //旋轉(zhuǎn)轉(zhuǎn)盤 item:獎品位置; txt:提示語; 
 var rotateFn = function (item, txt){ 
  var angles = item * (360 / turnplate.restaraunts.length) - (360 / (turnplate.restaraunts.length*2)); 
  if(angles<270){ 
   angles = 270 - angles;  
  }else{ 
   angles = 360 - angles + 270; 
  } 
  $('#wheelcanvas').stopRotate(); 
  $('#wheelcanvas').rotate({ 
   angle:0, 
   animateTo:angles+1800, 
   duration:8000, 
   callback:function (){ 
    alert(txt); 
    turnplate.bRotate = !turnplate.bRotate; 
   } 
  }); 
 }; 
  
 $('.pointer').click(function (){ 
  if(turnplate.bRotate)return; 
  turnplate.bRotate = !turnplate.bRotate; 
  //獲取隨機數(shù)(獎品個數(shù)范圍內(nèi)) 
  var item = rnd(1,turnplate.restaraunts.length); 
  //獎品數(shù)量等于10,指針落在對應(yīng)獎品區(qū)域的中心角度[252, 216, 180, 144, 108, 72, 36, 360, 324, 288] 
  rotateFn(item, turnplate.restaraunts[item-1]); 
 }); 
}); 
  
function rnd(n, m){ 
 var random = Math.floor(Math.random()*(m-n+1)+n); 
 return random; 
   
} 
  
  
//頁面所有元素加載完畢后執(zhí)行drawRouletteWheel()方法對轉(zhuǎn)盤進行渲染 
window.onload=function(){ 
 drawRouletteWheel(); 
}; 
  
function drawRouletteWheel() {   
 var canvas = document.getElementById("wheelcanvas");   
 if (canvas.getContext) { 
  //根據(jù)獎品個數(shù)計算圓周角度 
  var arc = Math.PI / (turnplate.restaraunts.length/2); 
  var ctx = canvas.getContext("2d"); 
  //在給定矩形內(nèi)清空一個矩形 
  ctx.clearRect(0,0,422,422); 
  //strokeStyle 屬性設(shè)置或返回用于筆觸的顏色、漸變或模式  
  ctx.strokeStyle = "#FFBE04"; 
  //font 屬性設(shè)置或返回畫布上文本內(nèi)容的當(dāng)前字體屬性 
  ctx.font = '16px Microsoft YaHei';    
  for(var i = 0; i < turnplate.restaraunts.length; i++) {     
   var angle = turnplate.startAngle + i * arc; 
   ctx.fillStyle = turnplate.colors[i]; 
   ctx.beginPath(); 
   //arc(x,y,r,起始角,結(jié)束角,繪制方向) 方法創(chuàng)建弧/曲線(用于創(chuàng)建圓或部分圓)   
   ctx.arc(211, 211, turnplate.outsideRadius, angle, angle + arc, false);   
   ctx.arc(211, 211, turnplate.insideRadius, angle + arc, angle, true); 
   ctx.stroke();  
   ctx.fill(); 
   //鎖畫布(為了保存之前的畫布狀態(tài)) 
   ctx.save();   
     
   //----繪制獎品開始---- 
   ctx.fillStyle = "#E5302F"; 
   var text = turnplate.restaraunts[i]; 
   var line_height = 17; 
   //translate方法重新映射畫布上的 (0,0) 位置 
   ctx.translate(211 + Math.cos(angle + arc / 2) * turnplate.textRadius, 211 + Math.sin(angle + arc / 2) * turnplate.textRadius); 
     
   //rotate方法旋轉(zhuǎn)當(dāng)前的繪圖 
   ctx.rotate(angle + arc / 2 + Math.PI / 2); 
     
   /** 下面代碼根據(jù)獎品類型、獎品名稱長度渲染不同效果,如字體、顏色、圖片效果。(具體根據(jù)實際情況改變) **/ 
   if(text.indexOf("M")>0){//流量包 
    var texts = text.split("M"); 
    for(var j = 0; j<texts.length; j++){ 
     ctx.font = j == 0?'bold 20px Microsoft YaHei':'16px Microsoft YaHei'; 
     if(j == 0){ 
      ctx.fillText(texts[j]+"M", -ctx.measureText(texts[j]+"M").width / 2, j * line_height); 
     }else{ 
      ctx.fillText(texts[j], -ctx.measureText(texts[j]).width / 2, j * line_height); 
     } 
    } 
   }else if(text.indexOf("M") == -1 && text.length>6){//獎品名稱長度超過一定范圍  
    text = text.substring(0,6)+"||"+text.substring(6); 
    var texts = text.split("||"); 
    for(var j = 0; j<texts.length; j++){ 
     ctx.fillText(texts[j], -ctx.measureText(texts[j]).width / 2, j * line_height); 
    } 
   }else{ 
    //在畫布上繪制填色的文本。文本的默認顏色是黑色 
    //measureText()方法返回包含一個對象,該對象包含以像素計的指定字體寬度 
    ctx.fillText(text, -ctx.measureText(text).width / 2, 0); 
   } 
     
   //添加對應(yīng)圖標(biāo) 
   if(text.indexOf("金幣")>0){ 
    var img= document.getElementById("shan-img"); 
    img.onload=function(){  
     ctx.drawImage(img,-15,10);    
    };  
    ctx.drawImage(img,-15,10);  
   }else if(text.indexOf("謝謝參與")>=0){ 
    var img= document.getElementById("sorry-img"); 
    img.onload=function(){  
     ctx.drawImage(img,-15,10);    
    };  
    ctx.drawImage(img,-15,10);  
   } 
   //把當(dāng)前畫布返回(調(diào)整)到上一個save()狀態(tài)之前  
   ctx.restore(); 
   //----繪制獎品結(jié)束---- 
  }    
 }  
}        

實現(xiàn)效果圖:

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • 喜大普奔!jQuery發(fā)布 3.0 最終版

    喜大普奔!jQuery發(fā)布 3.0 最終版

    jQuery發(fā)布已經(jīng)十年了,挺讓人難以置信。過去的這些年Web開發(fā)變了很多,jQuery也隨之變化著。在這個過程中,團隊一直在對確保過往代碼的兼容支持和獲取最好的Web開發(fā)實踐的現(xiàn)實之間努力著。就在2天前,jQuery發(fā)布了新的3.0最終版本
    2016-06-06
  • 基于JQuery制作可編輯的表格特效

    基于JQuery制作可編輯的表格特效

    這篇文章主要介紹了基于JQuery制作可編輯的表格特效,一共給出了2種解決方案,小伙伴們能看出來哪種方案更合理嗎?
    2014-12-12
  • jQuery  ready方法實現(xiàn)原理詳解

    jQuery ready方法實現(xiàn)原理詳解

    這篇文章主要介紹了jQuery ready方法實現(xiàn)原理詳解的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • jquery uploadify 在FF下無效的解決辦法

    jquery uploadify 在FF下無效的解決辦法

    這篇文章主要介紹了jquery uploadify 在FF下無效的解決辦法,很實用,需要的朋友可以參考下
    2014-09-09
  • jQuery實現(xiàn)連續(xù)動畫效果實例分析

    jQuery實現(xiàn)連續(xù)動畫效果實例分析

    這篇文章主要介紹了jQuery實現(xiàn)連續(xù)動畫效果,實例分析了animate方法實現(xiàn)動畫效果的相關(guān)技巧,并備有較為詳盡的注釋供讀者學(xué)習(xí)參考,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • jQuery替換textarea中換行的方法

    jQuery替換textarea中換行的方法

    這篇文章主要介紹了jQuery替換textarea中換行的方法,涉及jQuery操作頁面元素的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • jQuery validate插件功能與用法詳解

    jQuery validate插件功能與用法詳解

    這篇文章主要介紹了jQuery validate插件功能與用法,結(jié)合實例形式詳細分析了jQuery validate插件的功能、參數(shù)、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2016-12-12
  • jquery.multiselect多選下拉框?qū)崿F(xiàn)代碼

    jquery.multiselect多選下拉框?qū)崿F(xiàn)代碼

    這篇文章主要為大家詳細介紹了jquery.multiselect 多選下拉框?qū)崿F(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 推薦10個2014年最佳的jQuery視頻插件

    推薦10個2014年最佳的jQuery視頻插件

    也許有時你需要在網(wǎng)站上播放一些音頻和視頻文件,也許你正在建立一個在線社區(qū)需要有分享和播放音樂和視頻的功能。下面介紹的這些免費jQuery插件也許有你需要的。
    2014-11-11
  • jquery移動listbox的值原理及代碼

    jquery移動listbox的值原理及代碼

    jQuery操作listbox原理并不難,就是將listbox中的選中項進行移動,實現(xiàn)我們需要的移動效果,具體實例如下,感興趣的朋友可以學(xué)習(xí)下
    2013-05-05

最新評論