Canvas实现图片放大缩小移动操作
对于HTML5相信大家都不陌生,很早就出来了,但是貌似都没有真正的使用过。最近做项目时要实现这样一个需求:一个图片,大小不固定,要求能实现类似地图一样放大、缩小、移动功能。这里就很合适使用html5的canvas画布。
实现步骤如下:
1. 定义一个canvas标签。
- <canvas id="bargraphCanvas" width="500" height="600"></canvas>
这里有个很重要的地方,就是这个width和height一定要写,否则不能实现。同时,画布的宽高只能用这个方法写,css设置有问题。大家可以试试。
2.初始化canvas,以及其他所需对象。
- var canvas, context;
- var img,//图片对象
- imgIsLoaded,//图片是否加载完成;
- imgX = 0,
- imgY = 0,
- imgScale = 1;
- (function int() {
- canvas = document.getElementById('bargraphCanvas'); //画布对象
- context = canvas.getContext('2d');//画布显示二维图片
- loadImg();
- })();
3.定义一个image对象并设置好它的onload事件和src属性。
- function loadImg() {
- img = new Image();
- img.onload = function () {
- imgIsLoaded = true;
- drawImage();
- }
- img.src = '../../Content/images/mayday.jpg';
- }
4.调用canvas的draw方法。
- function drawImage() {
- context.clearRect(0, 0, canvas.width, canvas.height);
- context.drawImage(
- img, //规定要使用的图像、画布或视频。
- 0, 0, //开始剪切的 x 坐标位置。
- img.width, img.height, //被剪切图像的高度。
- imgX, imgY,//在画布上放置图像的 x 、y坐标位置。
- img.width * imgScale, img.height * imgScale //要使用的图像的宽度、高度
- );}
这里要介绍下canvas的drawImage方法,参考w3school,drawImage是可以实现图片的裁剪功能,参数的含义以及是否必填如下:
** img 规定要使用的图像、画布或视频。
** sx 可选。开始剪切的 x 坐标位置。
** sy 可选。开始剪切的 y 坐标位置。
** swidth 可选。被剪切图像的宽度。
** sheight 可选。被剪切图像的高度。
** x 在画布上放置图像的 x 坐标位置。
** y 在画布上放置图像的 y 坐标位置。
** width 可选。要使用的图像的宽度。(伸展或缩小图像)
** height 可选。要使用的图像的高度。(伸展或缩小图像)
5.到这里,如果代码没有问题的话,图片就可以成功地在canvas中显示了。下面就是实现放大、缩小、平移操作。在初始化canvas的同时也初始化其事件,如下:
- /*事件注册*/
- function canvasEventsInit() {
- canvas.onmousedown = function (event) {
- var pos = windowToCanvas(event.clientX, event.clientY); //坐标转换,将窗口坐标转换成canvas的坐标
- canvas.onmousemove = function (evt) { //移动
- canvas.style.cursor = 'move';
- var posl = windowToCanvas(evt.clientX, evt.clientY);
- var x = posl.x - pos.x;
- var y = posl.y - pos.y;
- pos = posl;
- imgX = x;
- imgY = y;
- drawImage(); //重新绘制图片
- };
- canvas.onmouseup = function () {
- canvas.onmousemove = null;
- canvas.onmouseup = null;
- canvas.style.cursor = 'default';
- };
- };
- canvas.onmousewheel = canvas.onwheel = function (event) { //滚轮放大缩小
- var pos = windowToCanvas (event.clientX, event.clientY);
- event.wheelDelta = event.wheelDelta ? event.wheelDelta : (event.deltalY * (-40)); //获取当前鼠标的滚动情况
- if (event.wheelDelta > 0) {
- imgScale *= 2;
- imgX = imgX * 2 - pos.x;
- imgY = imgY * 2 - pos.y;
- } else {
- imgScale /= 2;
- imgX = imgX * 0.5 pos.x * 0.5;
- imgY = imgY * 0.5 pos.y * 0.5;
- }
- drawImage(); //重新绘制图片
- };
- }
- /*坐标转换*/
- function windowToCanvas(x,y) {
- var box = canvas.getBoundingClientRect(); //这个方法返回一个矩形对象,包含四个属性:left、top、right和bottom。分别表示元素各边与页面上边和左边的距离
- return {
- x: x - box.left - (box.width - canvas.width) / 2,
- y: y - box.top - (box.height - canvas.height) / 2
- };
- }
按照这些步骤,图片的加载,放大、缩小、平移都已经实现了。个人感觉这个比较难的地方在于,这个是使用原生javascript写的,如果使用jquery会不会简单些,以后有时间再试试吧。目前效果如下:
Canvas实现图片放大缩小移动操作的更多相关文章
- javascript仿新浪微博图片放大缩小及旋转效果
javascript仿新浪微博图片放大缩小及旋转效果 经常看到新浪微博里有图片放大缩小旋转效果,感觉效果还不错,所以就想试着做一个类似的demo出来,至于旋转对于IE可以用滤镜来解决,标准的浏览器可以 ...
- 鼠标滚轮图片放大缩小功能,使用layer弹框后不起作用
今天在项目中遇到的一个问题:点击按钮使用layer弹框弹出一张图片,需要加一个鼠标滚轮放大缩小,图片也跟着放大缩小的功能.于是在网上找了一个demo. DEMO: <!DOCTYPE html ...
- hammer使用: 代码:捏合、捏开、图片放大 的一个手机图片“放大缩小可拖动”的小效果
hammer.js 的使用. (手机手势插件) 捏合.捏开.图片放大 的一个手机图片“放大缩小可拖动”的小效果. 相关js 到 http://www.bootcdn.cn/ 查找和下载. hamme ...
- vue项目 一行js代码搞定点击图片放大缩小
一行js代码搞定xue项目需要点击图片放大缩小,其实主要用的是用到了vue:class的动态切换,内容比较简单.一开始我把维护的需求想得太复杂了,和测试小姐姐聊了一下才反应过来. 两个月不到跟了四个项 ...
- 自定义mousewheel事件,实现图片放大缩小功能实现
本文是承接 上一篇的<自定义鼠标滚动事件> 的基础上实现的,建议大家先看一下上一篇的mousewheel的实现,再浏览下文: 上篇中我们介绍到: $element.mousewheel( ...
- imageView图片放大缩小及旋转
imageView图片放大缩小及旋转 一.简介 二.方法 1)设置图片放大缩小效果 第一步:将<ImageView>标签中的android:scaleType设置为"fitCen ...
- wpf下的图片放大缩小
WPF下实现图片的放大缩小移动 在windows 7里面有自带的图片查看器,这个软件可以打开一张图片然后以鼠标在图片中的焦点为原点来进行缩放,并且放大后可以随意拖动.下面我们在WPF中实现这个功能 ...
- 41.Android之图片放大缩小学习
生活中经常会用到图片放大和缩小,今天简单学习下. 思路:1.添加一个操作图片放大和缩小类; 2. 布局文件中引用这个自定义控件; 3. 主Activity一些修改. 代码如下: 增加图片操作类: ...
- 图片放大缩小(和ViewPager配合使用流畅显示)--第三方开源--PhotoView
图片的放大缩小实现效果是使用的github上的一个开源项目photoView实现的,下载地址:https://github.com/chrisbanes/PhotoView 下面看测试代码: acti ...
随机推荐
- 【转】PHP ob_start() 函数介绍
php ob_start 与 ob_end_flush() 是 php 的缓冲输出函数. ob_start([string output_callback])- 打开输出缓冲区,所有的输出信息不在直接 ...
- Sublime Text3 以及 SublimeREPL使用Virtualenv执行python
1. SublimeText3 安装Virtualenv插件(Crtl+Shift+P) 2. 新建python虚拟环境: Crtl+Shift+P,选中Virtualenv:New选项,在底部Vir ...
- (转)CMOS Sensor的调试经验分享
CMOS Sensor的调试经验分享 我这里要介绍的就是CMOS摄像头的一些调试经验. 首先,要认识CMOS摄像头的结构.我们通常拿到的是集成封装好的模组,一般由三个部分组成:镜头.感应器和图像信号处 ...
- 替换jenkins上打包完成的安装包的方法
修改 /root/.jenkins/jobs/Item名称/lastSuccessful/archive/*/obj 文件夹下的文件,就可以在下图二中下载新修改的文件,需要注意的是,此文件夹下不能有新 ...
- category用法
1.今天在复习之前的category的时候,遇到一个这样子的问题.查来一下,原来苹果的官方文档中有说明,苹果时不提倡我们在类别中重写原文件的内容,如果要重写,就继承他,然后重写,但是在项目中,有很多前 ...
- 有一道题,大家能帮我看一下哪里错了吗?c++的
有一道题我不知道是哪里错了,大神们帮忙看一下,谢谢! 试题描述: 在四位自然数中有这样一些特点的数:(1)它们是素数:(2)将这些素数加上45后得到一个新的数值:(3)请同学们在这些新的数值中挑选出: ...
- 使用git 更新线上代码
先本地代码合并://1合并分支git branch//2查看taggit tag //3添加tagcloud_crm]$ git tag -a v1.0.2 -m "0902"// ...
- gulp 安装 使用 和删除
1.安装 全局安装: npm intstall gulp -g (首先你得有node.js ,这个可以去node 官网下载个iso的镜像安装包,傻瓜式安装.自带npm) 安装在项目中: 首先 ...
- .net post的参数如果出现乱码如何解决!
可以在webConfig里面添加 <system.web> <globalization requestEncoding="gb2312" responseEnc ...
- linux关闭双显卡的方法
我正在使用的一体机是双显卡,在linux下没有很么太好的办法来切换双显卡, 导致使用一会儿后就发烫,关键是这时风扇呜呜的响很吵人 最后找到了下面的解决方法来关掉独立显卡 见 https://githu ...