iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎么用HTML5 Canvas API控制图片的缩放变换
  • 890
分享到

怎么用HTML5 Canvas API控制图片的缩放变换

2024-04-02 19:04:59 890人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关怎么用HTML5 canvas api控制图片的缩放变换,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 缩放变换scale(sx,sy)传入

这篇文章将为大家详细讲解有关怎么用HTML5 canvas api控制图片的缩放变换,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

缩放变换scale(sx,sy)传入两个参数,分别是水平方向和垂直方向上对象的缩放倍数。例如context.scale(2,2)就是对图像放大两倍。其实,看上去简单,实际用起来还是有一些问题的。我们来看一段代码:

<!DOCTYPE html>   

<html lang="zh">   

<head>   

    <meta charset="UTF-8">   

    <title>缩放变换</title>   

    <style>   

        body { background: url("./images/bg3.jpg") repeat; }  

        #canvas { border: 1px solid #aaaaaa; display: block; margin: 50px auto; }   

    </style>   

</head>   

<body>   

<div id="canvas-warp">   

    <canvas id="canvas">   

        你的浏览器居然不支持Canvas?!赶快换一个吧!!   

    </canvas>   

</div>   

<script>   

    window.onload = function(){   

        var canvas = document.getElementById("canvas");   

        canvas.width = 800;   

        canvas.height = 600;   

        var context = canvas.getContext("2d");   

        context.fillStyle = "#FFF";   

        context.fillRect(0,0,800,600);   

        context.strokeStyle = "red";   

        context.lineWidth = 5;   

        for(var i = 1; i < 4; i++){   

            context.save();   

            context.scale(i,i);   

            context.strokeRect(50,50,150,100);   

            context.restore();   

        }   

    };   

</script>   

</body>   

</html>  

运行结果:

2016322115330220.jpg (850&times;500)

 其实缩放很简单,稍微复杂的是,如何让鼠标成为放大或者缩小的中心。如果数学几何不好,计算公式就可能看不明白了。

javascript Code复制内容到剪贴板

canvas.onmousewheel=canvas.onwheel=function(event){//chrome firefox浏览器兼容   

    var pos=windowToCanvas(canvas,event.clientX,event.clientY);   

    event.wheelDelta=event.wheelDelta?event.wheelDelta:(event.deltaY*(-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();   

}  

  这个时候,基本功能就实现了,加载一张图片和加载多张图片都差不多,维护每一张图片的位置和大小,下面来整理一下代码吧。

JavaScript Code复制内容到剪贴板

var canvas,context;   

var img,//图片对象   

    imGISLoaded,//图片是否加载完成;   

    imgX=0,   

    imgY=0,   

    imgScale=1;   

(function int(){   

    canvas=document.getElementById('canvas');   

    context=canvas.getContext('2d');   

    loadImg();   

})();   

function loadImg(){   

    img=new Image();   

    img.onload=function(){   

        imgIsLoaded=true;   

        drawImage();   

    }   

    img.src="map.jpg";   

}   

function drawImage(){   

    context.clearRect(0,0,canvas.width,canvas.height);   

    context.drawImage(img,0,0,img.width,img.height,imgX,imgY,img.width*imgScale,img.height*imgScale);   

}   

canvas.onmousedown=function(event){   

    var pos=windowToCanvas(canvas,event.clientX,event.clientY);   

    canvas.onmousemove=function(event){   

        canvas.style.cursor="move";   

        var pos1=windowToCanvas(canvas,event.clientX,event.clientY);   

        var x=pos1.x-pos.x;   

        var y=pos1.y-pos.y;   

        pos=pos1;   

        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(canvas,event.clientX,event.clientY);   

    event.wheelDelta=event.wheelDelta?event.wheelDelta:(event.deltaY*(-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(canvas,x,y){   

    var bbox = canvas.getBoundinGClientRect();   

    return {   

        x:x - bbox.left - (bbox.width - canvas.width) / 2,   

        y:y - bbox.top - (bbox.height - canvas.height) / 2   

    };   

}  

缩放变换应注意的问题

看了上面的例子,大家一定对产生的结果有点奇怪。一是左上角顶点的坐标变了,而是线条的粗细也变了。因此,对于缩放变换有两点问题需要注意:

缩放时,图像左上角坐标的位置也会对应缩放。

缩放时,图像线条的粗细也会对应缩放。

比如对于最小的那个原始矩形,它左上角的坐标是(50,50),线条宽度是5px,但是放大2倍后,左上角坐标变成了(100,100),线条宽度变成了10px。这就是缩放变换的副作用。

童鞋们一定在期待着我说解决副作用的途径。很遗憾,没有什么好的方法去解决这些副作用。如果想固定左上角坐标缩放,可以把左上角坐标变成(0,0),这样的话无论是什么倍数,0乘上它还是0,所以不变。如果不想让线条粗细变化,那就别使用线条。或者自己封装一个函数,不要使用scale()。

究其根本,之前我们说过平移变换、旋转变换、缩放变换都属于坐标变换,或者说是画布变换。因此,缩放并非缩放的是图像,而是整个坐标系、整个画布!就像是对坐标系的单位距离缩放了一样,所以坐标和线条都会进行缩放。仔细想想,这一切貌似挺神奇的。

关于“怎么用HTML5 Canvas API控制图片的缩放变换”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 怎么用HTML5 Canvas API控制图片的缩放变换

本文链接: https://www.lsjlt.com/news/92240.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用HTML5 Canvas API控制图片的缩放变换
    这篇文章将为大家详细讲解有关怎么用HTML5 Canvas API控制图片的缩放变换,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 缩放变换scale(sx,sy)传入...
    99+
    2024-04-02
  • 怎么使用HTML5 Canvas API控制图片的缩放变换
    这篇文章给大家分享的是有关怎么使用HTML5 Canvas API控制图片的缩放变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。缩放变换scale(sx,sy)传入两个参数,分...
    99+
    2024-04-02
  • 怎么用HTML5 Canvas控制图形矩阵变换
    小编给大家分享一下怎么用HTML5 Canvas控制图形矩阵变换,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 当我们把对应的...
    99+
    2024-04-02
  • HTML5中Canvas如何控制图形矩阵变换
    这篇文章主要介绍了HTML5中Canvas如何控制图形矩阵变换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在介绍矩阵变换transform...
    99+
    2024-04-02
  • 怎么用HTML5的canvas实现图片压缩
    本篇内容主要讲解“怎么用HTML5的canvas实现图片压缩”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用HTML5的canvas实现图片压缩”吧!代码如...
    99+
    2024-04-02
  • 如何使用HTML5 Canvas实现图片缩放、颜色渐变效果
    这篇文章主要为大家展示了“如何使用HTML5 Canvas实现图片缩放、颜色渐变效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用HTML5 Canva...
    99+
    2024-04-02
  • 怎么用HTML5的Canvas API绘制图形
    本篇内容介绍了“怎么用HTML5的Canvas API绘制图形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • 怎么通过Canvas及File API缩放并上传图片
    本文小编为大家详细介绍“怎么通过Canvas及File API缩放并上传图片”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么通过Canvas及File API缩放并上传图片”文章能帮助大家解决疑惑,下面...
    99+
    2024-04-02
  • 怎么在html5中使用canvas压缩图片
    这期内容当中小编将会给大家带来有关怎么在html5中使用canvas压缩图片,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。知识点:canvas 的 toDataURL('image/png'...
    99+
    2023-06-09
  • 怎么调用HTML5的Canvas API绘制图形
    这篇文章主要讲解了“怎么调用HTML5的Canvas API绘制图形”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么调用HTML5的Canvas API绘...
    99+
    2024-04-02
  • HTML5中Canvas怎么绘制图片
    这篇文章给大家分享的是有关HTML5中Canvas怎么绘制图片的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。获取Image对象,new出来定义Image对象的src属性,参数:图片路径定义Image对象的onlo...
    99+
    2023-06-09
  • HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析
    这篇文章将为大家详细讲解有关HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。翻转、移动、平移、放大、缩小XML/HTML Code复制内容到剪贴...
    99+
    2023-06-09
  • HTML5 canvas怎么实现图形变换
    这篇文章主要介绍“HTML5 canvas怎么实现图形变换”,在日常操作中,相信很多人在HTML5 canvas怎么实现图形变换问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • html5怎么使用canvas绘制一张图片
    本篇内容主要讲解“html5怎么使用canvas绘制一张图片”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么使用canvas绘制一张图片”吧!<...
    99+
    2024-04-02
  • 怎么使用canvas压缩图片
    今天就跟大家聊聊有关怎么使用canvas压缩图片,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先要先获取到图片文件var eleFile = docu...
    99+
    2023-06-09
  • HTML5 Canvas怎么绘制文本及图片
    这篇文章主要讲解了“HTML5 Canvas怎么绘制文本及图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML5 Canvas怎么绘制文本及图片”吧!...
    99+
    2024-04-02
  • jQuery怎么实现鼠标滚轮控制图片缩放
    本文小编为大家详细介绍“jQuery怎么实现鼠标滚轮控制图片缩放”,内容详细,步骤清晰,细节处理妥当,希望这篇“jQuery怎么实现鼠标滚轮控制图片缩放”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,...
    99+
    2024-04-02
  • HTML5 canvas怎么实现图形变换效果
    这篇文章主要介绍“HTML5 canvas怎么实现图形变换效果”,在日常操作中,相信很多人在HTML5 canvas怎么实现图形变换效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • HTML5的Canvas API怎么用
    这篇文章主要介绍“HTML5的Canvas API怎么用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“HTML5的Canvas API怎么用”文章能帮助大家解决问题...
    99+
    2024-04-02
  • 通过变换矩阵怎么实现canvas的缩放功能
    本篇文章为大家展示了通过变换矩阵怎么实现canvas的缩放功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。第一步就是监听鼠标的滚轮事件,在滚轮事件中根据鼠标的滚动以及基于前一次的变换,重新设置co...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作