canvas波浪效果的实现代码

广告:宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取~~~

canvas波浪效果的实现代码

本篇文章给大家带来的内容是关于canvas波浪效果的实现代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

基于canvas的三次贝塞尔曲线(bezierCurveTo)

<canvas id="myCanvas"></canvas><script>    var WAVE_HEIGHT = 200 //波浪变化高度    var SCALE = 0.5 // 绘制速率    var CYCLE = 360 / SCALE    var TIME = 0    function initCanvas() {        var c = document.getElementById("myCanvas")        var width = window.screen.width        var height = window.screen.height        var ctx = c.getContext("2d")        c.width = width        c.height = height        // start        window.requestAnimationFrame(function() {            draw(ctx, width, height)        })    }    function draw(ctx, width, height) {        ctx.clearRect(0, 0, width, height)        TIME = (TIME + 1) % CYCLE        var angle = SCALE * TIME // 当前正弦角度        var dAngle = 60 // 两个波峰相差的角度        ctx.beginPath()        ctx.moveTo(0, height * 0.5 + distance(WAVE_HEIGHT, angle, 0))        ctx.bezierCurveTo(            width * 0.4,            height * 0.5 + distance(WAVE_HEIGHT, angle, dAngle),            width * 0.6,            height * 0.5 + distance(WAVE_HEIGHT, angle, 2 * dAngle),            width,            height * 0.5 + distance(WAVE_HEIGHT, angle, 3 * dAngle)        )        ctx.strokeStyle = "#ff0000"        ctx.stroke()        ctx.beginPath()        ctx.moveTo(0, height * 0.5 + distance(WAVE_HEIGHT, angle, -30))        ctx.bezierCurveTo(            width * 0.3,            height * 0.5 + distance(WAVE_HEIGHT, angle, dAngle - 30),            width * 0.7,            height * 0.5 + distance(WAVE_HEIGHT, angle, 2 * dAngle - 30),            width,            height * 0.5 + distance(WAVE_HEIGHT, angle, 3 * dAngle - 30)        )        ctx.strokeStyle = "#0000ff"        ctx.stroke()        function distance(height, currAngle, diffAngle) {            return height * Math.cos((((currAngle - diffAngle) % 360) * Math.PI) / 180)        }        // animate        window.requestAnimationFrame(function() {            draw(ctx, width, height)        })    }    initCanvas()</script>
登录后复制

以上就是canvas波浪效果的实现代码的详细内容,更多请关注9543建站博客其它相关文章!

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:css文本超出排在下一行怎么调整行间距
下一篇:哪个标签是定义标题的

发表评论

关闭广告
关闭广告