一个好玩的jq+php实现转盘抽奖程序
前台页面:
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<meta name="keywords" content="html5,本地存储" />
<meta name="description" content="Helloweba演示平台,演示XHTML、CSS、jquery、PHP案例和示例" />
<title>幸运大转盘-jQuery+PHP实现的抽奖程序</title>
<style type="text/css">
*{ margin:0; padding:0;}
img { border:none;}
.w1000{ width:1000px; margin:0 auto;}
.w1000 img, .gl img{ display:block;}
/*中奖名单*/
button{padding:2px 8px;}
.action{text-align:center; padding:10px; border-bottom:dashed 1px #ccc;}
#rightDemo{width:257px; padding:10px;position:absolute; left:95px; top:90px;}
#rightDemo li{ color:#825a00; font-size:13px;width:257px;}
ul{ height:335px; overflow:hidden;}
ul li{line-height:30px; height:30px; overflow:hidden; list-style:none; padding:0; margin:0;}
/*页面样式*/
.box_11{ background:url(http://www.sansejin.com.cn/themes/laboci_2012/images/sales201308/box_r11_bg.jpg) no-repeat center center;}
.gl{ background:#F00F4B;}
/*转盘样式*/
#main{width:1000px; min-height:600px; margin:0 auto;}
.demo{width:1000px; height:527px; position:relative; margin:0 auto; zoom:1;}
#disk{width:1000px; height:527px; background:url(http://www.sansejin.com.cn/themes/laboci_2012/images/sales201308/disk.jpg) no-repeat}
#start{width:111px; height:212px; position:absolute; top:149px; left:605px;}
#start img{cursor:pointer}
/*转盘样式*/ </style>
<script type="text/javascript" src="http://www.helloweba.com/demo/js/jquery.js"></script>
<script type="text/javascript" src="http://www.helloweba.com/demo/lottery/jQueryRotate.2.2.js"></script>
<script type="text/javascript" src="http://www.helloweba.com/demo/lottery/jquery.easing.min.js"></script>
<script type="text/javascript">
$(function(){
$("#startbtn").click(function(){
lottery();
});
});
function lottery(){
$.ajax({
type: 'POST',
url: 'data.php',
dataType: 'json',
cache: false,
error: function(){
alert('出错了!');
return false;
},
success:function(json){
$("#startbtn").unbind('click').css("cursor","default");
var a = json.angle;
var p = json.prize;
$("#startbtn").rotate({
duration:3000, //转动时间
angle: 0, //默认角度
animateTo:1800+a, //转动角度
easing: $.easing.easeOutSine,
callback: function(){
alert('恭喜你,抽中'+'"'+p+'"!');
$("#startbtn").rotate({angle:0}); $("#startbtn").click(function(){ lottery(); }).css("cursor","pointer"); }
});
}
});
}
</script>
</head> <body> <div class="gl">
<!--抽奖区域[-->
<div class="gl">
<div class="box_11">
<!--抽奖转盘[-->
<div class="demo">
<div id="disk"></div>
<div id="start"><img src="http://www.sansejin.com.cn/themes/laboci_2012/images/sales201308/start.png" alt="抽奖" id="startbtn"/></div>
<!--中奖名单[-->
<div id="rightDemo">
<ul id="rightBox">
<li>手机尾号为***7884的用户抽中100元现金券大礼包</li>
<li>手机尾号为***7884的用户抽中100元现金券大礼包</li>
<li>手机尾号为***0573的用户抽中大奖iphone5智能手机</li>
<li>手机尾号为***3200的用户抽中300元现金券大礼包</li>
<li>手机尾号为***4520的用户抽中300元现金券大礼包</li>
<li>手机尾号为***2341的用户抽中300元现金券大礼包</li>
<li>手机尾号为***9687的用户抽中3折抢购齿白健精品套装</li>
<li>手机尾号为***0931的用户抽中300元现金券大礼包</li>
<li>手机尾号为***1747的用户抽中3折抢购红酒木瓜丰胸靓汤</li>
<li>手机尾号为***3748的用户抽中100元现金券大礼包</li>
<li>手机尾号为***0125的用户抽中300元现金券大礼包</li>
<li>手机尾号为***0063的用户抽中3折抢购魔泥金装精品套装</li>
<li>手机尾号为***7884的用户抽中300元现金券大礼包</li>
<li>手机尾号为***5892的用户抽中100元现金券</li>
<li>手机尾号为***7884的用户抽中300元现金券大礼包</li>
<li>手机尾号为***7224的用户抽中3折抢购祛疤精华凝露组合二代</li>
<li>手机尾号为***7910的用户抽中300元现金券大礼包</li>
<li>手机尾号为***2832的用户抽中300元现金券大礼包</li>
<li>手机尾号为***3488的用户抽中3折抢购红酒木瓜丰胸靓汤</li>
<li>手机尾号为***6693的用户抽中300元现金券大礼包</li>
<li>手机尾号为***4787的用户抽中3折抢购齿白健精品套装</li>
<li>手机尾号为***8547的用户抽中3折抢购祛疤精华凝露组合二代</li>
<li>手机尾号为***7884的用户抽中300元现金券大礼包</li>
<li>手机尾号为***2670的用户抽中100元现金券</li>
<li>手机尾号为***0811的用户抽中300元现金券大礼包</li>
<li>手机尾号为***5120的用户抽中3折抢购魔泥金装精品套装</li>
<li>手机尾号为***9229的用户抽中300元现金券大礼包</li>
<li>手机尾号为***4321的用户抽中大奖ipad mini平板电脑</li>
<li>手机尾号为***6693的用户抽中300元现金券大礼包</li>
<li>手机尾号为***8777的用户抽中100元现金券</li>
<li>手机尾号为***9968的用户抽中300元现金券大礼包</li>
<li>手机尾号为***4699的用户抽中3折抢购祛疤精华凝露组合二代</li>
<li>手机尾号为***8511的用户抽中300元现金券大礼包</li>
<li>手机尾号为***6665的用户抽中300元现金券大礼包</li>
<li>手机尾号为***5552的用户抽中3折抢购红酒木瓜丰胸靓汤</li>
<li>手机尾号为***4321的用户抽中300元现金券大礼包</li>
<li>手机尾号为***1399的用户抽中100元现金券大礼包</li>
<li>手机尾号为***8455的用户抽中3折抢购魔泥金装精品套装</li>
<li>手机尾号为***8822的用户抽中300元现金券大礼包</li>
<li>手机尾号为***8224的用户抽中3折抢购红酒木瓜丰胸靓汤</li>
<li>手机尾号为***5023的用户抽中300元现金券大礼包</li>
</ul>
</div>
<!--]end 中奖名单-->
</div>
<!--]end 抽奖转盘-->
</div>
</div> <script type="text/javascript">
function maquer(){
setInterval(function(){
$('#rightBox li:first').animate({'height':'0','opacity': '0'}, 'slow', function() {
$(this).removeAttr('style').insertAfter('#rightBox li:last');
});
},1000);
$(this).attr('disabled',true);
return;
}
maquer();
</script>
</body>
</html>
data.php
<?php include("config.php");//链接数据库 $prize_arr = array(
'0' => array('id'=>1,'min'=>55,'max'=>80,'prize'=>'3折抢购红酒木瓜丰胸靓汤 ','v'=>10),//弧度:55°-80°范围是:“3折抢购红酒木瓜丰胸靓汤”奖, v=10是中奖率是10%
'1' => array('id'=>2,'min'=>10,'max'=>35,'prize'=>'3折抢购自由呼吸魔泥金装精品套装','v'=>10),
'2' => array('id'=>3,'min'=>320,'max'=>355,'prize'=>'100元现金券','v'=>20),
'3' => array('id'=>4,'min'=>230,'max'=>265,'prize'=>'3折抢购218齿白健套装','v'=>10),
'4' => array('id'=>5,'min'=>185,'max'=>215,'prize'=>'3折抢购498元祛疤精华','v'=>10),
'5' => array('id'=>6,'min'=>140,'max'=>170,'prize'=>'300元现金券大礼包','v'=>40)
); function getRand($proArr) {
$result = '';
//概率数组的总概率精度
$proSum = array_sum($proArr);
//概率数组循环
foreach ($proArr as $key => $proCur) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $proCur) {
$result = $key;
break;
} else {
$proSum -= $proCur;
}
}
unset ($proArr); return $result;
} foreach ($prize_arr as $key => $val) {
$arr[$val['id']] = $val['v'];
}
$rid = getRand($arr); //根据概率获取奖项id
$res = $prize_arr[$rid-1]; //中奖项
$min = $res['min'];
$max = $res['max'];
$result['angle'] = mt_rand($min,$max); //随机生成一个角度
$result['prize'] = $res['prize'];
echo json_encode($result);
?>
config.php(其实也可以不链接数据库,把data.php里面的链接数据库注释)
<?php
$q=mysql_connect("localhost","root","");
if(!$q){
die('亲,链接不到数据库哦!'.mysql_error());
}
mysql_query("set name utf8"); //以utf8读取数据库
mysql_select_db("test",$q); //数据库
?>
原文:
http://www.helloweba.com/view-blog-216.html
一个好玩的jq+php实现转盘抽奖程序的更多相关文章
- 用jQuery和PHP来实现转盘抽奖程序
准备工作 首先要准备素材,抽奖的界面用到两张图片,圆盘图片和指针图片,实际应用中可以根据不同的需求制作不同的圆盘图片. 接着制作html页面,实例中我们在body中加入如下代码: <div cl ...
- 幸运大转盘-jQuery+PHP实现的抽奖程序
目前好多网站上应用的转盘抽奖程序大多是基于flash的,而本文结合实例将使用jQuery和PHP来实现转盘抽奖程序,为了便于理解,作者分两部分来讲解,本文讲解第一部分,侧重使用jQuery实现转盘的转 ...
- jQuery幸运大转盘_jQuery+PHP抽奖程序
http://www.thinkphp.cn/code/1153.html 网上转盘抽奖程序大多是flash完成的,而本文使用jQuery和PHP来实现转盘抽奖程序. 若是想看更多js特效.网站源码. ...
- 简单JS旋转实现转盘抽奖效果
闲来没事,做了一个模拟转盘抽奖的HTML&JS的效果: 可以在设置的时候,选择几个区域,并且可以填写指针将要停止的区域 比如,我选择了"区域2",结果就是这样 具体可以见下 ...
- 简单的转盘抽奖——CSS动画优化
前言 前两天去一家公司面试,被问到一些小游戏的东西.面试官提到了刷红包还有抽奖这些怎么实现,当时简单说了下思路,回来之后想想还是说的太轻描淡写了,干说不做就是耍流氓,所以就做了一个(Demo & ...
- HTML5 Canvas绘制转盘抽奖
新项目:完整的Canvas转盘抽奖代码 https://github.com/givebest/GB-canvas-turntable 演示 http://blog.givebest.cn/GB-ca ...
- javascript 转盘抽奖代码和计数器代码
要介绍了javascript圆盘抽奖程序实现原理和完整代码例子,需要的朋友可以参考下 看到网页上有不少大转盘抽奖的应用,心血来潮也想弄个.于是找了点资料自己研究... 效果预览: 一.模拟抽奖的实 ...
- js转盘抽奖
这个是很简易的转盘,只用了html,css,js 通过css产生一个转盘上的指针,用js动态改变css中的transparent改变指针的角度.再添加一个背景图片类似于奖项的转盘 <!DOCTY ...
- canvas转盘抽奖
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" ...
随机推荐
- lazy loading img 图片延迟加载
http://yunpan.cn/cVsjPW6dgbcsh (提取码:b5db)
- notepad++搜索结果不显示line XX的方法
在使用notepad++如果多次搜索,得到的结果中会出现多次line xx: line xx:,造成文件大量垃圾信息的存在,不利于找寻所需的内容,如下图. 对于这种情况, ...
- HTML&CSS基础学习笔记1.19-DIV标签1
div标签 这里我们要认识一下HTML里使用非常多的的一个标签:<div>. <div>标签定义文档中的分区或节(division/section),他可以把文档分割为独立的. ...
- USB 调试工具(python2.7 + Tkinter + pyusb/pywinusb)
项目地址:USB-HID-TEST 整体预览图(win8下的效果): ====================== 项目结构: COM --hidHelper.py --usbHelper.py UI ...
- Codeforces 449D Jzzhu and Numbers
http://codeforces.com/problemset/problem/449/D 题意:给n个数,求and起来最后为0的集合方案数有多少 思路:考虑容斥,ans=(-1)^k*num(k) ...
- 关于NSIS脚本的Demo
这个NSIS脚本是打包公司的整个Release项目工程. 用NSIS编译器编译下就可以了. ; Script generated by the HM NIS Edit Script Wizard. ! ...
- [置顶] 【原创分享】嵌入式linux应用之内核移植定制篇-前篇(linux-3.8.12 mini2440)--20130824
移植的话其实很早就做过了,不过那时用的友善定制的老版本2.6.32 驱动什么的全部弄好了,仅仅用默认配置而已.基本不用改动什么,很简单. 内核更新其实非常的快,今天我就用个3.8.12来移植. 当然, ...
- BZOJ2768: [JLOI2010]冠军调查
2768: [JLOI2010]冠军调查 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 484 Solved: 332[Submit][Status ...
- sicily 1007 To and Fro
题意:字符串的操作处理 // Problem#: 8768 // Submission#: 2606406 // The source code is licensed under Creative ...
- js 获取input file路径改变图像地址
html代码 <img id="newImage" alt="100x100" src="__PUBLIC__/img/1.jpg" ...