jQuery+PHP实现的掷色子抽奖游戏实例,jquery色子

本文实例讲述了jQuery+PHP实现的掷色子抽奖游戏详细步骤。分享给大家供大家参考。具体分析如下:

该游戏是以大富翁游戏为背景,综合运用jQuery和PHP知识,设计出以掷色子点数来达成抽奖的效果,当然抽奖概率是可控的,开发者可以将本实例稍作修改即可运用到网站中的抽奖活动场景中。效果图如下:

完整实例代码点击此处本站下载。

HTML部分:

首先我们需要准备两粒色子和奖品素材,这些作者已经打包上传了,请大家放心下载。我们将在html页面中写下如下的html结构代码,.wrap用来放置色子和提示信息,#prize则是用来放置奖品的。

复制代码 代码如下:

CSS部分:

我们要用CSS技术来将页面布局合理规范化,我们将奖品围成一个矩形,共10个位置,将两粒色子定位在矩形的中央,抽奖时可以直接点击中间的色子。这些我们可以用CSS的定位技术来实现页面布局。

复制代码 代码如下:

.demo{width:650px; height:420px; margin:60px auto 10px auto; position:relative; }

.wrap{width:200px; height:100px; position:absolute; margin-left:220px; margin-top:140px; z-index:1000;}

#msg{display:none;width:50px; height:20px; padding:4px; background:#ffc; border:1px solid #fc9;

text-align:center; color:#f30; font-size:18px; position:absolute; z-index:1001; right:-20px; top:-10px}

.dice{width:90px; height:90px; display:block; float:left; background:url(dice.png) no-repeat; cursor:pointer}

#dice_mask{width:200px; height:100px; background:#fff; opacity:0; position:absolute; top:0; left:0; z-index:999}

.dice_1{background-position:-5px -4px}

.dice_2{background-position:-5px -107px}

.dice_3{background-position:-5px -212px}

.dice_4{background-position:-5px -317px}

.dice_5{background-position:-5px -427px}

.dice_6{background-position:-5px -535px}

.dice_t{background-position:-5px -651px}

.dice_s{background-position:-5px -763px}

.dice_e{background-position:-5px -876px}

#prize{position:relative}

#prize li{position:absolute; width:150px; height:112px; border:1px solid #d3d3d3}

#d_0{left:0; top:0}

#d_1{left:160px; top:0}

#d_2{left:320px; top:0}

#d_3{left:480px; top:0}

#d_4{left:480px; top:128px}

#d_5{left:480px; top:256px}

#d_6{left:320px; top:256px}

#d_7{left:160px; top:256px}

#d_8{left:0; top:256px}

#d_9{left:0; top:128px}

.mask{opacity: 0.6; width:150px; height:112px; line-height:32px; background:#ffc;

z-index:1001; position:absolute; top:0; left:0; text-align:center; font-size:16px}

jQuery部分:

我们使用jQquery来完成前端动作,包括掷色子动画,仿大富翁奖品逐步运动动画,其中有防重复点击知识、ajax交互知识,动画提示知识。整个 操作流程可简单概括为:点击色子->向dice.php发送ajax请求->完成掷色子动画->提示点数->逐步运动动画到最终 奖品位置停止->完成抽奖。

复制代码 代码如下:

$(function(){

$('#dice').click(function(){

$('#prize li .mask').remove();

$('.wrap').append('

');//加遮罩

var dice1 = $('#dice1');

var dice2 = $('#dice2');

$.getJSON('dice.php',function(json){

var num1 = json[0];

var num2 = json[1];

diceroll(dice1,num1);//掷色子1动画

diceroll(dice2,num2);//掷色子2动画

var num = parseInt(num1)+parseInt(num2);

$('#msg').css('top','-10px').fadeIn(500).text(num+'点').animate({top:'-50px'},'1000').fadeOut(500);

roll(0, num);//逐步运动动画

});

});

});

函数diceroll()是一个色子运动动画,在本站前面的文章中已讲解过,就是通过jQuery的animate()实现的位移、延时、变化背景样式来实现的动画效果。

复制代码 代码如下:

function diceroll(dice,num){

dice.attr('class','dice');//清除上次动画后的点数

dice.css('cursor','default');

dice.animate({left: '+2px'}, 100,function(){

dice.addClass('dice_t');

}).delay(200).animate({top:'-2px'},100,function(){

dice.removeClass('dice_t').addClass('dice_s');

}).delay(200).animate({opacity: 'show'},600,function(){

dice.removeClass('dice_s').addClass('dice_e');

}).delay(100).animate({left:'-2px',top:'2px'},100,function(){

dice.removeClass('dice_e').addClass('dice_'+num);

dice.css('cursor','pointer');

});

}

函数roll()至关重要,通过setInterval()设置一个间隔动画,每隔0.5秒时间执行一次。参数i代表初始位置,参数step代表需要执行 的步数,在本例中就是色子的点数,即需要走的步数。我们根据i给当前奖品加上.mask,当i的值与step相等时,停止动画,并且移除色子的遮罩(防止 重复点击)。

复制代码 代码如下:

function roll(i,step){

var time = setInterval(function(){

if(i>9){

var t = i - 10;

$('#d_'+t).append('

');

$('#d_'+(t-1)+' .mask').remove();

}

$('#d_'+i).append('

');

$('#d_'+(i-1)+' .mask').remove();

if(i==step){

clearInterval(time); //如果到达指定位置则停止

$('#dice_mask').remove();//移除遮罩

}

i++;//继续前进

},500);

}

PHP部分:

dice.php需要做的事情有:根据配置好的奖品概率,得到总点数,根据总点数进行两粒色子的点数分配,最后返回给前端页面两粒色子的点数。

复制代码 代码如下:

//设置中奖概率

$prize_arr = array(

'2' => array('id'=>2,'v'=>10),

'3' => array('id'=>3,'v'=>20),

'4' => array('id'=>4,'v'=>5),

'5' => array('id'=>5,'v'=>5),

'6' => array('id'=>6,'v'=>20),

'7' => array('id'=>7,'v'=>2),

'8' => array('id'=>8,'v'=>3),

'9' => array('id'=>9,'v'=>20),

'10' => array('id'=>10,'v'=>0),

'11' => array('id'=>11,'v'=>10),

'12' => array('id'=>12,'v'=>5),

);

foreach ($prize_arr as $key => $val) {

$arr[$val['id']] = $val['v'];

}

$sum = getRand($arr); //根据概率获取奖项id,得到总点数

//分配色子点数

$arrs = array(

'2' => array(array(1,1)),

'3' => array(array(1,2)),

'4' => array(array(1,3),array(2,2)),

'5' => array(array(1,4),array(2,3)),

'6' => array(array(1,5),array(2,4),array(3,3)),

'7' => array(array(1,6),array(2,7),array(3,4)),

'8' => array(array(2,6),array(3,5),array(4,4)),

'9' => array(array(3,6),array(4,5)),

'10' => array(array(4,6),array(5,5)),

'11' => array(array(5,6)),

'12' => array(array(6,6))

);

$arr_rs = $arrs[$sum];

$i = array_rand($arr_rs);//随机取数组

$arr_a = $arr_rs[$i];

shuffle($arr_a);//打乱顺序

echo json_encode($arr_a);

函数getRand()用来计算概率

复制代码 代码如下:

//计算概率

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;

}

希望本文所述对大家的php程序设计有所帮助。

http://www.bkjia.com/PHPjc/937083.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/937083.htmlTechArticlejQuery+PHP实现的掷色子抽奖游戏实例,jquery色子 本文实例讲述了jQuery+PHP实现的掷色子抽奖游戏详细步骤。分享给大家供大家参考。具体分析...

php色子,jQuery+PHP实现的掷色子抽奖游戏实例,jquery色子_PHP教程相关推荐

  1. php 掷,jQuery+PHP实现的掷色子抽奖游戏实例

    jQuery+PHP实现的掷色子抽奖游戏实例 发布于 2016-01-23 05:44:43 | 334 次阅读 | 评论: 0 | 来源: 网友投递 PHP开源脚本语言PHP(外文名: Hypert ...

  2. php丢色子,PHP制作的掷色子点数抽奖游戏实例(代码)

    PHP制作的掷色子点数抽奖游戏实例,通过掷色子点数来达到抽奖的效果,为抽奖活动增添一些趣味性. 我们将在html页面中写下如下的html结构代码,.wrap用来放置色子和提示信息,#prize则是用来 ...

  3. php 控制骰子概率,PHP制作的掷色子点数抽奖游戏实例(代码)

    PHP制作的掷色子点数抽奖游戏实例,通过掷色子点数来达到抽奖的效果,为抽奖活动增添一些趣味性. 我们将在html页面中写下如下的html结构代码,.wrap用来放置色子和提示信息,#prize则是用来 ...

  4. 投色子抽奖游戏 html,jQuery实现简单的抽奖游戏

    今天要写的是,利用jQuery写一个抽奖的案例,页面包含四个组件,两个按钮分别是开始和停止的按钮.两个box,分别盛放人员和奖品.当点击开始按钮时,人员不停地进行切换.抽奖的box中显示等待抽奖结果. ...

  5. 投色子抽奖游戏 html,使用jQuery实现的掷色子游戏动画效果

    实现原理:当色子掷出后,通过jQuery的animate()函数改变色子位移,中间加入延时效果,并变换色子背景,最终动画运行到随机产生的点数时停止,并显示掷出的点数.其实就是动画过程加入多个不同图片的 ...

  6. php掷骰子游戏,js实现简单掷骰子小游戏

    本文实例为大家分享了js掷骰子小游戏的具体代码,供大家参考,具体内容如下 实现方法: 方法一:通过background-position.background-image.backg-repeat三个 ...

  7. jQuery实现自动左右滚动效果的代码实例

    2019独角兽企业重金招聘Python工程师标准>>> jQuery实现自动左右滚动效果的代码实例 思路: 点击滚动模式下,是为点击(向前/向后/数字)添加click事件,通过控制展 ...

  8. jQuery遍历之next()、nextAll()方法使用实例

    jquery遍历:next()和nextAll()方法.实例如下: 复制代码 代码如下: <html> <head> <script type="text/ja ...

  9. jquery.zSlide.js-基于CSS3/HTML5演示文档jQuery插件

    一.卖的什么葫芦药? jquery.zSlide.js是我最近折腾的一个jQuery插件,借助于CSS3和HTML5的一些新特性,在浏览器中实现类似于powerpoint幻灯片展示. 如果你看到这段文 ...

  10. jquery table ajax,JQuery Ajax动态加载Table数据的实例讲解

    我们在jsp定义一个select和一个table,要求实现根据select的选值,动态加载table数据. table第一次加载数据的function定义如下: function loadData() ...

最新文章

  1. POJ 3061 (二分+前缀和or尺取法)
  2. STL vector的几种清空容器(删除)办法
  3. 只会使用 WaitGroup?你应该学习下 ErrGroup!
  4. 高通量数据中批次效应的鉴定和处理(二)
  5. Hyper-V passes Microsoft’s checkmarks exam: isn’t that always the case?
  6. js 实现ReplaceAll 的方法
  7. 进程退出:SIGINT、SIGTERM和SIGKILL区别
  8. 微信小程序——车牌键盘js+css
  9. Linux驱动开发: USB驱动开发
  10. TCP/UDP常用端口号,大家快收藏
  11. 华为云centos8 配置国内yum源及遇到问题
  12. Excel最大值和最小值的提取问题
  13. php钓鱼怎么使用方法,盘钩使用方法
  14. ABAP对excel的操作(为单元格填充背景颜色、设置border等)
  15. 贴片电阻封装经验选择学习研究总结
  16. C语言——数组定义及用法
  17. 【技术邻】CAE工程师崩溃的10个瞬间
  18. 《淘宝技术这十年》读书笔记 (四). 分布式时代和中间件
  19. FlexRay网络管理与测试
  20. ios关于农历的一些操作

热门文章

  1. Echarts 柱状图使用
  2. PHP反三角函数,反三角函数求导公式
  3. 对抗神经网络(一)——GAN
  4. win10系统无法删除文件提示找不到该项目解决办法
  5. SSD【目标检测篇】
  6. 文通车牌识别 SDK
  7. QTreeView 和QTreeWidget
  8. php 车牌号限号,机动车限行尾号今天起轮换 周一至周五分别限行 4 和 9、5 和 0、1 和 6、2 和 7、3 和 8...
  9. Springboot封装的好的发送post请求的工具类
  10. Int与byte[]互转详解分析