http://www.thinkphp.cn/code/1153.html

网上转盘抽奖程序大多是flash完成的,而本文使用jQuery和PHP来实现转盘抽奖程序。

若是想看更多js特效、网站源码、 js教程请访问 http://www.sucaihuo.com/js 还有演示DEMO,最主要是可以免费下载。

  1. 首先要准备两张图片,即圆盘和指针,然后我们在#disk来放置圆盘背景图片,在css中控制,用#start来放置指针图片start.png。
  2. <div id="disk"></div>
  3. <div id="start"><img src="data:images/start.png" id="startbtn" alt="转盘开启"/></div>
  4. CSS指针和圆盘样式如下:
  5. #disk{width:417px; height:417px; background:url(images/disk.jpg) no-repeat}
  6. #start{width:163px; height:320px; position:absolute; top:46px; left:130px;}
  7. #start img{cursor:pointer}
  8. 接着我们引入jquery.js、旋转插件jQueryRotate.2.2.js及动画easing插件jquery.easing.min.js。easing 教程我们已经讲过了,jQuery Easing动画插件。
  9. <script type = "text/javascript" src = "jquery.js" > </script>
  10. <script type = "text/javascript" src = "jQueryRotate.2.2.js"></script>
  11. <script type = "text/javascript" src = "jquery.easing.min.js"></script>
  12. 最后通过jQueryRotate.js旋转插件,我们让指针转起来。
  13. $(function() {
  14. $("#startbtn").rotate({
  15. bind: {
  16. click: function() {
  17. var random = Math.floor(Math.random() * 360); //生成随机数
  18. $(this).rotate({
  19. duration: 3000,
  20. //转动时间间隔(速度单位ms)
  21. angle: 0,
  22. //指针开始角度
  23. animateTo: 3600 + random,
  24. //转动角度,当转动角度到达3600+random度时停止转动。
  25. easing: $.easing.easeOutSine,
  26. //easing动画效果
  27. callback: function() { //回调函数
  28. alert('恭喜您,中奖了!');
  29. }
  30. });
  31. }
  32. }
  33. });
  34. });
  35. 下面介绍使用PHP来控制抽奖几率,以及完成两者之间的交互:
  36. 首先,在ajax.php中创建一个奖项对应角度和中奖几率二维数组:
  37. $prize_arr = array(
  38. '0' => array('id' => 1, 'min' => 1, 'max' => 29, 'prize' => '一等奖', 'v' => 1),
  39. '1' => array('id' => 2, 'min' => 302, 'max' => 328, 'prize' => '二等奖', 'v' => 2),
  40. '2' => array('id' => 3, 'min' => 242, 'max' => 268, 'prize' => '三等奖', 'v' => 5),
  41. '3' => array('id' => 4, 'min' => 182, 'max' => 208, 'prize' => '四等奖', 'v' => 7),
  42. '4' => array('id' => 5, 'min' => 122, 'max' => 148, 'prize' => '五等奖', 'v' => 10),
  43. '5' => array('id' => 6, 'min' => 62, 'max' => 88, 'prize' => '六等奖', 'v' => 25),
  44. '6' => array('id' => 7, 'min' => array(32, 92, 152, 212, 272, 332),
  45. 'max' => array(58, 118, 178, 238, 298, 358), 'prize' => '七等奖', 'v' => 50)
  46. //min数组表示每个个奖项对应的最小角度 max表示最大角度
  47. //prize表示奖项内容,v表示中奖几率(若数组中七个奖项的v的总和为100,如果v的值为1,则代表中奖几率为1%,依此类推)
  48. );
  49. 中奖概率方法我们之前在jQuery砸金蛋_PHP砸金蛋讲过,代码如下
  50. function getRand($proArr) {
  51. $data = '';
  52. $proSum = array_sum($proArr); //概率数组的总概率精度
  53. foreach ($proArr as $k => $v) { //概率数组循环
  54. $randNum = mt_rand(1, $proSum);
  55. if ($randNum <= $v) {
  56. $data = $k;
  57. break;
  58. } else {
  59. $proSum -= $v;
  60. }
  61. }
  62. unset($proArr);
  63. return $data;
  64. }
  65. 函数getRand()会根据数组中设置的几率计算出符合条件的id,我们可以接着调用getRand()。
  66. foreach ($prize_arr as $v) {
  67. $arr[$v['id']] = $v['v'];
  68. }
  69. $prize_id = getRand($arr); //根据概率获取奖项id
  70. $res = $prize_arr[$prize_id - 1]; //中奖项
  71. $min = $res['min'];
  72. $max = $res['max'];
  73. if ($res['id'] == 7) { //七等奖
  74. $i = mt_rand(0, 5);
  75. $data['angle'] = mt_rand($min[$i], $max[$i]);
  76. } else {
  77. $data['angle'] = mt_rand($min, $max); //随机生成一个角度
  78. }
  79. $data['prize'] = $res['prize'];
  80. echo json_encode($data);
  81. 接着点击”开始抽奖“按钮,便会向后台ajax.php请求并返回奖项信息,这时指针开始转动,指针最终停留位置是由ajax.php返回值angle 来决定的,这样我们就可以控制概率和前端指针转动停留位置。代码如下:
  82. $(function() {
  83. $("#startbtn").click(function() {
  84. lottery();
  85. });
  86. });
  87. function lottery() {
  88. $.ajax({
  89. type: 'POST',
  90. url: 'ajax.php',
  91. dataType: 'json',
  92. cache: false,
  93. error: function() {
  94. alert('Sorry,出错了!');
  95. return false;
  96. },
  97. success: function(json) {
  98. $("#startbtn").unbind('click').css("cursor", "default");
  99. var angle = json.angle; //指针角度
  100. var prize = json.prize; //中奖奖项标题
  101. $("#startbtn").rotate({
  102. duration: 3000,//转动时间 ms
  103. angle: 0, //从0度开始
  104. animateTo: 3600 + angle,//转动角度
  105. easing: $.easing.easeOutSine, //easing扩展动画效果
  106. callback: function() {
  107. var resulte = confirm('恭喜您中得' + prize + '\n想要继续吗?');
  108. if (resulte) { //若是点击确定,继续抽奖
  109. lottery();
  110. }
  111. }
  112. });
  113. }
  114. });
  115. }
复制代码

查看该特效演示及免费下载,请访问http://www.sucaihuo.com/js/19.html

jQuery幸运大转盘_jQuery+PHP抽奖程序的更多相关文章

  1. jQuery幸运大转盘_jQuery+PHP抽奖程序的简单实现

    jQuery幸运大转盘_jQuery+PHP抽奖程序的简单实现 在线实例 查看演示 完整代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...

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

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

  3. jquery——九宫格大转盘抽奖

    一.用到的图片 二.代码如下,重点是js部分 <!DOCTYPE html> <html> <head> <meta http-equiv="Con ...

  4. PHP+AJAX开发幸运大转盘抽奖

    PHP+AJAX开发幸运大转盘抽奖,通过奖品库存.中奖次数来计算中奖概率 奖品设置 $prizes = array( 0 => array( "id" => 0, // ...

  5. asp.net+jQueryRotate开发幸运大转盘

    在线抽奖程序在很多网站上很多,抽奖形式多种多样,Flash抽奖偏多,本文将给大家介绍jQuery转盘抽奖,结合代码实例将使用jQuery和asp.net来实现转盘抽奖程序,为了便于理解,文章贴出实现源 ...

  6. PHP幸运大转盘源码,支持ThinkPHP

    原理 先看图 可以看到1-6等奖都只有1个 ,7等奖有6个.指针默认指向上图位置,记为0°. 每个奖项对应不同的角度,圆的角度为360°,分成12块,所以每块为30°. 为了防止指针指着相邻两个将向之 ...

  7. html5简单拖拽实现自动左右贴边+幸运大转盘

    此篇文章主要实现两个功能: 1.点击屏幕下方签到悬浮按钮: 2.弹出幸运大转盘,转盘抽奖签到 效果如图: ​ 在网上找了很多移动端拖拽的js实现方式,大部分都是这一种,html5的touch事件,但是 ...

  8. Vue 幸运大转盘

    转盘抽奖主要有两种,指针转动和转盘转动,个人觉得转盘转动比较好看点,指针转动看着头晕,转盘转动时指针是在转盘的中间位置,这里要用到css的transform属性和transition属性,这两个因为不 ...

  9. 跟我一起学编程—《Scratch编程》第24课:幸运大转盘

    同学你好,欢迎来到<跟我一起学编程>,我是包老师.这是<Scratch3.0编程>课程的第24课,我这节课教你做一个抽奖游戏:幸运大转盘. 学习目标: 1. 能够熟练使用造型工 ...

随机推荐

  1. 【bzoj2152】【聪聪可可】【点分治】

    [问题描写叙述] 聪聪和可但是兄弟俩.他们俩常常为了一些琐事打起来,比如家中仅仅剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(但是他们家仅仅有一台电脑)--遇到这样的问题,普通情况下石头剪刀布就好 ...

  2. Oracle11g表空间导入dmp数据

    如果你的表数据没有附带表空间和用户名,那么只要一句话 Imp {u_name}/{u_pwd}@{local_svrname} fromuser={from_user} touser={u_name} ...

  3. C项目实践之通讯录管理案例

    1.功能需求分析 通讯录管理案例主要实现对联系人的信息进行添加.显示.查找.删除.更新和保存功能.主要功能需求描述如下: (1)系统主控平台: 充许用户选择想要进行的操作,包括添加联系人信息,显示.查 ...

  4. HDU1045 Fire Net —— 二分图最大匹配

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1045 Fire Net Time Limit: 2000/1000 MS (Java/Others)  ...

  5. How to Execute Page_Load() in Page's Base Class?

    https://stackoverflow.com/questions/2737092/how-to-execute-page-load-in-pages-base-class We faced th ...

  6. YTU 2851: 数字游戏

    2851: 数字游戏 时间限制: 1 Sec  内存限制: 128 MB 提交: 164  解决: 85 题目描述 输入若干个正整数,将其中能写成其它两个正整数的平方和的数输出来. 例,若输入的数中有 ...

  7. 区块链共识算法 PBFT(拜占庭容错)、PAXOS、RAFT简述

    共识算法 区块链中最重要的便是共识算法,比特币使用的是POS(Proof of Work,工作量证明),以太币使用的是POS(Proof of Stake,股权证明)使得算理便的不怎么重要了,而今PO ...

  8. BZOJ1143:祭祀river(二分图求有向图的最大点独立集)

    在遥远的东方,有一个神秘的民族,自称Y族.他们世代居住在水面上,奉龙王为神.每逢重大庆典, Y族都 会在水面上举办盛大的祭祀活动.我们可以把Y族居住地水系看成一个由岔口和河道组成的网络.每条河道连接着 ...

  9. Python基础第七天

    一.内容 二.练习 练习1 题目:编写函数,函数执行的时间是随机的 图示: 代码: import time import random def func(): s = 1 l = [] for i i ...

  10. poj 3517(约瑟夫环问题)

    And Then There Was One Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 4873   Accepted: ...