canvas实现探照灯效果
发布时间 - 2026-01-10 22:54:34 点击率:次canvas中的clip()方法用于从原始画布中剪切任意形状和尺寸。一旦剪切了某个区域,则所有之后的绘图都会被限制在被剪切的区域内(不能访问画布上的其他区域)

也可以在使用clip()方法前通过使用save()方法对当前画布区域进行保存,并在以后的任意时间通过restore()方法对其进行恢复
接下来使用clip()方法实现一个探照灯效果
<button id="btn">变换</button>
<button id="con">暂停</button>
<canvas id="canvas" width="400" height="290" style="border:1px solid black">当前浏览器不支持canvas,请更换浏览器后再试</canvas>
<script>
btn.onclick = function(){history.go();}
con.onclick = function(){
if(this.innerHTML == '暂停'){
this.innerHTML = '恢复';
clearInterval(oTimer);
}else{
this.innerHTML = '暂停';
oTimer = setInterval(fnInterval,50);
}
}
var canvas = document.getElementById('canvas');
//存储画布宽高
var H=290,W=400;
//存储探照灯
var ball = {};
//存储照片
var IMG;
//存储照片地址
var URL = 'http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/chunfen.jpg';
function initial(){
if(canvas.getContext){
var cxt = canvas.getContext('2d');
var tempR = Math.floor(Math.random()*30+20);
var tempX = Math.floor(Math.random()*(W-tempR) + tempR);
var tempY = Math.floor(Math.random()*(H-tempR) + tempR)
ball = {
x:tempX,
y:tempY,
r:tempR,
stepX:Math.floor(Math.random() * 21 -10),
stepY:Math.floor(Math.random() * 21 -10)
};
IMG = document.createElement('img');
IMG.src=URL;
IMG.onload = function(){
cxt.drawImage(IMG,0,0);
}
}
}
function update(){
ball.x += ball.stepX;
ball.y += ball.stepY;
bumpTest(ball);
}
function bumpTest(ele){
//左侧
if(ele.x <= ele.r){
ele.x = ele.r;
ele.stepX = -ele.stepX;
}
//右侧
if(ele.x >= W - ele.r){
ele.x = W - ele.r;
ele.stepX = -ele.stepX;
}
//上侧
if(ele.y <= ele.r){
ele.y = ele.r;
ele.stepY = -ele.stepY;
}
//下侧
if(ele.y >= H - ele.r){
ele.y = H - ele.r;
ele.stepY = -ele.stepY;
}
}
function render(){
//重置画布高度,达到清空画布的效果
canvas.height = H;
if(canvas.getContext){
var cxt = canvas.getContext('2d');
cxt.save();
//将画布背景涂黑
cxt.beginPath();
cxt.fillStyle = '#000';
cxt.fillRect(0,0,W,H);
//渲染探照灯
cxt.beginPath();
cxt.arc(ball.x,ball.y,ball.r,0,2*Math.PI);
cxt.fillStyle = '#000';
cxt.fill();
cxt.clip();
//由于使用了clip(),画布背景图片会出现在clip()区域内
cxt.drawImage(IMG,0,0);
cxt.restore();
}
}
initial();
clearInterval(oTimer);
function fnInterval(){
//更新运动状态
update();
//渲染
render();
}
var oTimer = setInterval(fnInterval,50);
</script>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# canvas
# 探照灯
# 探照灯效果
# 基于canvas实现超炫酷的流水灯效果
# 出现在
# 并在
# 对其
# 不支持
# 再试
# 清空
# 使用了
# 涂黑
# function
# onclick
# innerHTML
# history
# px
# solid
# script
# black
# document
# var
# getElementById
# IMG
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
🚀拖拽式CMS建站能否实现高效与个性化并存?
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
Android自定义listview布局实现上拉加载下拉刷新功能
浅析上传头像示例及其注意事项
如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)
python中快速进行多个字符替换的方法小结
Python结构化数据采集_字段抽取解析【教程】
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
如何在阿里云高效完成企业建站全流程?
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
如何基于PHP生成高效IDC网络公司建站源码?
Android滚轮选择时间控件使用详解
如何自定义建站之星模板颜色并下载新样式?
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
如何制作一个表白网站视频,关于勇敢表白的小标题?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
JavaScript如何操作视频_媒体API怎么控制播放
微信h5制作网站有哪些,免费微信H5页面制作工具?
VIVO手机上del键无效OnKeyListener不响应的原因及解决方法
如何快速搭建高效服务器建站系统?
青岛网站建设如何选择本地服务器?
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
Laravel如何创建自定义Facades?(详细步骤)
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
如何在万网ECS上快速搭建专属网站?
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
详解Android——蓝牙技术 带你实现终端间数据传输
高性能网站服务器配置指南:安全稳定与高效建站核心方案
如何在景安云服务器上绑定域名并配置虚拟主机?
Laravel Session怎么存储_Laravel Session驱动配置详解
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
海南网站制作公司有哪些,海口网是哪家的?
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
百度浏览器如何管理插件 百度浏览器插件管理方法
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
iOS发送验证码倒计时应用
如何有效防御Web建站篡改攻击?
无锡营销型网站制作公司,无锡网选车牌流程?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
HTML 中如何正确使用模板变量为元素的 name 属性赋值

