Using JS to implement a rotating Christmas tree in HTML

Using JS to implement a rotating Christmas tree in HTML

<!DOCTYPE HEML PUBLIC>
<html>
    <head>
    <meta charset="utf-8">
    <title>
        From ZXW-NUDT
    </title>
        <style>
            body{text-align:center}
            html, body
            {
                width: 100%;
                height: 100%;
                margin: 0;
                padding: 0;
                border: 0;
            }
            
            div
            {
                margin: 0;
                padding: 0;
                border: 0;
            }

            .nav
            {
                position: absolute;
                top: 0;
                left: 0;
                width: 100%;
                height: 27px;
                background-color: white;
                color: black;
                text-align: center;
                line-height: 25px;
            }

            a
            {
                color: black;
                text-decoration: none;
                border-bottom: 1px dashed black;
            }

            a:hover
            {
                border-bottom: 1px solid red;
            }

            .previous
            {
                float: left;
                margin-left: 10px;
            }

            .next
            {
                float: right;
                margin-right: 10px;
            }

            .green
            {
                color: green;
            }

            .red
            {
                color: red;
            }

            textarea
            {
                width: 100%;
                height: 100%;
                border: 0;                
                padding: 0;                
                margin: 0;                
                padding-bottom: 20px;              
            }

            .block-outer            
            {                
                float: left;                
                width: 22%;                
                height: 100%;                
                padding: 5px;                
                border-left: 1px solid black;                
                margin: 30px 3px 3px 3px;                
            }

            .block-inner            
            {                
                height: 68%;                
            }

            .one
            {                
                border: 0;                
            }
        </style>
    </head>
<body marginwidth="0" marginheight="0">
    <canvas id="c" height="356" width="446">
    <script>
        var collapsed = true;
        function toggle()
        {
            var fs = top.document.getElementsByTagName('frameset')[0];
            var f = fs.getElementsByTagName('frame');
            if (collapsed)
            {
                fs.rows = '250px,*';
                fs.noResize = false;
                f[0].noResize = false;
                f[1].noResize = false;
            }

            else
            {
                fs.rows = '30px,*';
                fs.noResize = true;
                f[0].noResize = true;
                f[1].noResize = true;
            }
            collapsed = !collapsed;
        }
    </script>

    <script>
        var b = document.body;
        var c = document.getElementsByTagName('canvas')[0];
        var a = c.getContext('2d');
        document.body.clientWidth;
    </script>

    <script>
        M=Math;
        Q=M.random;J=[];
        U=16;
        T = M.sin;
        E=M.sqrt;
        for(O=k=0;x=z=j=i=k<200;)
        with(M[k]=k?c.cloneNode(0):c)
        {    
            width=height=k?32:W=446;
            with(getContext('2d'))
            if(k>10|!k)

            for(
            font='60px Impact',
            V='rgba(';I=i*U,fillStyle=k?k==13?V+'205,205,215,.15)':
            V+(147+I)+','+(k%2?128+I:0)+','+I+',.5)':'#cca',i<7;)

            beginPath(fill(arc(Ui/3,24-i/2,k==13?4-(i++)/2:8-i++,0,M.PI*2,1)));

            else for(;
            x=T(i),        
            y=Q()*2-1,        
            D=x*x+y*y,        
            B=E(Dx/.9-1.5*y+1),        
            R=67*(B+1)*(L=k/9+.8)>>1,        
            i++<W;        
            )

            if(D<1)    
            beginPath(strokeStyle=V+R+','+(R+B*L>>0)+',40,.1)'),        
            moveTo(U+x*8,U+y*8),        
            lineTo(U+x*U,U+y*U),        
            stroke();

            for(        
            y=H=k+E(k++)*25,        
            R=Q()*W;        
            P=3,j<H;)    
            J[O++]=[
                x+=T(R)*P+Q()*6-3,y+=Q()*U-8,
                z+=T(R-11)*P+Q()*6-3,
                j/H*20+((j+=U)>H&Q()>.8?Q(P=9)*4:0)>>1]
        }

        setInterval(function G(m,l)
        {    
            A=T(D-11);    
            if(l)

            return(        
            m[2]-l[2])*A+(l[0]-m[0])*T(D);        
            a.clearRect(0,0,W,W);        
            J.sort(G);

            for(
            i=0;
            L=J[i++];
            a.drawImage(M[L[3]+1],207+L[0]*A+L[2]*T(D)>>0,L[1]>>1))    
            {
                if(i==2e3)
                a.fillText
                ('Happy Christmas!',U,345);

                if(!(i%7))        
                a.drawImage(M[13],
                ((157*(i*i)+T(D*5+i*i)*5)%W)>>0,
                ((113*i+(D*i)/60)%(290+i/99))>>0);
            }    
            D+=.02
        },1)
    </script>
</body>
</html>

Regarding adding background music, assume that this HTML file has a folder named music, and there is an audio file music.mp3 in the folder. Then the code should be:

<audio src="music/music.mp3" autoplay="autoplay" loop="loop"></audio>
  • src is the address
  • Autoplay default playback
  • loopDefault loop

Changing the background should be (I haven't tried it anyway):

<div class="image"><img src="images.jpg" alt="" /></div><div class="content">

This concludes this article about implementing a rotating Christmas tree in HTML using JS. I hope it will be helpful for everyone’s study, and I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Detailed explanation of dynamic Christmas tree through JavaScript
  • Implementing Christmas tree code based on JS2Image
  • JavaScript flashing Christmas tree implementation code

<<:  CSS implements various loading effects with parsing process

>>:  Summary of MySQL's commonly used database and table sharding solutions

Recommend

MySQL character set viewing and modification tutorial

1. Check the character set 1. Check the MYSQL dat...

Example of using mycat to implement MySQL database read-write separation

What is MyCAT A completely open source large data...

Centos7 installation of Nginx integrated Lua sample code

Preface The computer I use is a Mac, and the oper...

In-depth explanation of the locking mechanism in MySQL InnoDB

Written in front A database is essentially a shar...

About dynamically adding routes based on user permissions in Vue

Display different menu pages according to the use...

Sample code for automatic web page refresh and automatic jump

Automatic web page refresh: Add the following code...

Solution to the failure of loading dynamic library when Linux program is running

Unable to load dynamic library under Linux When t...

Solution to MySQLSyntaxErrorException when connecting to MySQL using bitronix

Solution to MySQLSyntaxErrorException when connec...

Three ways to prevent MySQL from inserting duplicate data

Create a new table CREATE TABLE `person` ( `id` i...

Parsing Apache Avro Data in One Article

Abstract: This article will demonstrate how to se...

How to use the yum command

1. Introduction to yum Yum (full name Yellow dogU...

Graphical explanation of the solutions for front-end processing of small icons

Preface Before starting this article, let’s do a ...

Summary of MySQL log related knowledge

Table of contents SQL execution order bin log Wha...