八卦时钟代码

八卦时钟代码<!DOCTYPEhtml><htmllang=”en”><head><metacharset=”UTF-8″><title>www.dupengfei.top</title><style>html{background:#000;color:#666;font-size:12px;…

大家好,又见面了,我是你们的朋友全栈君。

八卦时钟代码

 

<!DOCTYPE html>
<html lang=”en”>
<head>
    <meta charset=”UTF-8″>
    <title>www.dupengfei.top</title>
    <style>
        html{

            background: #000;
            color: #666;
            font-size: 12px;
            overflow:hidden;
        }
        *{

            margin: 0;
            padding: 0;
        }
        span{

            display: block;
            float: left;
        }
        .on{

            color: #fff;
        }
        .wrapper{

            width: 200px;
            height: 200px;
            position: absolute;
            left:50%;
            top:50%;
            margin-top: -100px;
            margin-left: -100px;
        }
        .wrapper .timebox{

            position: absolute;
            width: 200px;
            height: 200px;
            top: 0;
            left:0;
            border-radius: 100%;
            transition: all 0.5s;
        }
        .timebox span{

            transition: all 0.5s;
            float: left;
        }
        .wrapper  .timebox span{

            position: absolute;
            left:50%;
            top:50%;
            width: 40px;
            height: 18px;
            margin-top: -9px;
            margin-left: -20px;
            text-align: right;
        }

    </style>
</head>
<body>

<div id=”wrapper”>
    <div class=”timebox yuebox” id=”yueBox”></div>
    <div class=”timebox riqiBox” id=”riqiBox”></div>
    <div class=”timebox hourbox” id=”hourbox”></div>
    <div class=”timebox minutebox” id=”minutebox”></div>
    <div class=”timebox secondbox” id=”secondbox”></div>
</div>

<script>

    let wrapper = document.getElementById(“wrapper”);
    let yueBox = document.getElementById(“yueBox”);
    let riqiBox = document.getElementById(“riqiBox”);
    let hourbox = document.getElementById(“hourbox”);
    let minutebox = document.getElementById(“minutebox”);
    let secondbox = document.getElementById(“secondbox”);

    /*
    * 找所有的东西标签函数
    * */
    let findSiblings = function( tag ){

        let parent = tag.parentNode;
        let childs = parent.children;
        let sb = [];
        for(let i=0 ; i <= childs.length-1 ; i++){

            if( childs[i]!==tag){

                sb[sb.length] = childs[i];
            }
        }
        return  sb ;
    };

    /*
    * 去掉所有兄弟的类
    * */
    let removeSiblingClass =function( tag ){

        let sb = findSiblings( tag );
        for(let i=0 ;  i <= sb.length-1 ; i++){

            sb[i].className = “”;
        }
    };

    /*
    * 初始化月份函数
    * */
    let initMonth = function(){

        for(let i=1; i<=12; i++){

            let span = document.createElement(“span”);
            span.innerHTML = i+”月”;
            yueBox.appendChild( span );
        }
    };

    // 初始化日期
    let initDate = function(){

        for(let i=1; i<=31; i++){

            let span = document.createElement(“span”);
            span.innerHTML = i+”日”;
            riqiBox.appendChild( span );
        }
    };

    // 初始化小时,分钟,秒
    let initHour = function(){

        for(let i=0; i<=23; i++){

            let h = i ;
            let span = document.createElement(“span”);
            if( h<10){

                h=”0″+h;
            }
            span.innerHTML = h +”点”;
            hourbox.appendChild( span );
        }
    };
    let initMinute = function(){

        for(let i=0; i<=59; i++){

            let  f = i ;
            let span = document.createElement(“span”);
            if( f<10){

                f=”0″+f;
            }
            span.innerHTML = f +”分”;
            minutebox.appendChild( span );
        }
    };
    let initSecond = function(){

        for(let i=0; i<=59; i++){

            let  miao = i ;
            let span = document.createElement(“span”);
            if( miao<10){

                miao=”0″+miao;
            }
            span.innerHTML = miao +”秒”;
            secondbox.appendChild( span );
        }
    };

    // 时间文字样式切换函数
    let changeTime = function(tag){

        tag.className = “on”;
        removeSiblingClass( tag );
    };

    /*
    * 初始化日历函数
    * */
    let initRili = function(){

        initMonth(); // 初始化月份
        initDate(); // 初始化日期
        initHour(); // 小时
        initMinute();
        initSecond();
    };

    /*
    * 展示当前时间
    * 参数:mydate 时间对象
    * */
    let  showNow = function( mydate ){

        let yue = mydate.getMonth() ;
        let riqi = mydate.getDate();
        let hour = mydate.getHours()  ;
        let minute = mydate.getMinutes();
        let second = mydate.getSeconds();
        // 时间文字样式切换函数
        changeTime( yueBox.children[yue] );
        changeTime( riqiBox.children[riqi-1] );
        changeTime( hourbox.children[hour] );
        changeTime( minutebox.children[minute] );
        changeTime( secondbox.children[second] );

    };

    // 展示时间圆圈函数
    // tag:目标
    // num:数字数量
    // dis:圆圈半径
    let textRound = function(tag,num,dis){

        let span = tag.children ;
        for(let i=0 ; i<=span.length-1; i++){

            span[i].style.transform=”rotate(“+ (360/span.length)*i+”deg)  translateX(“+dis+”px)” ;
        }
    };
    /*
    * 旋转指定“圆圈”指定度数
    * */
    let rotateTag = function(tag , deg){

        tag.style.transform = “rotate(“+deg+”deg)”;
    };

    let main = function(){

        initRili(); // 初始化日历

        setInterval(function(){

            let mydate = new Date();
            showNow( mydate ); // 展示当前时间
        },1000);

        //  n秒后,摆出圆形
        setTimeout(function(){

            wrapper.className = “wrapper”;
            textRound(yueBox,12,40);
            textRound(riqiBox,31,80);
            textRound(hourbox,24,120);
            textRound(minutebox,60,160);
            textRound(secondbox,60,200);
            setInterval(function(){

                let mydate = new Date();
                rotateTag( yueBox , -30*mydate.getMonth());
                rotateTag( riqiBox , -360/31*(mydate.getDate()-1) );
                rotateTag( hourbox , -360/24*mydate.getHours());
                rotateTag( minutebox , -6*mydate.getMinutes());
                rotateTag( secondbox , -6*mydate.getSeconds());
            },1000)
        },6000)

    };
    main();

</script>

</body>
</html>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154092.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 文科生也能学会的Excel VBA 宏编程入门

    文科生也能学会的Excel VBA 宏编程入门文章目录VBA宏编程简介准备工作打开宏功能打开“开发工具”选项卡VBA编程示例任务介绍文件宏全局宏VBA宏编程简介VBA编程是Office系列软件自带的编程功能,也就是说不只是Excel,Word和PPT也能进行VBA编程。而“宏”可以理解为一组自动化程序,执行一个宏就能执行其对应的一系列操作。创建宏主要有两种方法,一种是录制宏,也就是将人的一些操作录下来,需要的时候执行宏就可以自动重复这些操…

    2022年6月10日
    39
  • 五种常用手机Java编程软件[通俗易懂]

    五种常用手机Java编程软件[通俗易懂]越来越多的朋友都对编程感兴趣,编程需要工具,所以大家也想知道有哪些好用的java编程工具,接下来系哦啊吧就为大家介绍几款常用的相关编程工具。1.JDKJDK-java开发工具包JDK是Java开发工具包,基本上每个研究java的人都首先在机器上安装JDK,那么他有哪些部件呢?下面是运行java时真正工作的四个文件夹:bin、include、lib、jrebin:是最重要的是编译器包括:java和jvm与头文件lib:类库jre:java运行时环境的交互一般用于java程序的开发,而jre只运行类而不编译

    2022年7月21日
    12
  • 过采样和欠采样_欠采样有几种情况

    过采样和欠采样_欠采样有几种情况一、采样定理只要采样频率高于信号最高频率的两倍,就可以从采样信号中恢复出原始信号。二、过采样和欠采样1、采样频率高于信号最高频率的两倍,这种采样被称为过采样。2、采样频率低于信号最高频率的两倍,这种采样被称为欠采样。三、基带信号和频带信号的采样1、对基带信号进行欠采样是无法从采样信号中恢复出原始信号的,因此基带信号的采样都是过采样。 2、对频带信号进行采样可以是…

    2025年8月24日
    9
  • OpenCV 人脸识别LBPH算法分析

    OpenCV 人脸识别LBPH算法分析一、背景及理论基础人脸识别是指将一个需要识别的人脸和人脸库中的某个人脸对应起来(类似于指纹识别),目的是完成识别功能,该术语需要和人脸检测进行区分,人脸检测是在一张图片中把人脸定位出来,完成的是搜寻的功能。从OpenCV2.4开始,加入了新的类FaceRecognizer,该类用于人脸识别,使用它可以方便地进行相关识别实验。原始的LBP算子定义为在3*3的窗口内,以窗口中心像素为阈值,将相邻的8…

    2022年6月3日
    35
  • java冒泡排序代码_Java冒泡排序

    java冒泡排序代码_Java冒泡排序一、冒泡排序:利用冒泡排序对数组进行排序二、基本概念:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后。在第二趟:仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2…

    2022年7月8日
    14
  • linux查看分区类型(查看文件系统类型 centos)

    1,fdisk-l fdisk-l只能列出硬盘的分区表、容量大小以及分区类型,但看不到文件系统类型。2,df-hdf命令是用来查看文件系统磁盘空间使用量的。但df命令只会列出已挂载的文件系统信息,对于没有挂载的文件系统是查看不到的。使用这个命令可以很方便的查看已挂载的文件系统的空间使用量、剩余空间大小等信息。3,parted

    2022年4月13日
    380

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号