php波浪运算符,canvas波浪效果的实现代码
发布日期:2021-06-24 16:52:35 浏览次数:2 分类:技术文章

本文共 1544 字,大约阅读时间需要 5 分钟。

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

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

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()

转载地址:https://blog.csdn.net/weixin_33960567/article/details/115976478 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:php中页面平滑回到顶部代码,JavaScript简单实现网页回到顶部功能
下一篇:go会取代java吗,7月编程语言排行出炉:Go语言飙升至前十Java暴跌

发表评论

最新留言

表示我来过!
[***.240.166.169]2024年04月07日 23时48分24秒