> 웹 프론트엔드 > HTML 튜토리얼 > HTML+css+js로 별이 빛나는 하늘 회전 및 텍스트 페이드인 효과 구현(코드 첨부)

HTML+css+js로 별이 빛나는 하늘 회전 및 텍스트 페이드인 효과 구현(코드 첨부)

奋力向前
풀어 주다: 2021-07-13 19:04:48
앞으로
3022명이 탐색했습니다.

이 기사에서는 html+css+js를 사용하여 별이 빛나는 하늘이 회전하고 텍스트가 점차 나타나는 효과를 얻는 방법을 코드 예제를 통해 소개합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

HTML+css+js로 별이 빛나는 하늘 회전 및 텍스트 페이드인 효과 구현(코드 첨부)

더 이상 고민하지 않고 바로 코드로 들어가 보겠습니다. 효과는 별이 빛나는 하늘이 회전하고 텍스트가 점차적으로 나타나고 별이 빛나는 하늘의 작은 공이 회전하는 것입니다.

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>星空特效</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        body{
            overflow: hidden;
            background-color: #000;
        }
        h1{
            position: absolute;
            line-height: 50px;
            letter-spacing: 5px;
            color: #fff;
            width: 300px;
            top: 40%;
            left: 50%;
            margin-left: -200px;
            font-size: 30px;
        }
    </style></head><body>
    <h1>
      
    </h1>
    <canvas></canvas>
    <script>
        var canvas=document.querySelector("canvas");
            ctx=canvas.getContext("2d");
            w=canvas.width=window.innerWidth;
            h=canvas.height=window.innerHeight;
            var canvas2=document.createElement("canvas");
                ctx2=canvas2.getContext("2d");
                canvas2.width=100;
                canvas2.height=100;
            var a=canvas2.width/2;
        var grandient=ctx.createRadialGradient(a,a,0,a,a,a);
            grandient.addColorStop(0.025,&#39;#fff&#39;);
            grandient.addColorStop(0.1, &#39;hsl(220,59%,18%)&#39;);
            grandient.addColorStop(0.025, &#39;hsl(220,60%,33%)&#39;);
            grandient.addColorStop(1,"transparent");
            ctx2.fillStyle=grandient;
            ctx2.beginPath();
            ctx2.arc(a,a,a,0,Math.PI*2);
            ctx2.fill();
            ctx2.closePath();
            var stars=[];
            var count=0;
            function Star(){
                this.pos=Math.floor(Math.random()* w/2-100);
                this.r=Math.floor(Math.random()*100);
                this.dx=w/2;
                this.dy=h/2;
                this.rand=Math.floor(Math.random()*360);
                this.speed=this.pos/100000;
                stars[count]=this;
                count ++;
            }
            Star.prototype.draw=function(){
                var x=Math.sin(this.rand+1)* this.pos+this.dx;
                    y=Math.cos(this.rand)*this.pos/2+this.dy;
                ctx.drawImage(canvas2,x-this.r/2,y-this.r/2,this.r,this.r);
                this.rand=this.rand+this.speed;
            }
            for(var i=0;i<1000;i++){
                new Star();
            }
            function anmit(){
                ctx.clearRect(0,0,w,h);
                for(var i=0;i<stars.length;i++){
                    stars[i].draw();
                }
                requestAnimationFrame(anmit);
            }
            anmit();
            var oH=document.getElementsByTagName("h1")[0];
            var arr=["这世间过于俗气","不像你一般","浩瀚星辰,温柔婉转"],
                index=0,
                arrLen=arr.length,
                strLen=arr[0].length;
                pos=0,
                row=0,
                str="",
                timer=null;
            function print() {
                while(row<index){
                    str=str+arr[row]+"<br>";
                    row++;
                }
                oH.innerHTML=str+arr[index].substring(0,pos);
                if(pos==strLen){
                    index++;
                    pos =0;
                    if(index<arr.length){
                        strLen=arr[index].length;
                        timer=setTimeout(print,250);
                    }
                }else{
                    pos++;
                    timer=setTimeout(print,250);
                }
            }
            setTimeout(print,250);
    </script></body></html>
로그인 후 복사

효과 사진:

HTML+css+js로 별이 빛나는 하늘 회전 및 텍스트 페이드인 효과 구현(코드 첨부)

효과 영상 블로거가 b 스테이션으로 보냈습니다: https://www.bilibili.com/video/BV13K4y1e77Y?from=search&seid=9564283641943003056

추천 학습: Html 영상 튜토리얼

위 내용은 HTML+css+js로 별이 빛나는 하늘 회전 및 텍스트 페이드인 효과 구현(코드 첨부)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿