js轮盘抽奖

需求:实现中奖是否可控

思路:通过旋转角度来实现轮盘转动,根据角度来确定是否中奖

 window.onload = function(){

     var oTurn = document.getElementById('turntable');
     var oStart = document.getElementById('start');
     var timer, timer2 = null;
     var deg = 0;    //当前旋转度数
     var iSpeed = 0;    //加速减速变量
     var iNum = 1800;    //旋转角度(旋转多少圈360*i)
     var iZ = 45+60*1;    //可中奖的值(15+60*i), 不中奖的值(45+60*i)
     var iTotal = iNum + iZ;    //总共旋转度数
     var bStop = true;    //可点击开关
     var iTp = 0;        //保存下一次旋转需要的总度数
     var bFirst = true;    //是否第一次点击

     oStart.onclick = function(){
         start();
     };

     function start(){
         if(bStop){
             bStop = false;

             timer = setInterval(function(){
                 //第一次点击,小于总度数的一半时加速,大于一半是减速,速度小于0时,默认为0.5
                 if(bFirst){
                     if(deg<=iTotal/2){
                         iSpeed = iSpeed + 0.1;
                     }
                     if(deg>iTotal/2){
                         iSpeed -= 0.1;
                     }
                     if(iSpeed <= 0){
                         iSpeed = 0.5;
                     }
                 }else{
                     if(deg<=iTp/2){
                         iSpeed = iSpeed + 0.1;
                     }
                     if(deg>iTp/2){
                         iSpeed -= 0.1;

                     }
                     if(iSpeed <= 0){
                         iSpeed = 0.5;
                     }
                 }    

                 deg+=iSpeed;    //每次旋转度数=当前度数+ 速度变量(速度快,旋转快,即加速运动;速度慢,减速运动)        

                 //当前度数大于等于总度数是停止
                 if(deg>=iTotal){
                     clearInterval(timer);
                     deg%=360;                //设置
                     iTp = iTotal + deg;        //下一次旋转的总度数
                     iSpeed = 0;                //重置
                     bFirst = false;
                     bStop = true;
                     return false;
                 }else{
                     $('#turntable').css({'-webkit-transform':'rotate(' + deg + 'deg)'});
                 }

             }, 30);
         }
     }    

 };

js轮盘抽奖的更多相关文章

  1. C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断

    C#保留2位小数几种场景总结   场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...

  2. 原生js轮盘抽奖实例分析(幸运大转盘抽奖)

    效果图: 所需图片素材: 这张图是pointer.png的位置的. turntable-bg.jpg这张是转盘背景图,在背景位置. 这张是turntable.png位置的. 需要这三张图片,如果要实现 ...

  3. js转盘抽奖

    这个是很简易的转盘,只用了html,css,js 通过css产生一个转盘上的指针,用js动态改变css中的transparent改变指针的角度.再添加一个背景图片类似于奖项的转盘 <!DOCTY ...

  4. js一个抽奖的例子

    朋友公司开年会,帮忙写了个抽奖的demo,源码如下,github中有程序: html: <header> lottery demo </header> <div clas ...

  5. Js 转动抽奖实现

    一.样本 地址:http://js.zhuamimi.cn/choujiang/index.htm 源码:https://pan.baidu.com/s/15KhesfcLf1WMOom6PhzCjA ...

  6. js实现抽奖

    抽奖.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  7. js 简单抽奖实现

    大家在很多活动页面上都看到绚丽多彩的抽奖运用,网上也有比较多关于这方面的js和用as.今天我在工作的时候也要做个抽奖的运用.我之前没有写过这类的js,也不会as,就得屁颠屁颠的问度娘啦,虽然找到有js ...

  8. jquery.rotate.js可选抽奖次数和中奖内容的转盘抽奖demo

    需求: 最多可以抽奖5次,而且,每次只会中“2000元理财金”或者“谢谢参与”,其它的不会抽中(哈哈,果然都是套路). 效果如下: 一.页面结构: <div class="g-cont ...

  9. JS数组抽奖程序教学实例

    数组Javascript中非常重要的知识点,为了在课堂上提高学生兴趣,教学举例的选择就比较重要了. 为了提高学生兴趣,特设计一个可输入,可控制结束的,利用JS数组实现的抽奖教学实例.代码如下:

随机推荐

  1. Vmware虚拟机网络模式及虚拟机与物理机通信方法

    [转]http://www.cqeis.com/news_detail/newsId=1477.html Vmware虚拟机软件是一个“虚拟PC”软件,它使你可以在一台机器上同时运行二个或更多Wind ...

  2. ubuntu下vpn无反应的解决办法

    mv ~/.gconf  ~/.gcongbk0 sudo reboot

  3. Niagara技术文档汇总

    Niagara技术文档汇总http://wenku.baidu.com/view/ccdd4e2c3169a4517723a38f.html Niagara讲解要点http://wenku.baidu ...

  4. ORA-00845 Oracle 启不来修改 MEMORY_TARGET

    1.内存减小导致Oracle启动不了   Last login: Sun Nov  4 15:09:06 2012 from 192.168.5.222  [oracle@h1 ~]$ sqlplus ...

  5. JavaScript+XML+VBA导出报表初步构想

    最近在做人事档案管理系统遇到的一个问题就是种类多.数量大的报表打印问题.这个系统的一个特点就是信函打印,各种介绍信.各种证明信.对于这样的重复性的功能,最好的方法就是所有的报表实现格式套用. 经过分析 ...

  6. HDU 3060 多边形面积并

    Area2 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  7. if语句之求一元二次方程

    思路:1.首先明白什么叫做一元二次方程,当a不等于0的时候,此方程是一元二次方程 2.根据公式derta=b*b-4*a*c来判断根的情况 ①derta>0时,方程有两个不相等的实根 ②dert ...

  8. POJ 1562(L - 暴力求解、DFS)

    油田问题(L - 暴力求解.DFS) Description The GeoSurvComp geologic survey company is responsible for detecting ...

  9. USACO Palindromic Squares 【STL__string_的应用】

    这里有个讲解 string 用法非常详细的博文:https://www.byvoid.com/zhs/blog/cpp-string 题目意思很简单啦,就是找回文 使用string可以高速A过 Sou ...

  10. Verilog实现IIC通讯第二版

    HMC5883三轴磁力传感器IIC通讯模块的VerilogHDL的实现 上一版并没有实现我想要的功能 0.0.1版   正在修订中   2013/9/2 //date :2013/7/7 //desi ...