js+css实现骰子的随机转动

网上找的例子,然后增添了新的东西,在这里展示一下......

效果图预览:

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>js+css3实现3D骰子特效 - 站长素材</title>
<style>
* { margin:0; padding:0; }body { background:#efefef; overflow:hidden; }h1 { text-align:center; margin-top:40px; text-shadow:1px 1px 3px #000; font-size:40px; color:#fff;}#shadow {height:300px; width:600px; position:absolute; top:400px; left:0; z-index:0;background:-webkit-radial-gradient(center center , 150px 50px, #cfcfcf, #efefef );background:-moz-radial-gradient(center center , 150px 50px, #cfcfcf, #efefef );background:-ms-radial-gradient(center center , 150px 50px, #cfcfcf, #efefef );background:-o-radial-gradient(center center , 150px 50px, #cfcfcf, #efefef );background:radial-gradient(center center , 150px 50px, #cfcfcf, #efefef );-webkit-transform:perspective(100px) rotateX(60deg) rotateY(0deg);-moz-transform:perspective(100px) rotateX(60deg) rotateY(0deg);-ms-transform:perspective(100px) rotateX(60deg) rotateY(0deg);-o-transform:perspective(100px) rotateX(60deg) rotateY(0deg);transform:perspective(100px) rotateX(60deg) rotateY(0deg);opacity:0;
}#container {/*background:black;*/height:240px; width:240px; position:absolute; top:180px; z-index:1;-webkit-transform-style:preserve-3d;-moz-transform-style:preserve-3d;-ms-transform-style:preserve-3d;-o-transform-style:preserve-3d;transform-style:preserve-3d;-webkit-transform:perspective(2000px) rotateX(-10deg) rotateY(45deg) ;-moz-transform:perspective(2000px) rotateX(-10deg) rotateY(45deg) ;-ms-transform:perspective(2000px) rotateX(-10deg) rotateY(45deg) ;-o-transform:perspective(2000px) rotateX(-10deg) rotateY(45deg) ;transform:perspective(2000px) rotateX(-10deg) rotateY(45deg) ;
}
#container p {position:absolute;top:40%;left:35%;padding:5px;word-spacing:0.2em;line-height:20px;background:black;color:#fff;text-align:center;
}
#container div { height:240px; width:240px; position:absolute; left:0; top:0; color:#fff; line-height:240px; text-align:center; font-weight:bold; font-size:80px; cursor:pointer; background:rgba( 239,239,239, 1 );-webkit-transition:500ms all ease;-moz-transition:500ms all ease;-ms-transition:500ms all ease;-o-transition:500ms all ease;transition:500ms all ease;
}
#container div div {border:1px solid #fff; /* rgba( 255,255,255, 1 ) */box-shadow:1px 0 3px #fff,1px 0px 10px #efefef;border-radius:8px;background:-webkit-radial-gradient(center, #d81002, #b20c00 );background:-moz-radial-gradient(center, #d81002, #b20c00 );background:-ms-radial-gradient(center, #d81002, #b20c00 );background:-o-radial-gradient(center, #d81002, #b20c00 );background:radial-gradient(center, #d81002, #b20c00 );
}
#container div div:hover {background:-webkit-radial-gradient(center, #f00, #b20c00 );background:-moz-radial-gradient(center, #f00, #b20c00 );background:-ms-radial-gradient(center, #f00, #b20c00 );background:-o-radial-gradient(center, #f00, #b20c00 );background:radial-gradient(center, #f00, #b20c00 );
}
#container div ul {list-style:none;margin:30px;
}
#container div li {width: 60px;height:60px;float:left;overflow:hidden;-webkit-transition:500ms all ease;-moz-transition:500ms all ease;-ms-transition:500ms all ease;-o-transition:500ms all ease;transition:500ms all ease;
}#container div li span  { width:50px; height:50px; margin:5px auto;display:block;background:-webkit-linear-gradient(top, #eee, #fff );background:-moz-linear-gradient(top, #eee, #fff );background:-ms-linear-gradient(top, #eee, #fff );background:-o-linear-gradient(top, #eee, #fff );background:linear-gradient(top, #eee, #fff );border-radius:25px;box-shadow:-1px -1px 2px #000;
}
</style>
<script src="Aui-core-1.42-min.js" language="javascript" type="text/javascript"></script>
<script language="javascript" type="text/javascript">
Aui.ready( function()
{if( /ie/g.test( Aui.browser() ) ){Aui("body").html("Adam CSS 3.0 effect,支持非IE浏览器。你懂的!").setStyle({"color" : "#000","text-align" : "center","font-size" : "50px","font-weight" : "bolder","line-height" : "500px"});}else{var oDoc = Aui(document),docWidth = oDoc.width();Aui("body").html("<div id=\"hujunzheng\"></h1><div id=\"container\" style=\"left:"+ ( ( docWidth - 240 )*0.5 ) +"px;\"></div><strong id=\"shadow\" style=\"left:"+ ( ( docWidth - 600 )*0.5 ) +"px;\"></strong></div>");var oContainer = Aui.byID("#container")[0],AuiCon = Aui( oContainer ),AuiShadow = Aui("#shadow"),transform = function( elem, value, key ){key = key || "transform";[ "-webkit-", "-moz-", "-ms-", "-o-", "" ].forEach( function( pre ){elem.style[ pre + key ] = value;});    return elem;},piece = function( value, key ){var str = "";key = key || "transform";[ "-webkit-", "-moz-", "-ms-", "-o-",  "" ].forEach( function( pre ){str += ( pre + key + ":" + value );return false;});    return str;},startMove = function startMove( obj ){obj.timer = obj.timer || null;clearInterval( obj.timer );obj.timer = setInterval (function (){x -= speedY;y += speedX;speedY *= 0.95;speedX *= 0.95;if( Math.abs( speedX ) < 0.1 && Math.abs( speedY ) < 0.1 ){stopMove( obj.timer );};transform( obj, "perspective(" + pers + "px) rotateX("+ x +"deg) rotateY(" + y +"deg)" );}, 30);},stopMove = function( t ){clearInterval( t );},addEvent = function ( obj, sEvent, fn ){if( obj.attachEvent ){obj.attachEvent( "on" + sEvent, fn );}else{obj.addEventListener( sEvent, fn, false );};},onMouseWheel = function( e ){if( e.wheelDelta ? e.wheelDelta < 0 : e.detail > 0 ){if( pers < 2000 ){pers += 50;_top -= 0.5;};}else{if( pers > 50 ){pers -= 50;_top += 0.5;};};AuiShadow.setStyle( "top", _top );transform( oContainer, "perspective(" + pers + "px) rotateX("+ x +"deg) rotateY(" + y +"deg)" );if( e.preventDefault ){e.preventDefault();};return false;},setNum = function( obj, n ){var arr = [[ 4 ],[ 0, 8 ],[ 0, 4, 8 ],[ 0, 2, 6, 8 ],[ 0, 2, 4, 6, 8 ],[ 0, 2, 3, 5, 6, 8]];Aui.each( arr[n], function( i , v ){obj.find("li").eq( v ).html("<span></span>");});}; x = -10,y = 45,speedX = 0,speedY = 0,i = 1,d_x = 0,d_y = 0,d_z = 519,pers = 2000,_top = 400;while( i < 7 ){if( i < 5 ){d_x = 0;d_y = i * 90;}else if( i === 5 ){d_x = 90;d_y = 0;}else {d_x = -90;d_y = 0;};AuiCon.append( "<div id=\"box-"+ i +"\" style=\""+ piece("rotateX(" + d_x + "deg) rotateY(" + d_y + "deg) translateZ(" + d_z + "px) scaleX( 0.4 ) scaleY( 0.4 );") +"opacity:0;\"><div><ul><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li></ul></div></div>" );i += 1;};var oDiv = AuiCon.children("div");Aui.each( oDiv, function( i ){( function( d , obj ){setTimeout( function(){obj.style.opacity = 1;setTimeout( function(){setNum( Aui( obj ), d );if( d < 4 ){transform( obj, "rotateX(0deg) rotateY(" + ( i * 90 )+"deg) translateZ(180px) scaleX( 1 ) scaleY( 1 )" );}else if( d === 5 ){transform( obj, "rotateX(90deg) rotateY(0deg) translateZ(180px) scaleX( 1 ) scaleY( 1 )" );setTimeout( function(){AuiShadow.fx({ opacity : 1 }, 400 );Aui.each( oDiv, function( x ){if(  x < 4 ){transform( this, "rotateX(0deg) rotateY(" + ( x * 90 )+"deg) translateZ(72px) scaleX( 0.6 ) scaleY( 0.6 )" );}else if( x === 5 ){transform( this, "rotateX(90deg) rotateY(0deg) translateZ(72px) scaleX( 0.6 ) scaleY( 0.6 )" );}else if( x === 4){transform( this, "rotateX(-90deg) rotateY(0deg) translateZ(72px) scaleX( 0.6 ) scaleY( 0.6 )" );};});}, 400 );}else if( d === 4){transform( obj, "rotateX(-90deg) rotateY(0deg) translateZ(180px) scaleX( 1 ) scaleY( 1 )" );};} , 100 );} , d * 200 );})( i, this );});oDoc.mousedown( function( e ){var moveX = e.clientX,moveY = e.clientY;var startX = x;var startY = y;var lastX = moveX;var lastY = moveY;speedX = speedY = 0;oDoc.mousemove( function( e ){y = startY + ( e.clientX - moveX )/5;x = startX - ( e.clientY - moveY )/5;
                    transform( oContainer, "perspective(" + pers + "px) rotateX("+ Math.ceil( x ) +"deg) rotateY(" + Math.ceil( y ) +"deg)" );speedX = Math.ceil( ( e.clientX - lastX )/2 );
                speedY = Math.ceil( ( e.clientY - lastY )/2 );
                lastX = e.clientX;lastY = e.clientY;});oDoc.mouseup( function(){this.onmousemove = null;this.onmouseup = null;startMove( oContainer );});stopMove( oContainer.timer );return false;});var wheel = function( e ){onMouseWheel.call( null, e || window.event );};addEvent( oDoc[0], "mousewheel", wheel );addEvent( oDoc[0], "DOMMouseScroll", wheel );};/*加入之后使得在骰子生成之后开始转动
     2s之后执行 每隔100ms执行函数(模拟鼠标的移动位置)
*/window.setTimeout(function(){var cntcc = 0;var hjzgg;var clientX = Math.ceil(Math.random()*500);var clientY = Math.ceil(Math.random()*500);var moveX = clientX,moveY = clientY;var startX = x;var startY = y;var lastX = moveX;var lastY = moveY;speedX = speedY = 0;hjzgg=window.setInterval(function(){++cntcc;y = startY + ( clientX - moveX )/5;x = startX - ( clientY - moveY )/5;if(cntcc==50){ window.clearInterval(hjzgg);}transform( oContainer, "perspective(" + pers + "px) rotateX("+ Math.ceil( x ) +"deg) rotateY(" + Math.ceil( y ) +"deg)" );speedX = Math.ceil( ( clientX - lastX )/2 ); speedY = Math.ceil( ( clientY - lastY )/2 );lastX = clientX;lastY = clientY;clientX = Math.ceil(Math.random()*500);clientY = Math.ceil(Math.random()*500);}, 100); },2000); /*********************************************************/ }); </script> </head><body></body> </html>

 

项目下载地址:

http://files.cnblogs.com/files/hujunzheng/%E8%BD%AC%E5%8A%A8%E7%9A%84%E9%AA%B0%E5%AD%90.zip

转载于:https://www.cnblogs.com/hujunzheng/p/4780940.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/531431.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux安装交叉编译环境

&#xff08;一&#xff09;交叉编译器的简介 &#xff08;1&#xff09;本地编译 在了解交叉编译之前我们首先介绍一下另一个概念&#xff1a;本地编译 之前所做的C开发属于本地编译&#xff0c;即在当前PC下&#xff08;x86的CPU下&#xff09;&#xff0c;直接编译出可以运…

jsp实现邮件的发送

如果程序出现 454 Authentication failed, please open smtp flag first! 错误&#xff0c;那么一般是邮箱没有开通POP3/SMTP服务&#xff0c;登录邮箱&#xff0c;在设置中开启该服务即可 &#xff01; 另外需要的jar包如下: imap.jar, mail.jar, smtp.jar, 可以自己在网上下…

linux的mount和umount指令使用

mount即挂在操作&#xff0c;磁盘或分区创建好文件系统后需要挂载到一个目录&#xff08;一般mount在/mnt下&#xff09;才能使 用&#xff0c;和winsdows不同的是在linux下需要手动挂载。 用法&#xff1a;mount [-t文件系统] [选项] 设备目录注意&#xff1a;[ ]为可选项…

斐波那契的四种求法

首先看一下斐波那契的矩阵表示&#xff1a; 数列的递推公式为&#xff1a;f(1)1&#xff0c;f(2)2&#xff0c;f(n)f(n-1)f(n-2)(n>3) 用矩阵表示为&#xff1a; 进一步&#xff0c;可以得出直接推导公式&#xff1a; #include<iostream> #include<cstring> #i…

利用STM32制作红外测温仪之软件设计(MLX90614)

目录&#xff08;一&#xff09;工程目录如图&#xff1a;&#xff08;二&#xff09;main函数实现&#xff1a;&#xff08;三&#xff09;MLX90614测温代码实现前面介绍了使用 STM32制作红外测温仪硬件设计,今天来说一下软件的实现&#xff0c;具体的程序&#xff0c;完整的k…

Windows下使用Dev-C++开发基于pthread.h的多线程程序

一、下载Windows版本的pthread 目前最新版本是&#xff1a;pthreads-w32-2-9-1-release.zip。 二、解压pthread到指定目录 我选择的目录是&#xff1a;E:\DEV-CPP\Pthread完成后&#xff0c;该目录会多出三个文件夹&#xff1a;Pre-built.2&#xff0c;pthreads.2&#xff0c;Q…

(三)linux之根文件系统的制作

&#xff08;一&#xff09;准备工作 Ubuntu 16.04系统linux-3.5内核:linux-3.5-20190929交叉编译工具arm-linux-gcc-4.5.1-v6-vfp-20120301.rarbusybox源码包&#xff1a;busybox-1.21.1.rar &#xff08;二&#xff09;工具介绍 &#xff08;1&#xff09;交叉编译器 这个…

c/c++多线程模拟系统资源分配(并通过银行家算法避免死锁产生)

银行家算法数据结构 &#xff08;1&#xff09;可利用资源向量Available 是个含有m个元素的数组&#xff0c;其中的每一个元素代表一类可利用的资源数目。如果Available[j]K&#xff0c;则表示系统中现有Rj类资源K个。 &#xff08;2&#xff09;最大需求矩阵Max 这是一个nm的…

(四)Linux内核模块化编程

目录&#xff08;一&#xff09;模块化编程简介&#xff08;二&#xff09;安装卸载模块命令.&#xff08;三&#xff09;将自定义功能添加到内核三种方法&#xff08;1&#xff09;修改Kconfig和Makefile&#xff08;2&#xff09;直接修改功能对应目录下的Makefile文件&#…

基于X86平台的PC机通过网络发送一个int(32位)整数的字节顺序

1.字节顺序  字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序&#xff0c;通常有小端、大端两种字节顺序。小端字节序指低字节数据存放在内存低地址处&#xff0c;高字节数据存放在内存高地址处&#xff1b;大端字节序是高字节数据存放在低地址处&#xff0c;低字…

Linux内核空间和用户空间

在Linux系统中存在进程的概念&#xff1a; 进程的分类&#xff1a; 用户进程&#xff1a;运行在用户空间的进程被称为用户进程 内核进程:运行在内核空间的进程被称为内核进程 进程的空间&#xff1a; 系统会为每一个进程分0-4G的虚拟寻址空间&#xff0c;在4G的空间中 0-3G&…

codeforces Round #320 (Div. 2) C. A Problem about Polyline(数学) D. Or Game(暴力,数学)

解题思路&#xff1a;就是求数 n 对应的二进制数中有多少个 1 #include <iostream> #include<cstdio> using namespace std; int main(){int n;cin>>n;int ans 0; // while(n){//这也是一种好的方法 // n n&(n-1); // ans; // }while(n…

(五)Linux之设备驱动模型

目录&#xff08;一&#xff09;Linux内核驱动简介&#xff08;二&#xff09;杂项设备驱动模型&#xff08;1&#xff09;相关接口&#xff08;2&#xff09;杂项设备注册过程&#xff08;三&#xff09;早期经典字符设备驱动模型&#xff08;1&#xff09;相关接口&#xff0…

操作系统页面置换算法(opt,lru,fifo,clock)实现

选择调出页面的算法就称为页面置换算法。好的页面置换算法应有较低的页面更换频率&#xff0c;也就是说&#xff0c;应将以后不会再访问或者以后较长时间内不会再访问的页面先调出。 常见的置换算法有以下四种&#xff08;以下来自操作系统课本&#xff09;。 1. 最佳置换算法(…

(六)Linux之设备驱动模型(续)

前面我们学习了杂项设备驱动模型、早期经典字符设备驱动模型,这一小节来讲解Linux中的标准字符设备驱动。 目录&#xff08;一&#xff09;为什么引入标准字符设备驱动模型&#xff08;二&#xff09;相关接口&#xff08;三&#xff09;注册流程&#xff08;四&#xff09;程序…

N个数依次入栈,出栈顺序有多少种?

对于每一个数来说&#xff0c;必须进栈一次、出栈一次。我们把进栈设为状态‘1’&#xff0c;出栈设为状态‘0’。n个数的所有状态对应n个1和n个0组成的2n位二进制数。由于等待入栈的操作数按照1‥n的顺序排列、入栈的操作数b大于等于出栈的操作数a(a≤b)&#xff0c;因此输出序…

(七)linux函数接口的使用

前面我们讲解了字符设备的驱动模型&#xff0c;有了前面的基础后&#xff0c;今天学习函数接口就比较容易了 目录&#xff08;一&#xff09;open函数接口&#xff08;二&#xff09;read函数接口&#xff08;三&#xff09;lseek函数接口&#xff08;四&#xff09;用户空间和…

(八)linux驱动之ioctl的使用

这篇文章给大家讲解一下ioctl的简单使用&#xff0c;关于ioctl更详细的教程后面有机会单独写出来 &#xff08;一&#xff09;什么是ioctl ioctl是设备驱动程序中对设备的I/O通道进行管理的函数。所谓对I/O通道进行管理&#xff0c;就是对设备的一些特性进行控制&#xff0c;例…

(九)linux中断编程

目录&#xff08;一&#xff09;linux中断的介绍&#xff08;二&#xff09;内核中断的操作过程&#xff08;三&#xff09;实例代码&#xff08;一&#xff09;linux中断的介绍 linux内核中的中断通过中断子系统来管理。linux系统中有专门的中断子系统&#xff0c;原理很复杂…

网络爬虫(1)

参考&#xff1a;http://www.cnblogs.com/dongkuo/p/4851735.html算法分析我们现在从需求中提取关键词来逐步分析问题。 首先是“种子节点”。它就是一个或多个在爬虫程序运行前手动给出的URL&#xff08;网址&#xff09;&#xff0c;爬虫正是下载并解析这些种子URL指向的页面…