前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >canvas 处理图像(上)

canvas 处理图像(上)

作者头像
用户8921923
发布于 2022-10-24 11:07:48
发布于 2022-10-24 11:07:48
2.3K00
代码可运行
举报
文章被收录于专栏:全栈私房菜全栈私房菜
运行总次数:0
代码可运行

canvas 处理图像(上)

本文将介绍在 Canvas 中使用图像的知识,包括加载图像和处理图像中的单个像素。Canvas 的这个功能可以用来创建一些炫丽的效果。本文还将教会你一般图像处理的知识。

1. 加载图像

canvas 高级功能(下)讲述了如何将画布导出为图像,将它保存到本地和与他人共享。现在,我们将学习如何实现完全相反的操作:将图像加载到画布中。介绍这个功能的主要原因是,它使我们能够用2D渲染上下文方法对原本不是在画布中创建的图像进行处理。我们还可以使用几种特殊的像素处理 方法,对图像执行一些有趣的特殊操作,这将在下面介绍。

❝注意:在画布中进行像素处理实际上并不要求真加载图像,如照片。相反,画布本身就是作为图像进行处理的,这意味着你在上面绘制的所有内容都可以使用本文介绍的方法进行处理。 ❞

将图像加载到画布中实际上与绘制图像一样简单——只涉及一个方法。在调用drawImage方法时,至少需要三个参数:所绘制的图像和图像绘制位置的(x, y)坐标。这个方法的完整形式是:context.drawImage(image, x, y);

参数image可以是HTML img元素、HTML5 canvas元素或HTML5 video元素。

❝注意:实际上,drawImage方法有两种调用方式,这两种方式所使用的参数个数是不同的。我们将在下面详细介绍这两种方式。 ❞

首先,让我们使用与 HTML 文件位于相同目录的一个图像,将一个HTML img元素绘制到画布中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  const image = new Image();
  image.src = 'picture.jpg';
  image.onload = function() {
    context.drawImage(image, 0, 0);
  }

这里所做的第一件事是使用Image类为HTML img元素赋一个空的DOM对象。然后,通过把它的src属性设置为一个有效的图像文件路径,就可以将该图像加载到图像元素中,这就好像是设置了HTML img元素的src属性。实际上这创建了一个普通的HTML img元素,但是并没有将它显示在浏览器上。如果只希望给画布传递一个图像,而实际上不将它添加到HTML代码中,那么就可以使用这种方法。如果你就是想要看到这个HTML图像,那么完全可以跳过这些步骤,将image变量的值赋给现有HTML img元素的 DOM 对象。

❝注意:在这个例子中,我们使用的是本地存储的图像文件,但是只要愿意,你也可以轻松地加载其他网站的图像。然而,使用外部图像有一些限制。现在,你只需要知道在使用外部图像时,画布会限制一些特定的功能就可以了。 ❞

无论使用哪一种方法,现在我们都应该能够访问图像的 DOM 对象了。最后要做的一件事是将这个图像对象传递给2D渲染上下文的drawImage方法,但是在这之前,我们需要确认这个图像已经完全加载。为此,可以使用imageload方法,它是在一个元素完全加载后触发load事件时调用的方法。

现在,我们知道这个图像在什么时候完成加载:我们将drawImage方法置于load事件被触发之后运行的回调事件中。drawImage方法的参数就是刚刚创建的图像对象,以及绘制图像的原点(x, y)坐标值。

如果一切正常,我们就能够将图像绘制到画布上,尽管图像可能被剪掉一部分。然而,不需要担心,因为剪掉的原因是画布小于所绘制的图像尺寸,而图像是以完整尺寸绘制的。

然而,无法看到另一半图像很让人失望,所以让我们看看如何使它适合画布的尺寸。

2. 调整和裁剪图像

我们现在知道调用drawImage方法的第一种方式,即将完整尺寸的图像绘制到画布上,但超过画布边界的部分被剪掉了。为了解决这个问题,需要调整图像大小或者控制图像的裁剪。通过drawImage方法的最后两种调用方式都能够完成这两个任务,第一种调用可以调整图像大小,第二种可以同时调整和裁剪图像。drawImage的所有调用方式的唯一区别是所使用参数的个数和类型不同。

2.1 调整图像大小

实际上,调整图像大小与绘制完整尺寸的图像一样简单,只需要传入希望绘制的图像宽度和高度。用代码来表示,带有调整大小的参数的drawImage方法:context.drawImage(image, x, y, width, height);的确非常简单。

将前一个例子的drawImage方法修改为以下形式,图像就能够被调整为在画布中完全显示:context.drawImage(image, 0, 0, 500, 333);

其中,宽度为500像素,与画布的宽度相等。而333像素的高度是按照原始图像的高宽比(高度与宽度的比例)计算得来的。要计算这个高宽比,只需要用高度除以宽度,对于原始图像(宽1024像素,高683像素),计算得到的高宽比为0.666992188(683÷1024)。然后,用宽度乘以这个比例就可以计算出调整后的图像高度。

如果要绘制完整的图像,那么调整大小是很有用的,但是有时候我们需要进一步控制图像绘制的部分,那么它就缺少足够的支持了。这时,我们需要使用裁剪功能。

2.2 裁剪图像

裁剪的目的是将图像剪切为较小尺寸,这通常是因为我们只需要使用被裁剪对象的一部分。裁剪画布所采取的方法与流行的照片编辑应用程序(如Adobe Photoshop)是完全相同的:划定一个希望保留的矩形区域,然后将矩形以外的全部内容删除。

裁剪是drawImage方法的最后一种用法,它总共有9个参数:源图像、源图像的裁剪区原点坐标(x, y)、源图像的裁剪区宽度和高度、在画布(目标)上绘制图像的原点坐标(x, y)及在画布上绘制图像的宽度和高度。用代码表示,这些参数如下所示(w表示宽度,h表示高度):

context.drawImage(image, sx, sy, sw, sh, dx, dy, dw, dh);

我们可以从前面的图像中裁剪出一小部分,然后将它绘制到画布中:

context.drawImage(image, 0, 0, 250, 250, 0, 0, 250, 250);

在这个例子中,我们从源图像的左上角(0, 0)开始裁剪出250像素的正方形,然后以相同的宽度和高度将它绘制到画布的左上角。

在将裁剪的图像绘制到画布时,还可以调整它的尺寸,例如:

context.drawImage(image, 0, 0, 250, 250, 0, 0, 500, 500);

这段代码实际上与前一个例子是完全相同的,只是所绘制的图像不再保留裁剪区域的原始尺寸,而是将它放大两倍。

2.3 阴影

简单强调一下在进行裁剪时的阴影效果,这是很重要的。简言之,在调整图像尺寸时,阴影效果应该也显示得很好。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
context.shadowBlur = 20;
context.shadowColor = "rgb(0, 0, 0)";

const image = new Image();
image.src = 'picture.jpg';
image.onload = function() {
  context.drawImage(image, 50, 50, 300, 200);
}

然而,在一些浏览器中,对图像进行裁剪时阴影效果似乎会完全消失。官方规范规定了图像在绘制到画布时应当支持阴影效果,只是有些浏览器还没有完全支持这一点。

这就是关于在画布中调整和裁剪图像的全部内容。如果希望执行更多的操作,可以使用 2D 渲染上下文的变形功能,我们马上开始介绍这部分内容。

3. 图像变形

正如前面介绍的,在画布中绘制图像之后,我们就可以对它执行所有的 2D 渲染上下文方法。变形作为一组方法使我们能够在图像上做出一些非常漂亮的效果。现在继续学习如何使用它们来操作图像。

3.1 平移

这是到目前为止最简单的图像变形方法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
context.translate(100, 100);

const image = new Image();
image.src = 'picture.jpg';
image.onload = function() {
  context.drawImage(image, 50, 50, 300, 200);
}

它在绘制图像之前将画布平移,代码是我们已经熟悉的。

3.2 旋转

以前,在浏览器中旋转图像是很难实现的,但是利用画布这个操作变得很容易。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
context.translate(250, 250);
context.rotate(0.7854): // 旋转 45 度

const image = new Image();
image.src = 'picture.jpg';
image.onload = function() {
  context.drawImage(image, 0, 0, 500, 500, -150, -150, 300, 300);
}

同样,这段代码中并没有什么新东西。

3.3 缩放与翻转

所有的变形方法中最随机的一个就是完全翻转图像。例如,通过各种方式对同一图像进行翻转,可以创建出万花筒效果。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const image = new Image();
image.src = 'picture.jpg';
image.onload = function () {
  // 左上角
  context.translate(50, 50);
  context.drawImage(image, 0, 0, 500, 500, 0, 0, 200, 200);

  //左下角
  context.setTransform(1, 0, 0, 1, 0, 0); // 重置变换矩阵
  context.translate(50, 450);
  context.scale(1, -1);

  context.drawImage(image, 0, 0, 500, 500, 0, 0, 200, 200);

  //右下角
  context.setTransform(1, 0, 0, 1, 0, 0);
  context.translate(450, 450);
  context.scale(-1, -1);

  context.drawImage(image, 0, 0, 500, 500, 0, 0, 200, 200);

  //右上角
  context.setTransform(1, 0, 0, 1, 0, 0);
  context.translate(450, 50);
  context.scale(-1, 1);

  context.drawImage(image, 0, 0, 500, 500, 0, 0, 200, 200);
}

这段代码太长了可能有点难以理解,但是其过程实际上很简单。它所执行的操作就是在 4 个不同位置绘制同一个图像,每一个都具有不同的缩放因子。如果使用负数缩放因子,就会使图像翻转。一定要记住,当图像翻转时,原点会转到图像右边,所以你必须移动原点进行补偿,以便从右到左进行绘制。例如,右上角的图像是在位置(450, 50)上绘制的,因为它已经在 x 轴方向翻转,这意味着现在它是从 x 轴450像素位置画到 x 轴250像素位置(从右到左)。

这个过程有点违反直觉,但是这确实是一种能够创建有趣图像效果的简单方法。例如,它完全可以用来在画布中绘制出人造的反射效果。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-06-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈私房菜 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
PHP之内置web服务器
这个主要是用来做本地的开发用的。不能用于线上环境。现在我就介绍一下这个工具如何使用。
魔王卷子
2019/05/24
3.9K0
PHP之内置web服务器
PHP的内置WEB服务器
在很多时候,我们需要简单的运行一个小 demo 来验证一些代码或者轮子是否可用,是否可以运行起来,但是去配 nginx 或者 apache 都很麻烦,其实,PHP CLI 已经提供了一个简单的测试服务器,我们直接就可以运行起来进行简单的一些测试工作。
硬核项目经理
2020/07/09
2.1K0
PHP的内置WEB服务器
web服务器与HTTP协议
Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源。 l Internet上供外界访问的Web资源分为: • 静态web资源(如html 页面):指web页面中供人们浏览的数据始终是不变。 • 动态web资源:指web页面中供人们浏览的数据是由程序产生的,不同时间点访问web页面看到的内容各不相同。 l 静态web资源开发技术 • Html l 常用动态web资源开发技术: • JSP/Servlet、ASP、PHP等 ruby python •
Java帮帮
2018/03/19
2.9K0
web服务器与HTTP协议
PHP新特性之字节码缓存和内置服务器
Zend OPcache 1).从PHP5.0//开始,内置了字节码缓存功能,名为Zend OPcache。因为PHP是解释性语言,PHP解释器执行PHP脚本时会解析PHP脚本代码,生成一系列的Zend操作码,然后执行字节码,每次的HTTP请求都是这样,会消耗很多资源,使用字节码缓存可以缓存预先编译的字节码,减少响应时间,降低系统资源的压力。 启用Zend OPcache 默认情况之下,Zend OPcache是没有启动的。如果是自己编译PHP,执行的时候命令必须包含以下选项:
用户2323866
2021/06/29
6400
Node.js开发Web后台服务
张果
2018/01/04
10.8K0
Node.js开发Web后台服务
python网络-动态Web服务器案例(30)
PythonWeb服务器网关接口(Python Web Server Gateway Interface,缩写为WSGI)是Python应用程序或框架和Web服务器之间的一种接口,
Se7eN_HOU
2019/06/26
1.4K0
python网络-动态Web服务器案例(30)
Linux/centos上如何配置管理Web服务器?
虫无涯
2023/11/08
6530
PHP之内置web服务器
将PHP的安装路径配置到电脑的系统环境变量Path中,下图是win7,win10中会看的更清楚
很酷的站长
2023/02/17
9550
PHP之内置web服务器
前端开发中的几种资源重定向方法
嗯,但是为嘛需要这么做呢...... 这道题面试中也真有很多稀里糊涂做完类似的项目,却答不上来的小伙伴,那你自个儿寻思去吧~
江米小枣
2020/06/15
2.6K0
web服务器有哪些?_服务器和web服务器有什么区别
如果一个软件的主要部分采用了”网络服务”,即它把存储或计算环节”外包”给其他网站了,那么我们就说这个软件属于Web Service架构。
全栈程序员站长
2022/11/04
9.4K0
web服务器有哪些?_服务器和web服务器有什么区别
技术解析 | Web缓存欺骗测试
前言: Omer Gil在BlackHat USA 2017 和BSides Tel-Aviv 2017 上,对Web 缓存欺骗技术这种攻击技术进行了演示,在他发布的“Web 缓存欺骗技术白皮书”中也做了详细的介绍。在特定情况下,web缓存欺骗攻击可以导致攻击者获得受害者的敏感信息。 Web缓存是指Web资源以副本的形式介于Web服务器和客户端之间,当下一个相同请求来到的时候,会根据缓存机制决定是直接使用副本响应访问请求,还是向源服务器再次发送请求。在实际应用中,web缓存十分常见,主要是Web缓存有着如下
FB客服
2018/02/23
1.2K0
技术解析 | Web缓存欺骗测试
自己动手写Web服务器(一)简单的静态服务器
前几天开始看《How Tomcat Works》,因为有人推荐要研究tomcat源代码,看这本书是很有帮助的。
the5fire
2019/02/28
1.4K0
《Node.js 极简教程》 东海陈光剑
Once you have installed Node, let's try building our first web server. Create a file named "app.js", and paste the following code:
一个会写诗的程序员
2019/02/22
1.6K0
《Node.js 极简教程》  东海陈光剑
web服务器 Nginx
Web服务器是一台使用HTTP协议与客户机浏览器进行信息交流(因此又称为HTTP服务器)、为互联网客户提供服务(信息浏览,下载资源等)的主机。发展趋势:从HTML到XML、从有线到无线、从无声到有声
王念博客
2019/07/25
7.4K0
PHP命令行下的世界
PHP作为一门web开发语言,通常情况下我们都是在Web Server中运行PHP,使用浏览器访问,因此很少关注其命令行操作以及相关参数的使用,但是,特别是在类Unix操作系统上,PHP可以作为一门脚本语言执行与shell类似的处理任务。
用户2131907
2019/02/27
6920
[Linux CentOS7] Web服务器搭建和设置[通俗易懂]
请完成以下项目要求: 1、 安装Web服务器所需软件,设置服务器的IP为192.168.1.2 。
全栈程序员站长
2022/08/24
3.9K0
[Linux CentOS7] Web服务器搭建和设置[通俗易懂]
Web服务器-Nginx解决跨域问题
作者介绍:简历上没有一个精通的运维工程师。请点击上方的蓝色《运维小路》关注我,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。
运维小路
2025/04/20
1860
Web服务器-Nginx解决跨域问题
用Python建立最简单的web服务器
利用Python自带的包可以建立简单的web服务器。在DOS里cd到准备做服务器根目录的路径下,输入命令: python -m Web服务器模块 [端口号,默认8000] 例如: python -m SimpleHTTPServer 8080 然后就可以在浏览器中输入 http://localhost:端口号/路径
py3study
2020/01/10
9.7K1
用Go实现一个简单的Web服务器
Web服务器是现代互联网应用开发的重要组成部分,可以接收来自客户端的请求,并提供相应的响应。Go语言作为一种高性能的编程语言,广泛应用于Web开发领域。本文将详细介绍如何使用Go语言实现一个简单的Web服务器,并展示其基本功能和用法。
网络技术联盟站
2023/07/12
7290
14-1-网络芯片CH395Q学习开发-WEB服务器-网页到底是啥, web服务器是啥, 网页如何显示的显示图片和视频
<p><iframe name="ifd" src="https://mnifdv.cn/resource/cnblogs/LearnCH395Q" frameborder="0" scrolling="auto" width="100%" height="1500"></iframe></p>
杨奉武
2021/06/21
1.4K0
14-1-网络芯片CH395Q学习开发-WEB服务器-网页到底是啥, web服务器是啥, 网页如何显示的显示图片和视频
相关推荐
PHP之内置web服务器
更多 >
LV.0
这个人很懒,什么都没有留下~
目录
  • canvas 处理图像(上)
    • 1. 加载图像
    • 2. 调整和裁剪图像
      • 2.1 调整图像大小
      • 2.2 裁剪图像
      • 2.3 阴影
    • 3. 图像变形
      • 3.1 平移
      • 3.2 旋转
      • 3.3 缩放与翻转
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档