`
guoyiqi
  • 浏览: 1016339 次
社区版块
存档分类
最新评论

HTML5 canvas变换

 
阅读更多

 

 

2.2.3 变换

现在我们探讨一下在canvas上绘制图像的另一种方式--使用变换(transformation)。接下来的代码清单显示结果跟上

面是一样的,只是绘制对角线的代码不一样。这个简单示例可能会让你误认为使用变换增加了不必要的复杂性。事实并非

如此,其实变换是实现复杂canvas操作的最好方式。在后面的示例中将会看到,我们使用了大量的变换,而这对熟悉

HTML5 Canvas API的复杂功能是至关重要的。

 

也许了解变换最简单的方法(至少这种方法不涉及大量的数学公式,也不需手足并用地去解释)就是把它当成是介于

开发人员发出的指令和canvas显示结果之间的一个修正层(modification layer)。不管在开发中是否使用变换,

修正层始终都是存在的。

 

修正--在绘制系统中的说法是变换--在应用的时候可以被顺序应用、组合或者随意修改。每个绘制操作的结果显示

在canvas上之前都要经过修正层去做修正。虽然这么做增加了额外的复杂性,但却为绘制系统添加了更为强大的

功能,可以像目前主流图像编辑工具那样支持实时图像处理,所以API中这部分内容的复杂性是必要的。

 

不在代码中调用变换函数并不意味着可以提升canvas的性能。canvas在执行的时候,变换会被呈现引擎

隐式调用,这与开发人员是否直接调用无关。在接触最基本的绘制操作之前,提前了解系统背后的原理至关

重要。

 

关于可重用代码有一条重要的建议:一般绘制都应从原点(坐标系中的0,0点)开始,

应用变换(缩放、平移、旋转等),然后不断修改代码直至达到希望的效果。如图2-4所示。

 

代码清单2-7展示了如何使用最简单变换方法--translate函数。

 
(点击查看大图)图2-4 基于原点绘制和变换的示意图
代码清单2-7 用变换的方式在canvas上绘制对角线
  1. <script> 
  2.   function drawDiagonal() {  
  3.     var canvas = document.getElementById('diagonal');  
  4.     var context = canvas.getContext('2d');  
  5.  
  6.     // 保存当前绘图状态  
  7.     context.save();  
  8.  
  9.     // 向右下方移动绘图上下文  
  10.     context.translate(70, 140);  
  11.  
  12.     // 以原点为起点,绘制与前面相同的线段  
  13.     context.beginPath();  
  14.     context.moveTo(0, 0);  
  15.     context.lineTo(70, -70);  
  16.     context.stroke();  
  17.  
  18.     // 恢复原有的绘图状态  
  19.     context.restore();  
  20.   }  
  21.  
  22.   window.addEventListener("load", drawDiagonal, true);  
  23. </script> 

我们详细研究一下上面这段通过平移方式绘制对角线的JavaScript代码。

(1) 首先,通过ID找到并访问canvas对象。(ID是diagonal。)

 

(2) 接着通过调用canvas对象的getContext函数获取上下文对象。

 

(3) 接下来,保存尚未修改的context,这样即使进行了绘制和变换操作,

也可以恢复到初始状态。如果不保存,那么在进行了平移和缩放等操作以后,

其影响会带到后续的操作中,而这不一定是我们所希望的。在变换前保存context状态可以方便以后恢复。

 

(4) 下一步是在context中调用translate函数。通过这个操作,当平移行为发生的时候,

我们提供的变换坐标会被加到结果坐标(对角线)上,结果就是将要绘制的对角线移动到

了新的位置上。不过,对角线呈现在canvas上是在绘制操作结束之后。

 

(5) 应用平移后,就可以使用普通的绘制操作来画对角线了。代码清单中调用了

三个函数来绘制对角线--beginPath、moveTo以及lineTo。绘制的起点是

原点(0,0),而非坐标点(70,140)。

 

(6) 在线条勾画出来之后,可以通过调用context.stroke()函数将其显示在canvas上。

 

(7) 最后,恢复context至原始状态,这样后续的canvas操作就不会被刚才的平移

操作影响了。图2-5显示了用这段代码绘制的对角线。

 

虽然新绘制的对角线看起来跟前面的一模一样,但这次绘制使用了强大的变换功能。

学习完本章接下来的内容,就会明白变换的强大之处。

 

 
图2-5 canvas上平移过的对角线
分享到:
评论

相关推荐

    html5 canvas文字变换切换特效

    在这个特定的案例中,“html5 canvas文字变换切换特效”是一种利用Canvas API实现的文字动画效果,当用户点击文字时,文字会发生变换,提供一种视觉上的交互体验。 在Canvas中,文字的绘制主要通过`fillText()`和`...

    HTML5 Canvas核心技术代码

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,创造出丰富的交互式用户体验。Canvas API提供了大量的方法和属性,使得JavaScript可以直接控制像素级别的图像操作。这个压缩包...

    html5 canvas酷炫3D文字变换动画特效

    在“html5 canvas酷炫3D文字变换动画特效”这个主题中,我们将深入探讨如何利用Canvas API创建引人注目的3D文字动画效果。 1. **HTML5 Canvas基础** - HTML5 Canvas是一个基于矢量图形的画布,通过JavaScript来...

    HTML5 Canvas五彩缤纷的3D发光水晶球动画

    HTML5 Canvas是一个强大的Web图形库,它允许开发者在网页上直接用JavaScript绘制图像,从而创建出丰富的交互式2D和3D图形。在这个名为“HTML5 Canvas五彩缤纷的3D发光水晶球动画”的项目中,我们将深入探讨如何利用...

    HTML5 Canvas核心技术—图形、动画与游戏开发一书源代码

    HTML5 Canvas是Web开发中的一个关键技术,它提供了一个在网页上绘制图形的API,使得开发者可以直接在浏览器中创建丰富的交互式2D图形、动画以及游戏。"HTML5 Canvas核心技术—图形、动画与游戏开发"这本书深入浅出地...

    html5 canvas文字变换切换特效.zip

    在这个"html5 canvas文字变换切换特效.zip"压缩包中,包含了一个使用Canvas实现的文字变换和切换特效。这个特效代码可能是利用HTML5 Canvas API结合jQuery库来创建的,使得文字动画效果更加流畅和吸引人。 首先,...

    html5 canvas核心技术

    HTML5 Canvas是Web开发中的一个关键技术,它提供了一个在网页上动态绘制图形的API。Canvas元素允许开发者通过JavaScript代码直接在浏览器中绘制2D图像,为网页应用带来了丰富的交互性和创新性。本核心教程由David ...

    HTML5 Canvas全屏背景动画特效

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,创造出丰富的视觉效果。在这个“HTML5 Canvas全屏背景动画特效”的主题中,我们将深入探讨如何利用Canvas来创建引人注目的全屏动画...

    HTML5 Canvas

    HTML5 Canvas是HTML5标准中的一个关键特性,它为网页提供了强大的绘图能力,使得开发者可以直接在浏览器上进行图形绘制,创造出丰富的动态视觉效果。这个经典学习教程将深入讲解Canvas的各个方面,帮助初学者和进阶...

    Foundation HTML5 Canvas For Games and Entertainment

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,为游戏和娱乐应用提供了丰富的可能性。这本书"Foundation HTML5 Canvas For Games and Entertainment"深入浅出地探讨了如何利用...

    HTML5 Canvas核心技术—图形、动画与游戏开发【扫描版PDF(71M)+试读章节+源码】

    HTML5 Canvas是现代Web开发中的一个关键特性,它允许开发者在网页上绘制矢量图形、动态图像和创建复杂的动画。本书“HTML5 Canvas核心技术—图形、动画与游戏开发”深入探讨了这一技术的核心概念和实践应用,对于想...

    html5 canvas可拖放互动的照片墙插件

    HTML5 Canvas是HTML5标准中的一个关键特性,它为网页提供了在浏览器中绘制图形的能力,类似于画布。这款“html5 canvas可拖放互动的照片墙插件”利用了Canvas的强大功能,创建了一个允许用户交互的动态照片展示平台...

    HTML5 Canvas酷炫可视化音频动画特效

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,创造出丰富的交互式2D和3D视觉效果。在这个特定的项目中,“HTML5 Canvas酷炫可视化音频动画特效”是一个利用Canvas API来实现的...

    HTML5 canvas 3D文字云动画

    HTML5的canvas元素是网页开发中的一个强大工具,它提供了在浏览器端进行2D和3D图形绘制的能力,无需依赖任何插件。在这个"HTML5 canvas 3D文字云动画"项目中,开发者利用canvas结合JavaScript实现了引人注目的视觉...

    html5 canvas生成全景图片360度展示特效

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,创造出丰富的交互式用户体验。在这个特定的场景中,我们讨论的是如何使用Canvas实现全景图片的360度展示特效。全景图是一种能够展示...

    HTML5 Canvas 游戏开发实战PDF+源码

    HTML5 Canvas是Web开发中的一个强大工具,它允许开发者在网页上进行动态图形绘制,为交互式游戏、数据可视化和多媒体应用提供了无限可能。在这个"HTML5 Canvas 游戏开发实战"项目中,我们将深入探讨如何利用Canvas ...

    使用HTML5 Canvas绘制 3D房间模型和人物动画特效

    HTML5 Canvas本身并不支持3D,但可以通过一些技巧模拟3D效果,如使用矩阵变换进行投影和旋转,以及利用Z-buffer(深度缓冲)来处理遮挡关系。 1. 矩阵变换:通过矩阵运算实现物体的平移、旋转和缩放,是3D图形中的...

    html5 canvas中文文档

    ### HTML5 Canvas中文文档知识点详解 #### 一、Canvas声明与获取 - **CanvasHtml声明** HTML5中的`&lt;canvas&gt;`元素用于在网页上绘制图形,它本身不具有绘图能力,而是通过JavaScript来控制绘图。一个基本的`...

Global site tag (gtag.js) - Google Analytics