热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

canvas离屏技术与放大镜实现代码示例-

这篇文章主要介绍了canvas离屏技术与放大镜实现代码示例的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。
这篇文章主要介绍了canvas离屏技术与放大镜实现代码示例的相关资料,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

利用 canvas 除了可以实现滤镜,还可以利用 离屏技术 放大镜功能。

为了方便讲解,本文分为 2 个应用部分:

  • 实现水印和中心缩放

  • 实现放大镜

1. 什么是离屏技术?

canvas 学习和滤镜实现 介绍过 drawImage 接口。除了绘制图像,这个接口还可以: 将一个 canvas 对象绘制到另一个 canvas 对象上 。这就是离屏技术。

2. 实现水印和中心缩放

在代码中,有两个 canvas 标签。分别是可见与不可见。 不可见的 canvas 对象上的 Context 对象,就是我们放置图像水印的地方。

更多详解,请看代码注释:



  
  
  


  

实现效果如下图所示:

3. 实现放大镜

在上述中心缩放的基础上,实现放大镜主需要注意以下 2 个部分:

  • 细化处理canvas的鼠标响应事件:滑入、滑出、点击和松开

  • 重新计算离屏坐标(详细公式计算思路请见代码注释)

  • 重新计算鼠标相对于 canvas 标签的坐标(详细公式计算思路请见代码注释)

代码如下:



  
  
  


  
  
  

放大镜效果如下图所示(被红笔标出的区域就是我们的正方形放大镜):

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。更多相关教程请访问Html5视频教程!


推荐阅读
author-avatar
mobiledu2402851173
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有