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 属性赋值