canvas原生实现直播视频弹幕效果。
上一篇中用动态创建DOM元素实现弹幕效果,好处是可以在DOM元素上添加事件,但问题是当大量弹幕出现会造成页面卡顿,于是尝试用canvas绘制弹幕效果。
canvas知识
绘制文字
let canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d');
ctx.font = '20px Microsoft YaHei'; //字体、大小
ctx.fillStyle = '#000000'; //字体颜色
ctx.fillText('canvas 绘制文字', 100, 100); //文本,字体x,y坐标
文本宽度
ctx.measureText('文本宽度').width
清除绘制内容
ctx.clearRect(0, 0, width, height);
实现步骤
1、创建canvas元素利用绝对定位覆盖在视频上
2、创建Barrage类,添加的弹幕缓存到弹幕列表中,并记录相应弹幕信