`

canvas入门详解

阅读更多

html5是新兴的网页技术标准

 

目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox、Chrome、Opera、Safari、IE9+)都已经开始支持html5了。

 

众所周知,html5中增加了许多新特性。在html5的众多特性中,Canvas应该算是最引人注目的新特性之一。我们使用html5的Canvas对象可以直接在浏览器的网页上绘制图形。这意味着浏览器可以脱离Flash等第三方插件,直接在网页上显示图形或动画。

 

 

现在,我们就来为html5初学者介绍如何使用html5 Canvas绘制基本的图形。

首先,我们需要准备如下html基础代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5 Canvas入门示例</title>
</head>
<body>

</body>
</html>

 上述代码是一个html5页面的基本代码模板。

其中,第一行代码<!DOCTYPE html>是一个文档类型标签指令,这也是html5页面的标准文档类型指令,用于告诉浏览器「这是一个html5页面,请按照html5的网页标准来解析显示该页面」。

第4行代码<meta charset="UTF-8">用于告诉浏览器「这个html5页面的字符编码为UTF-8」,这也是html5网页设置字符编码的标准写法。这与以往的html字符编码指令有所不同。

<!-- 以往的html字符编码指令如下 -->
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">

 

现在,我们就在包含上述代码的html文件中进行Canvas绘制图形的实例讲解。首先,我们在上述html代码的body部分添加如下canvas标签。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5 Canvas入门示例</title>
</head>
<body>
<!-- 添加canvas标签,并加上红色边框以便于在页面上查看效果 -->
<canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">
您的浏览器不支持canvas标签。
</canvas>
</body>
</html>

 

此时,我们使用支持html5的浏览器打开该页面,将会看到如下内容:

canvas标签显示效果canvas标签显示效果

在html5中,canvas标签本身并没有任何行为,仅仅只是在页面上占用指定大小的页面空白空间。canvas标签就相当于一块空白的画布,还需要我们自己使用JavaScript提供的canvas API编写相应的代码从而在这块画布上绘制出我们想要的图形。

备注:canvas标签体内的文字内容将会在不支持html5的浏览器中显示。如上
述html代码所示,如果你的浏览器不支持html5的canvas标签,那么将会在canvas标签处显示
文字「您的浏览器不支持canvas标签」。

 

作为「画家」的我们,首先需要熟悉我们手中的画笔,也就是JavaScript中的Canvas对象及其相关内容。

在html5中,一个canvas标签就对应一个Canvas对象,我们在JavaScript可以使用document.getElementById()等常规函数来获取该对象。值得注意的是,在JavaScript中,我们并不是直接操作Canvas对象,而是通过Canvas对象来获取对应的图形绘制上下文对象CanvasRenderingContext2D,然后我们再利用CanvasRenderingContext2D对象自带的许多绘制图形的函数来绘图。

这就好像是每一张画布都对应一支画笔,要想在画布上绘画,我们就先要拿到对应的画笔,然后使用这支画笔在画布上绘图。CanvasRenderingContext2D对象就相当于这支画笔。现在,我们就先来尝试在JavaScript中拿到这支画笔。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5 Canvas绘制线条入门示例</title>
</head>
<body>
<!-- 添加canvas标签,并加上红色边框以便于在页面上查看效果 -->
<canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">
您的浏览器不支持canvas标签。
</canvas>
<script type="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");
}
</script>
</body>
</html>

 

如上述代码所示,我们可以使用Canvas对象的getContext()方法来获取CanvasRenderingContext2D对象。比较细心的读者应该注意到了:getContext()方法需要传入一个字符串——2d,获取到的CanvasRenderingContext2D对象的名称中也带有2D。这是因为,目前html5只支持2D绘图,但是在未来的html5中也可能支持3D或其他形式的绘图。届时,我们可能就需要使用getContext("3d")来获取CanvasRenderingContext3D对象并绘制3D图形了。

  

 

注意点:【①Math.PI是JavaScript中表示π的常量,Math.PI /2为90°,Math.PI*2为360°

 

分享到:
评论

相关推荐

    《Html5 Canvas开发详解》示例代码

    这本书《Html5 Canvas开发详解》第二版提供了详细的示例代码,帮助学习者深入理解Canvas的用法和技巧。我们将逐一探讨每个章节的可能涵盖的知识点。 1. **第一章**: 基础入门 这一章通常会介绍Canvas的基本概念,...

    canvas简单实例详解

    这个“canvas简单实例详解”将带你深入了解Canvas的基本用法和常见操作,为你的网页开发添加丰富的视觉效果。 一、Canvas基本结构 Canvas元素在HTML中以`&lt;canvas&gt;`标签表示,可以通过ID来引用并进行JavaScript操作...

    2.1 canvas绘图章节课程介绍|canvas绘图详解|Canvas图形、动画、游戏开发从入门到精通全系列课程

    2.1_canvas绘图章节课程介绍|canvas绘图详解|Canvas图形、动画、游戏开发从入门到精通全系列课程

    1.16 canvas小结之下个阶段canvas绘图详解内容提前预告|倒计时粒子效果|Canvas图形、动画、游戏开发从入门到精通全系列课程

    1.16_canvas小结之下个阶段canvas绘图详解内容提前预告|倒计时粒子效果|Canvas图形、动画、游戏开发从入门到精

    5.5 CSS3中filter属性详解|模糊效果和filter|canvas项目综合实战|Canvas图形、动画、游戏开发从入门到精通全系列课程

    5.5_CSS3中filter属性详解|模糊效果和filter|canvas项目综合实战|Canvas图形、动画、游戏开发从入门

    Android入门到精通详解(完整书签)

    ### Android入门到精通详解知识点概览 #### 第一篇:Android系统结构和SDK使用 ##### 第1章:Android的系统介绍 - **系统介绍**:Android是Google开发的一款基于Linux平台的开源操作系统,专为移动设备设计。它...

    3.3 drawImage的参数详解|Canvas图像基础|Canvas图形、动画、游戏开发从入门到精通全系列课程

    3.3_drawImage的参数详解|Canvas图像基础|Canvas图形、动画、游戏开发从入门到精通全系列课程

    HTML5与CSS3基础教程(第8版)中文高清版

    自第1版至今,一直是讲解HTML和CSS入门知识的经典畅销书,全面系统地阐述HTML5和CSS3基础知识以及实际运用技术,通过大量实例深入浅出地分析了网页制作的方方面面。最新第8版不仅介绍了文本、图像、链接、列表、表格...

    Google Android入门到精通详解

    ### Google Android 入门到精通详解 #### 第一篇 Android系统结构和SDK使用 **1.1 系统介绍** Android是由Google开发的一款基于Linux内核的开源操作系统,它专为移动设备设计,如智能手机和平板电脑等。Android...

    Android入门到精通详解.pdf

    ### Android入门到精通详解知识点概览 #### 一、Android系统结构和SDK使用 ##### 1.1 系统介绍 - **定义**: Android是由Google公司开发的一款基于Linux内核的开源操作系统,专为移动设备设计。 - **组成**: - **...

    HTML5 Canvas cookbook

    #### 四、主要内容及知识点详解 ##### 4.1 基础概念与入门 - **Canvas 元素**:介绍 `&lt;canvas&gt;` 标签的基本属性和使用方法。 - **坐标系统**:讲解 Canvas 的坐标系统,如何设置画布的尺寸以及原点的位置。 - **...

    HTML5学习文档汇总

    此外,指南可能还涉及了离线存储(离线存储API)、拖放功能(Drag and Drop API)以及Canvas和SVG等图形绘制技术。 其次,“[HTML+5+从入门到精通]”可能是一本针对初学者的教程,从最基础的HTML5语法开始,逐步...

    Flutter完整开发实战详解 PDF

    9. 深入绘制原理:深入探讨如何自定义绘制和Canvas API。 10. 深入图片加载流程:分析图片加载库的工作原理,优化图片显示性能。 11. 全面深入理解Stream:介绍Dart中的Stream概念,如何处理实时数据流。 12. 全面...

    Android自定义组件开发详解.docx

    【Android自定义组件开发详解】 Android自定义组件的开发是Android应用开发中的一个重要部分,它涉及到自定义View和ViewGroup的创建,以及对canvas和paint的深入理解和运用。自定义组件能够满足开发者对于UI设计的...

    Java手机程序设计入门11

    ### Java手机程序设计入门:MIDP图形处理详解 #### 引言 MIDP(Mobile Information Device Profile)是Java ME平台的一部分,专为移动设备如手机和平板电脑设计。对于初学者而言,掌握MIDP图形处理技术是至关重要...

    Android入门之画图详解

    本文将深入解析Android入门级别的画图技术,帮助初学者理解和掌握如何在屏幕上绘制图形。 首先,我们来看看画图涉及的核心组件: 1. **Bitmap**:Bitmap是Android中的一个关键类,它代表了图像数据,可以是从资源...

    《J2ME手机游戏开发技术详解》

    总之,《J2ME手机游戏开发技术详解》是一本全面的指南,涵盖了从入门到高级的J2ME游戏开发技术,对于那些想踏入移动游戏开发领域的人来说,是一本不可多得的参考资料。尽管现在J2ME在智能机市场已被其他平台取代,但...

    Flash从入门到精通全套视频下载

    4. 动画原理:详解补间动画和关键帧动画的区别,以及如何创建基本的运动和形状补间。 5. 脚本基础:介绍ActionScript,学习基本的变量、函数和条件语句,为动态交互打下基础。 6. 音频与视频:插入和编辑音频、视频...

Global site tag (gtag.js) - Google Analytics