Canvas绘制雪花飘落效果的思路及方法是什么
Admin 2022-06-28 群英技术资讯 474 次浏览
今天我们就使用canvas来实现雪花飘落的效果️
HTML5 <canvas> 元素用于图形的绘制,通过脚本 (通常是JavaScript)来完成.
<canvas> 标签只是图形容器,您必须使用脚本来绘制图形。
你可以通过多种方法使用 canvas 绘制路径,盒、圆、字符以及添加图像。
1.创建一个画布(Canvas)
<canvas id="myCanvas" width="200" height="100"></canvas>
2.使用JavaScript绘制图像
//首先找到<canvas>元素 var c=document.getElementById("myCanvas"); //然后创建context对象 var ctx=c.getContext("2d"); //下面的两行代码绘制一个红色的矩形: ctx.fillStyle="#FF0000"; ctx.fillRect(0,0,150,75);
getContext("2d") 对象是内建的 HTML5 对象,拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。
设置fillStyle属性可以是CSS颜色,渐变,或图案。fillStyle 默认设置是#000000。
3.Canvas 坐标
canvas 是一个二维网格。
canvas 的左上角坐标为 (0,0)
ctx.fillRect(0,0,150,75);
上面的 fillRect 方法拥有参数 (0,0,150,75)。
意思是:在画布上绘制 150x75 的矩形,从左上角开始 (0,0)。
4.Canvas - 路径
moveTo(x,y) 定义线条开始坐标
lineTo(x,y) 定义线条结束坐标
在canvas中绘制圆形, 我们将使用以下方法:
arc(x,y,r,start,stop)
使用arc() 画一个圆
var c=document.getElementById("myCanvas"); var ctx=c.getContext("2d"); ctx.beginPath(); ctx.arc(95,50,40,0,2*Math.PI); ctx.stroke();
1.创建一个画布(Canvas)
var canvas =document.getElementById("canvas") //参数 contextID 指定了您想要在画布上绘制的类型。 //当前唯一的合法值是 "2d",它指定了二维绘图, //并且导致这个方法返回一个环境对象,该对象导出一个二维绘图 API。 var context = canvas.getContext("2d") var w =window.innerWidth var h =window.innerHeight canvas.width = w; canvas.height =h;
2.创建雪花的对象数组
var count =200 //雪花的个数 var snows=[] //雪花对象数组 for (var i=0 ; i< count;i++){ snows.push({ x:Math.random()*w,//Math.random()用于生成0~1的随机数 y:Math.random()*h, r:Math.random()*5, }) }
3.绘制雪花样式
function draw(){ context.clearRect(0,0,w,h) context.beginPath() for(var i=0; i<count;i++){ var snow = snows[i];//遍历每一片雪花 context.fillStyle ="rgb(255,255,255)" //设置雪花的样式 context.shadowBlur=10; context.shadowColor="rgb(255,255,255)"; //moveTo 的方法是可以移动到指定的坐标 context.moveTo(snow.x,snow.y) // 使用canvas arc()创建一个圆形 //x,y,r:圆的中心的x坐标和y坐标,r为半径 //0,Math.PI * 2起始弧度和结束弧度 context.arc(snow.x,snow.y,snow.r,0,Math.PI * 2) } //画布填充 context.fill() move() }
4.实现雪花飘动
function move(){ for (var i=0;i<count;i++){ var snow =snows[i]; snow.y +=(7-snow.r)/10 //从上往下飘落 snow.x+=((5-snow.r)/10)//从左到右飘落 if(snow.y>h){ snows[i]={ x:Math.random()*w, y:Math.random()*h, r:Math.random()*5, } } } }
5.设置刷新
draw() //每毫秒刷新一次 setInterval(draw,1)
6.完整代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>雪花飘飘之使用canvas元素用于在网页上绘制图形。</title> <style type="text/css"> *{ margin:0; padding:0; /* background-color: seagreen; */ background: url("雪人.jpg") no-repeat; background-size:100% 100%; } /* .can{ filter: blur(1px); } */ </style> </head> <body> <canvas id="canvas" class="can"></canvas> <script type="text/javascript"> //canvas 元素用于在网页上绘制图形。 var canvas =document.getElementById("canvas") //参数 contextID 指定了您想要在画布上绘制的类型。 //当前唯一的合法值是 "2d",它指定了二维绘图, //并且导致这个方法返回一个环境对象,该对象导出一个二维绘图 API。 var context = canvas.getContext("2d") var w =window.innerWidth var h =window.innerHeight canvas.width = w; canvas.height =h; var count =200 //雪花的个数 var snows=[] //雪花对象数组 for (var i=0 ; i< count;i++){ snows.push({ x:Math.random()*w,//Math.random()用于生成0~1的随机数 y:Math.random()*h, r:Math.random()*5, }) } //绘制雪花 function draw(){ context.clearRect(0,0,w,h) context.beginPath() for(var i=0; i<count;i++){ var snow = snows[i];//遍历每一片雪花 context.fillStyle ="rgb(255,255,255)" //设置雪花的样式 context.shadowBlur=10; context.shadowColor="rgb(255,255,255)"; //moveTo 的方法是可以移动到指定的坐标 context.moveTo(snow.x,snow.y) // 使用canvas arc()创建一个圆形 //x,y,r:圆的中心的x坐标和y坐标,r为半径 //0,Math.PI * 2起始弧度和结束弧度 context.arc(snow.x,snow.y,snow.r,0,Math.PI * 2) } //画布填充 context.fill() move() } //雪花飘动 function move(){ for (var i=0;i<count;i++){ var snow =snows[i]; snow.y +=(7-snow.r)/10 //从上往下飘落 snow.x+=((5-snow.r)/10)//从左到右飘落 if(snow.y>h){ snows[i]={ x:Math.random()*w, y:Math.random()*h, r:Math.random()*5, } } } } draw() //每毫秒刷新一次 setInterval(draw,1) </script> </body> </html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在css中,可以利用“@keyframes”规则和animation属性来实现左右运动效果。代码示例:<!DOCTYPE html><html><head><meta charset="utf-8"> <style> div{
在css中,可以利用“z-index”属性让元素的层级最高,该属性的作用就是设置元素的堆叠顺序,拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面,也就是元素的层级最高,语法为“元素{z-index:number;}”。
今天给大家分享的是关于用CSS实现简单的波浪效果的内容,如果是纯 CSS 实现波浪效果还是比较困难的,而本文使用 CSS 实现的波浪效果的思路非常有意思,下文有有实例和详细注释供大家参考,感兴趣的朋友接下来跟随小编一起看看吧。
用CSS怎样制作矩形边角加粗效果呢?有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
css渐进增强的理解:1、为低版本浏览器构建页面,保证最基本的功能,然后对高级浏览器进行效果、交互等改进,增加功能。2、渐进增强认为应该关注内容本身。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008