canvas星空连线背景特效

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>canvas星空连线背景特效</title>
		<style type="text/css">
			body{
				margin: 0;
			}
			#canvas{
				display: block;
				background: #000;
				margin: 0 auto;
			}
		</style>
	</head>
	<body>
		<canvas id="canvas"></canvas>
		<script>
			function Starry(){
				this.cxt=canvas.getContext("2d");
				canvas.width=window.innerWidth;
				canvas.height=window.innerHeight;
				this.cW=canvas.width;
				this.cH=canvas.height;
				this.num=200;
				this.data=[];
			}
			Starry.prototype={
				init: function(){
					for (var i=0;i<this.num;i++) {
						this.data[i]={
							x:Math.random()*this.cW,
							y:Math.random()*this.cH,
							cX:Math.random()*0.6-0.3,
							cY:Math.random()*0.6-0.3
						};
						this.drawCircle(this.data[i].x,this.data[i].y);
					}
					
				},
				drawCircle: function(x,y){
					var cxt=canvas.getContext("2d");
					cxt.save();//保存路径
					cxt.fillStyle="pink";
					cxt.beginPath();//开始路径
					cxt.arc(x,y,1,0,Math.PI*2,false);
					cxt.closePath();//结束路径
					cxt.fill();//填充方法
					cxt.restore();//释放路径
				},
				drawLine: function(x1,y1,x2,y2){
					var cxt=this.cxt;
					var color=cxt.createLinearGradient(x1,y1,x2,y2);
					color.addColorStop(0,"yellow");
					color.addColorStop(1,"green");
					cxt.save();
					cxt.strokeStyle=color;
					cxt.beginPath();//开始路径
					cxt.moveTo(x1,y1);
					cxt.lineTo(x2,y2);
					cxt.closePath();//结束路径
					cxt.stroke();//填充方法
					cxt.restore();//释放路径
					
				},
				moveCircle: function(){
					var self=this;
					self.cxt.clearRect(0,0,self.cW,self.cH);
					for(var i=0;i<self.num;i++){
						self.data[i].x+=self.data[i].cX;
						self.data[i].y+=self.data[i].cY;
						if(self.data[i].x>self.cW||self.data[i].x<0){
							self.data[i].cX=-self.data[i].cX;
						}
						if(self.data[i].x>self.cH||self.data[i].y<0){
							self.data[i].cY=-self.data[i].cY;
						}
						this.drawCircle(self.data[i].x,self.data[i].y);
						for(var j=i+1;j<self.num;j++){
							if(Math.pow(self.data[i].x-self.data[j].x,2)
							+Math.pow(self.data[i].y-self.data[j].y,2)
							<=50*50){
								self.drawLine(self.data[i].x,self.data[i].y,
									self.data[j].x,self.data[j].y);
							}
						}
					}
				}
			}
			var starry=new Starry();
			starry.init();
			setInterval(function(){starry.moveCircle();},1);
		</script>
	</body>
</html>

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Canvas星空特效是一种通过使用HTML5的canvas元素和JavaScript来实现的动态视觉效果。它可以模拟出夜空中闪烁的星星和流动的星云,为网页增添了一种神秘和浪漫的氛围。 要实现星空特效,首先需要借助canvas元素创建一个画布。接下来,通过设置画布的背景颜色为黑色,可以模拟出夜空的效果。然后,在画布上画出多个小圆,代表星星,通过调整星星的位置、大小和颜色,可以创造出星空中繁星闪烁的效果。 为了使星星的闪烁更加自然,可以通过使用JavaScript控制星星的透明度,实现星星的渐隐渐显效果。还可以使用随机数来控制星星的闪烁速度和亮度,使每个星星都有不同的闪烁效果。 除了星星,星空特效还可以添加星云的效果。通过在画布上使用渐变色填充一个大圆,可以模拟出星云的形状。可以调整星云的透明度和颜色,使其与星星相互交织,形成更加丰富的视觉效果。 在实际应用中,我们可以将这种星空特效应用于个人网站的背景,或者是某个特定的网页中,为用户带来更好的视觉体验。除此之外,还可以使用一些其他的特效技巧,如添加动画效果,让星星和星云在画布上流动,使整个星空呈现出更加生动的效果。 总而言之,Canvas星空特效通过使用canvas元素和JavaScript,可以实现一个模拟夜空的动态视觉效果,为网页增添一种神秘和浪漫的氛围。它可以用于个人网站的背景或特定的网页中,为用户带来更好的视觉体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值