利用jqueryRotare实现抽奖转盘
很多公司到了年底都会做一些抽奖活动来刺激、吸引、粘住客户,比如抽奖转盘活动。
前几天用一个jqueryRotate插件实现了转盘的效果。比起那些很炫丽的flash是稍逊点,但也基本实现了需求
效果图:(也可以看线上的效果:http://www.mbabycare.com/course/lottery):
实现这个其实蛮简单的,转动的效果用的jqueryRotate插件,所以只要判断每个奖荐对应的角度,然后设置指针的转动角度就可以了。比如关键的是jqueryRotate这个插件的用法。
jqueryRotate的资料:
支持Internet Explorer 6.0+ 、Firefox 2.0 、Safari 3 、Opera 9 、Google Chrome,高级浏览器下使用Transform,低版本ie使用VML实现
google code地址:http://code.google.com/p/jqueryrotate/
调用和方法:
$(el).rotate({ angle:0, //起始角度animateTo:180, //结束的角度duration:500, //转动时间callback:function(){}, //回调函数easing: $.easing.easeInOutExpo //定义运动的效果,需要引用jquery.easing.min.js的文件})$(el).rotate(45); //直接这样子调用的话就是变换角度$(el).getRotateAngle(); //返回对象当前的角度$(el).stopRotare(); //停止旋转动画 另外可以更方便的通过调用$(el).rotateRight()和$(el).rotateLeft()来分别向右旋转90度和向左旋转90度。
很简单吧,各种example可以看这里:http://code.google.com/p/jqueryrotate/wiki/Examples
下面是用jqueryRotate实现的抽奖转盘页面:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>转盘</title> <style>*{padding:0;margin:0}body{text-align:center}.ly-plate{position:relative;width:509px;height:509px;margin: 50px auto;}.rotate-bg{width:509px;height:509px;background:url(ly-plate.png);position:absolute;top:0;left:0}.ly-plate div.lottery-star{width:214px;height:214px;position:absolute;top:150px;left:147px;/*text-indent:-999em;overflow:hidden;background:url(rotate-static.png);-webkit-transform:rotate(0deg);*/outline:none}.ly-plate div.lottery-star #lotteryBtn{cursor: pointer;position: absolute;top:0;left:0;*left:-107px} </style> </head> <body><div class="ly-plate"><div class="rotate-bg"></div><div class="lottery-star"><img src="rotate-static.png" id="lotteryBtn"></div></div> </body> <script src="jquery-1.7.2.min.js"></script> <script src="jQueryRotate.2.2.js"></script><script> $(function(){var timeOut = function(){ //超时函数 $("#lotteryBtn").rotate({angle:0, duration: 10000, animateTo: 2160, //这里是设置请求超时后返回的角度,所以应该还是回到最原始的位置,2160是因为我要让它转6圈,就是360*6得来的callback:function(){alert('网络超时')}}); }; var rotateFunc = function(awards,angle,text){ //awards:奖项,angle:奖项对应的角度,text:提示文字 $('#lotteryBtn').stopRotate();$("#lotteryBtn").rotate({angle:0, duration: 5000, animateTo: angle+1440, //angle是图片上各奖项对应的角度,1440是我要让指针旋转4圈。所以最后的结束的角度就是这样子^^callback:function(){alert(text)}}); };$("#lotteryBtn").rotate({ bind: { click: function(){var time = [0,1];time = time[Math.floor(Math.random()*time.length)];if(time==0){timeOut(); //网络超时 }if(time==1){var data = [1,2,3,0]; //返回的数组 data = data[Math.floor(Math.random()*data.length)];if(data==1){rotateFunc(1,157,'恭喜您抽中的一等奖')}if(data==2){rotateFunc(2,247,'恭喜您抽中的二等奖')}if(data==3){rotateFunc(3,22,'恭喜您抽中的三等奖')}if(data==0){var angle = [67,112,202,292,337];angle = angle[Math.floor(Math.random()*angle.length)]rotateFunc(0,angle,'很遗憾,这次您未抽中奖')}}}} });}) </script> </html>
这里的time跟data是要从后台获取的,但这里只是静态页面,所以我就利用了random随机数来尽量模拟抽奖的过程了。
time参数表示从后台请求是否成功,0是请求超时,1是请求成功(成功后再判断返回的值是什么样);
data就是请求返回的数据,1,2,3表示一二三等奖,0是不中奖,根据返回的数据,再去设置指针旋转的角度。
因为这个图片上的角度无法用公式计算出来,所以只能这样子计算出来后定死。
如果比较规则的话,应该可以用公式计算。
若你有更好的想法,也可以留言给我:)
点击下载完整demo
参考:http://www.css88.com/archives/4959
转载于:https://www.cnblogs.com/mofish/archive/2013/01/24/2875516.html
利用jqueryRotare实现抽奖转盘相关推荐
- 详解与重构hyman《Android SurfaceView实战 打造抽奖转盘》
详解与重构hyman<Android SurfaceView实战 打造抽奖转盘> 作者:邵励治 一.概述--关于SurfaceView您不得不知道的二三事 1.SurfaceView是干什 ...
- Android实现抽奖转盘
慕客网视频传送门:http://www.imooc.com/learn/444 好久都没去慕客网了,虽然这次学习的是一个比较老的视频了,但是总比不学的好.(末尾附源码) 在学习之前,先来了解一波Sur ...
- html如何画出抽奖的转盘,css 如何“画”一个抽奖转盘
主要描述的是如何运用 css 绘制一个抽奖转盘,并运用原生 js 实现转盘抽奖效果. 先来张效果图: 布局 一般来说,转盘一般有四个部分组成:外层闪烁的灯.内层旋转的圆盘.圆盘上的中奖结果.指针. 所 ...
- 绘制抽奖转盘 (CSS+JS)
绘制抽奖转盘 HTML部分 CSS部分 JS部分 最终效果 Hello!这里是万物之恋,今天来教大家用css+js来简单绘制一个抽奖轮盘(不可转动) HTML部分 <div class=&quo ...
- 九宫格抽奖转盘源码分析
效果如上图所示,下面对其实现代码进行分析,看能不能破解其抽奖规则.需要引入jquery-1.8.3.min.js和images/9张图片. <!DOCTYPE html PUBLIC ...
- python转盘抽奖_react 抽奖转盘 ----小计
前言 很久没有写过小组件了,突然想做一个抽奖转盘,就花半天时间做一个,很简单 1.支持把一个圆盘分成n瓣. 2.实现转动动画. 3.弄个指针样式意思意思. 4.遇到抽奖的需求改吧改吧就能用了. 图是这 ...
- 抽奖 开源 html5,抽奖转盘.html · smilestone/awardRotate - Gitee.com
jQuery 抽奖转盘 #box{width: 340px;height: 340px; position: absolute; left:50%;top:50%;margin-left:-170px ...
- html旋转代码_用CSS实现一个抽奖转盘(附详细代码+思路)
原文:https://www.cnblogs.com/wenruo/p/9732704.html 先上效果 基本是用CSS实现的,没有用图片,加一丢丢JS.不过没有考虑太多兼容性. 首先画一个转盘 & ...
- Html5-Canvas实现简易的抽奖转盘
###Html5实现抽奖转盘效果 1.实现的基本效果 2.主要的内容 html5中canvas标签的使用 jQueryRotate.js旋转插件 3.主要html代码 <body>< ...
最新文章
- iis5.1配置php5.3.1详解,WinXP IIS 5.1 PHP 5.3 VC9.0 配置详解
- Maven学习总结(五)——聚合与继承
- 谷歌让AI芯片学会“下崽”,下一代TPU就让AI自己设计
- 浮点数相加php,利用php怎么实现一个浮点数精确运算功能
- 排序箭头,升序,降序简单实现
- 回调函数案列(C高级)
- 【数据竞赛】图像赛排行榜拉开100名差距的技巧
- python字符串常用方法_字符串常用方法
- [数据结构与算法] 单链表的简单demo
- java ajax 导出excel文件_springMVC(4)---生成excel文件并导出
- 1003.imx6Q自启动脚本
- 音乐艺考生如何提高视唱练耳技巧
- python制作病毒_python做病毒
- Luogu 3332 [ZJOI2013]K大数查询
- google浏览器html不提示,谷歌浏览器不显示标签页怎么回事 谷歌浏览器不显示标签页的解决方法...
- 英国留学生Discursive Essay怎么写?
- uniapp app端拉起高德网页地图
- Oracle用OEM和命令行方式创建用户及表空间
- [再寄小读者之数学篇](2014-06-21 向量公式)
- LY68L6400SLIT 编带
热门文章
- 老男孩Linux学习 -- 关于添加第二块磁盘的那些事
- Android开发:自定义GridView/ListView数据源
- android JSONObject的使用
- arm-eabi-gcc: error trying to exec 'cc1': execvp: No such file or directory
- 解决ActionBar中的不显示View控件
- MySql—锁机制原理
- HDU - 6641 TDL(数学)
- BZOJ - 2744 朋友圈 (二分图上的最大团)
- 深入理解PHP的运行模式
- 二分+并查集【bzoj3007】[SDOI2012]拯救小云公主