转:canvas--放大镜效果

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>鼠标事件</title>
</head>
<body>
<canvas id="canvas"></canvas>
<canvas id="offCanvas" style=" display: none;"></canvas>
<script>
 var canvas=document.getElementById('canvas')
 var context=canvas.getContext('2d')
 var offcanvas=document.getElementById('offCanvas')
 var offcontext=offcanvas.getContext('2d') 
 var image=new Image()
 //鼠标左键是否被点击
 var isMouseDown=false;
 //定义缩放值
 var scale 
 window.οnlοad=function(){
  canvas.width="1030";
  canvas.height='750';
  image.src="timg.jpg"
  //图片的原始尺寸要大于canvas的尺寸
  image.οnlοad=function(){
  offcanvas.width=image.width;
  offcanvas.height=image.height
  scale=offcanvas.width/canvas.width;  
  context.drawImage(image,0,0,canvas.width,canvas.height);
  offcontext.drawImage(image,0,0)
  }
  //将屏幕的坐标转换为在canvas的坐标
  function windowToCanvas(x,y){
  //获取canvas距离浏览器周围的left和top值
  var bbox=canvas.getBoundingClientRect();
 
  return {x:x-bbox.left,y:y-bbox.top}   
 
  //鼠标按下
  canvas.οnmοusedοwn=function(e){
  e.preventDefault(e);
  var point=windowToCanvas(e.clientX,e.clientY);
  //console.log('point.left'+point.x+','+e.clientX+','+e.clientY)
      isMouseDown=true
      //绘制放大镜 当onmouseup、onmouseout时 drawcanvasWithMagnifier传入false
      drawcanvasWithMagnifier(true,point)            
  }
  //鼠标移动
  canvas.οnmοusemοve=function(e){
  e.preventDefault(e);
  //需要查看鼠标的左键是否点击着 如果没有点击则释放放大镜效果
  //isMouseDown为true时显示放大镜
  if(isMouseDown){
  var point=windowToCanvas(e.clientX,e.clientY);
  //console.log('point.left'+point.x+','+e.clientX+','+e.clientY)
  drawcanvasWithMagnifier(true,point)
  }
  }
  //鼠标松开
  canvas.οnmοuseup=function(e){
  e.preventDefault(e);
  isMouseDown=false;
  drawcanvasWithMagnifier(false)
  }
  //鼠标移开
  canvas.οnmοuseοut=function(e){
  e.preventDefault(e);
  isMouseDown=false;
  drawcanvasWithMagnifier(false)
  }
  function drawcanvasWithMagnifier(isMouseDown,point){
  context.clearRect(0,0,canvas.width,canvas.height)
  context.drawImage(image,0,0,canvas.width,canvas.height);
  if(isMouseDown){
  //绘制放大镜】
  drawMagnifier(point)
  }
  }
  function drawMagnifier(point){
  //console.log('point.x'+point.x+'point.y'+point.y);
  //鼠标点击的位置 计算出在放大图像中的位置  计算出大图的中心坐标
  var imageLG_cx=point.x*scale
  var imageLg_cy=point.y*scale
  //放大镜显示的大小 设置为200 放大镜的半径为200
  var mr=200
  //计算圆形的坐标和宽高
  var sx=imageLG_cx-mr;
  var sy=imageLg_cy-mr;
  //用户可见的位置
  var dx=point.x-mr;
  var dy=point.y-mr;
  context.save()
  context.lineWidth=10.0;
  context.strokeStyle='#069'
  context.beginPath()
  //圆形剪辑
  context.arc(point.x,point.y,mr,0,Math.PI*2)
  context.stroke();
  context.clip();
  context.drawImage(offcanvas,sx,sy,2*mr,2*mr,dx,dy,2*mr,2*mr);
  context.restore()
 
 }
</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/247534.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MON

早上5点,咪咪牛就醒了,开始跳到我边上,用白毛毛把我弄醒,在我身上走来走去,把她按住抚摸也不能让她停止.....只能拎起来扔到边上了 ;)看起来还的确是很调皮的猫咪呢昨天晚上就开始不太怕我了,走到我的椅子边上喵喵叫,直到把她放在身上,才慢慢睡觉,满可爱的早上出门叫车,一车正停…

CSS做个Switch开关

Switch开关&#xff1a;根据需求可知&#xff0c;Switch开关只有两种选择&#xff0c;true或false。所以我们想到HTML的checkbox控件&#xff0c;用它来做。  <input id"switch" type"checkbox" class"switch" />但是在浏览器中&#xf…

vue小记录1

1.入口index.html文件 做reset.css初始化&#xff0c;视口viewport设置 2.规范化eslint配置&#xff08;常用&#xff09; &#xff08;1&#xff09;rules -->"semi"分号 "semi":[error,alway], &#xff08;2&#xff09;indent 空格 "inde…

解决虚拟机能ping通宿主机,而宿主机不能ping通虚拟机

解决虚拟机能ping通宿主机&#xff0c;而宿主机不能ping通虚拟机 首先&#xff0c;查看宿主机的网卡状态 如果没有&#xff0c;打开虚拟机&#xff0c;选择编辑 打开虚拟网络编辑器&#xff0c;并选择更改设置 勾选将设备适配器连接此网络 完成&#xff0c;这样宿主机便可以pin…

mongo使用学习FAQ

1:mongo的集合和database区分大小写么? 在 MongoDB 中&#xff0c;数据库和集合的名称是区分大小写的。这意味着&#xff0c;数据库 MyDatabase 和 mydatabase 或集合 MyCollection 和 mycollection 会被视为不同的数据库或集合。因此&#xff0c;在操作数据库和集合时&#…

前端下载的实现

前端很多项目中&#xff0c;都有文件下载的需求&#xff0c;特别是JS生成文件内容&#xff0c;然后让浏览器执行下载操作&#xff08;例如在线图片编辑、在线代码编辑、iPresst等&#xff09;。但受限于浏览器&#xff0c;很多情况下我们都只能给出个链接&#xff0c;让用户点击…

V记录2(文档)Vue.extend构造器

1.简单介绍 Vue.extend(options) 参数&#xff1a;对象 用法&#xff1a;使用Vue构造器&#xff0c;创建一个“子类”&#xff0c;参数是一个包含组件选项的对象&#xff0c;其中,data选项中必须是函数 描述&#xff1a;Vue.extend返回的是一个“扩展实例构造器”&#xff0c;也…

在javascript中,如何判断一个被多次encode 的url 已经被decode到原来的格式?

% 而不能被无限次decodeURIComponent 可以用%来进行判断 转载于:https://www.cnblogs.com/zhouyideboke/p/11169705.html

推荐base.css

学习《编写高质量代码--Web前端开发修炼之道》 /* CSS Document */ /*css reset*/ body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;} table{ border-collapse:collapse;border-spacing:0;} fieldest,i…

如何通过RFID开发来迎接第四次工业革命(转)

我们都经历了革命性的冲击&#xff0c;自上世纪90年代初的互联网冲击了文化和商业&#xff0c;但很少人知道如何完成RFID开发来迎接第四次工业革命&#xff0c;在接下来的二十年里&#xff0c;智能工厂的出现将成为一个重要组成部分。制造业作为我国工业的主体&#xff0c;面临…

对js数组去重的研究

1.利用es5 let arr [1, 2, 3, 4, 5, 6, 7, 1, 2, 3] const uniquearr>{ return Array.from(new Set(arr)) } console.log(unique(arr))2.通过双层循环使用splice删除 let arr [1, 2, 3, 4, 5, 6, 7, 1, 2, 3] const uniquearr>{ // return Array.from(new Se…

一些前端开发经典书籍推荐和下载链接分享

下面的这些书都是我曾看过或了解过的&#xff1a; 一.HTML 1.《HTML5权威指南》 非常全面的书&#xff0c;内容也很新&#xff0c;包含了HTML5CSS3JS DOM。 下载链接&#xff1a;http://pan.baidu.com/s/1qYGn1qW HTML我暂时没看什么书&#xff0c;学会了大部分的标签后我…

RFID图书管理系统程序源代码(转)

RFID图书管理系统程序源代码https://wenku.baidu.com/view/5f4e47f0c9d376eeaeaad1f34693daef5ef713d9.html

UOJ310 黎明前的巧克力 FWT

传送门 我们要求的是\([x^0]\prod\limits_{i1}^n (2x^{a_i}1)\)&#xff0c;其中乘积定义为集合对称差卷积。 这个直接做复杂度太高了&#xff0c;考虑优化。注意到在FWT之后&#xff0c;每一个序列中的值要么是\(3\)&#xff0c;要么是\(-1\)&#xff0c;而且这个只跟\(a_i\)有…

vue调用百度地图API

安装 $ npm install vue-baidu-map --save 全局注册 在main.js 里面引入以下代码 import BaiduMap from vue-baidu-mapVue.use(BaiduMap, {ak: 百度地图密钥AK }) 使用方法 <doc-preview><baidu-map class"map" style"display: flex; flex-direct…

mysql show processlist命令 详解

SHOW PROCESSLIST显示哪些线程正在运行。您也可以使用mysqladmin processlist语句得到此信息。如果您有SUPER权限&#xff0c;您可以看到所有线程。否则&#xff0c;您只能看到您自己的线程&#xff08;也就是&#xff0c;与您正在使用的MySQL账户相关的线程&#xff09;。请参…

JS 数据处理技巧及小算法汇总(转载)

1、根据属性来更新一个数组中的对象 const arr [ {id: 1, score: 1}, {id: 2, score: 2}, {id: 3, score: 4}]; //更新的值 const newValue {id: 3, score: 3} 更新数组中id为3的score值。 Es6 装逼写法如下&#xff1a; const result initial.map(x > x.id newValue.i…

让行内元素(如图片)在div中水平垂直居中 (干货)

&#xff08;1&#xff09;第一种&#xff1a;用vertical-align <div class"method1"><span class"tiptop"></span><img class"test" src"img/Dota2.jpg" alt"dota2"> </div><style> …

对Canvas的研究

1。标签定义图形&#xff0c;比如图表和其他图像&#xff0c;您必须使用脚本来绘制图形。 什么是 canvas? HTML5 <canvas> 元素用于图形的绘制&#xff0c;通过脚本 (通常是JavaScript)来完成. <canvas> 标签只是图形容器&#xff0c;您必须使用脚本来绘制图形。 …

Vue中watch的简单应用

Vue.js 有一个方法 watch&#xff0c;它可以用来监测Vue实例上的数据变动。 如果对应一个对象&#xff0c;键是观察表达式&#xff0c;值是对应回调&#xff0c;值也可以是方法名&#xff0c;或者是对象&#xff0c;包含选项。 下面写两个demo&#xff0c;参考demo来了解一下 …