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>
时间: 2024-08-01 00:18:31

js+css实现骰子的随机转动的相关文章

JS实现页面载入时随机显示图片效果_javascript技巧

本文实例讲述了JS实现页面载入时随机显示图片效果.分享给大家供大家参考,具体如下: <html> <head> <title>JS 随机图片效果</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <style type="text/css"> <!-- img { b

JS+CSS实现自动改变切换方向图片幻灯切换效果的方法

 这篇文章主要介绍了JS+CSS实现自动改变切换方向图片幻灯切换效果的方法,实例分析了javascript操作图片切换方向的幻灯片技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了JS+CSS实现自动改变切换方向图片幻灯切换效果的方法.分享给大家供大家参考.具体实现方法如下:   代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o

JS+CSS实现实用的单击输入框弹出选择框的方法

 这篇文章主要介绍了JS+CSS实现实用的单击输入框弹出选择框的方法,实例分析了javascript操作select及button的操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了JS+CSS实现实用的单击输入框弹出选择框的方法.分享给大家供大家参考.具体实现方法如下:   代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o

apache tomcat:apache + tomcat +js + css 实现分离跨域

一个java站点,使用tomcat服务器,那么需要把站点的css .images.js都需要分离.用不同的域名的话,会碰到跨域的情况.为此,使用apache的代理来实现分离工作css .images.js资源全部放到src.test.com/css/--src.test.com/images/--src.test.com/js/--java 站点tomcat 服务器访问方式ajp://127.0.0.1:8009/ 其实是http://127.0.0.1:8080/apache httpd.co

如何过滤html,js,css代码

以下是引用片段:以下为引用的内容:  #region/// 过滤html,js,css代码         /// <summary>         /// 过滤html,js,css代码         /// </summary>         /// <param name="html">参数传入</param>         /// <returns></returns>         public

把Node.js程序加入服务实现随机启动

  这篇文章主要介绍了把Node.js程序加入服务实现随机启动,本文使用qckwinsvc实现这个需求,讲解了qckwinsvc的安装和使用,需要的朋友可以参考下 如何开机就启动node.js程序 代码如下: npm install -g qckwinsvc 定位到安装目录,node_modules/.bin/ 运行如下命令: 代码如下: > qckwinsvc prompt: Service name: [name for your service] prompt: Service descr

JS+CSS实现仿触屏手机拨号盘界面及功能模拟完整实例

  本文实例讲述了JS+CSS实现仿触屏手机拨号盘界面及功能模拟的方法.分享给大家供大家参考.具体如下: 首先来看一下运行效果图: 具体实现代码如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 6

JS+CSS实现的拖动分页效果实例

  本文实例讲述了JS+CSS实现拖动分页效果的方法.分享给大家供大家参考.具体实现方法如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70

js+css 实现遮罩居中弹出层

 本文为大家详细介绍下使用js实现遮罩弹出层居中,且随浏览器窗口滚动条滚动,示例代码如下,感兴趣的朋友可以参考下 js+css 实现遮罩居中弹出层(随浏览器窗口滚动条滚动)   代码如下: <!doctype html>  <head>  <meta charset="utf-8" />  <title></title>  <style type="text/css">  *{}{margin: