搜尋
首頁web前端H5教程HTML5 canvas 基本語法_html5教學技巧

HTML 5 canvas —— 基本語法

簡述

5 規範引進了許多新特性,其中最令人期待的之一就是 元素。 HTML 5 提供了透過 JavaScript 繪製圖形的方法,此方法使用簡單但功能強大。每一個 元素都有一個"上下文( context )" (想像成繪圖板上的一頁),在其中可以繪製任意圖形。瀏覽器支援多個 canvas 上下文,並透過不同的 提供圖形繪製功能。 5 規範引進了許多新特性,其中最令人期待的之一就是 元素。 5 提供了透過 JavaScript 繪製圖形的方法,此方法使用簡單但功能強大。每一個 元素都有一個"上下文( context )" (想像成繪圖板上的一頁),在其中可以繪製任意圖形。瀏覽器支援多個 canvas 上下文,並透過不同的 提供圖形繪製功能。

大部分的瀏覽器都支援 2D canvas 上下文——包括 Opera, Firefox, Konqueror 和 Safari。而某些版本的 Opera 也支援 3D canvas ,Firefox 也可以透過插件形式支援 3D canvas :

  • 下載支援 3D canvas, HTML video 和 File I/O 的 Opera
  • Opera 3D canvas 上下文的文章
  • 關於 Firefox 3D canvas
    上下文的文章

本文介紹 2D canvas
基礎以及如何使用基本 canvas 函數,如線條、形狀、圖像和文字等。為了理解此文章,你最好了解 JavaScript 基礎知識。

可以點擊此處批次下載本文實例代碼

canvas 基礎

建立canvas 的方法很簡單,只需要在HTML 頁面中新增<font face="NSimsun"><canvas><code><font face="NSimsun"><canvas></canvas></font>元素:

<code><canvas id="myCanvas" width="300" height="150">
Fallback content, in case the browser does not support Canvas.
</canvas></code>

為了能在 JavaScript 中引用元素,最好給元素設定 ID ;也需要為 canvas 設定高度和寬度。

創建好了畫布後,讓我們來準備畫筆。要在畫布中繪製圖形需要使用 JavaScript 。先透過<font face="NSimsun"> getElementById<code><font face="NSimsun"> getElementById</font> 函數找到 canvas
元素,然後初始化上下文。之後可以使用上下文 API 繪製各種圖形。下面的腳本在 canvas 中繪製一個矩形 (點擊此處查看效果):

<code>// Get a reference to the element.
var elem = document.getElementById('myCanvas');

// Always check for properties 和 methods, to make sure your code doesn't break 
// in other browsers.
if (elem && elem.getContext) {
  // Get the 2d context.
  // Remember: you can only initialize one context per element.
  var context = elem.getContext('2d');
  if (context) {
    // You are done! Now you can draw your first rectangle.
    // You only need to provide the (x,y) coordinates, followed by the width and 
    // height dimensions.
    context.fillRect(0, 0, 150, 100);
  }
}</code>

可以把上面程式碼放置在文件 <font face="NSimsun">head<code><font face="NSimsun">head</font> 部分中,或是放在外部文件中。

2D context API

介紹如何建立 canvas 後,讓我們來看看 2D canvas API,看看能用這些函數做些什麼。

基本線條

上面的範例中展示了繪製矩形是多麼簡單。

透過 fillStylestrokeStyle 屬性可以輕鬆的設定矩形的填充和線條。顏色值使用方法和 十六進位數、()、() 和 ()( 若瀏覽器支持,如 Opera10 和 Firefox 3)。 十六進位數、()、() 和 ()( 若瀏覽器支持,如 Opera10 和 Firefox 3)。

透過 <font face="NSimsun">fillRect<code><font face="NSimsun">fillRect</font> 可以繪製有填充的矩形。使用 <font face="NSimsun">strokeRect<code><font face="NSimsun">strokeRect</font> 可以繪製只有邊框沒有填滿的矩形。如果想要清除部分 canvas 可以使用 <font face="NSimsun">clearRect<code><font face="NSimsun">clearRect</font>。上述三種方法的參數相同:x, y, width, height。前兩個參數設定 (x,y) 座標,後兩個參數設定矩形的高度和寬度。

可以使用 lineWidth 屬性來改變線條粗細。讓我們來看看使用了<font face="NSimsun">fillRect<code><font face="NSimsun">fillRect</font>,
<font face="NSimsun">strokeRect<code><font face="NSimsun">strokeRect</font> <font face="NSimsun">clearRect<code><font face="NSimsun">clearRect</font> 和其他的例子:

<code>context.fillStyle   = '#00f'; // blue
context.strokeStyle = '#f00'; // red
context.lineWidth   = 4;

// Draw some rectangles.
context.fillRect  (0,   0, 150, 50);
context.strokeRect(0,  60, 150, 50);
context.clearRect (30, 25,  90, 60);
context.strokeRect(30, 25,  90, 60);</code>

此範例效果圖見圖1.

Example render of fillRect, strokeRect and clearRect.

圖 1: fillRect, strokeRect 和
clearRect效果圖

路徑

透過 canvas 路徑(path)可以繪製任意形狀。可以先繪製輪廓,然後繪製邊框和填滿。建立自訂形狀很簡單,使用<font face="NSimsun"> beginPath()<code><font face="NSimsun"> beginPath()</font>開始繪製,然後使用直線、曲線和其他圖形繪製你的圖形。繪製完畢後呼叫<font face="NSimsun">fill<code><font face="NSimsun">fill</font><font face="NSimsun">stroke<code><font face="NSimsun">stroke</font> 即可新增填充或設定邊框。呼叫<font face="NSimsun"> closePath()<code><font face="NSimsun"> closePath()</font> 結束自訂圖形繪製。

下面是一個繪製三角形的例子:

<code>// Set the style properties.
context.fillStyle   = '#00f';
context.strokeStyle = '#f00';
context.lineWidth   = 4;

context.beginPath();
// Start from the top-left point.
context.moveTo(10, 10); // give the (x,y) coordinates
context.lineTo(100, 10);
context.lineTo(10, 100);
context.lineTo(10, 10);

// Done! Now fill the shape, 和 draw the stroke.
// Note: your shape will not be visible until you call any of the two methods.
context.fill();
context.stroke();
context.closePath();</code>

其效果圖見圖2.

HTML5 canvas 基本語法_html5教學技巧

图 2: 三角形

另一个较负责的例子中使用了直线、曲线和圆弧。

插入图像

<font face="NSimsun">drawImage</font> 方法允许在 canvas 中插入其他图像
(<font face="NSimsun"> img</font><font face="NSimsun">canvas</font> 元素) 。在 Opera 中可以再 canvas 中绘制 SVG 图形。此方法比较复杂,可以有3个、5个或9个参数:

  • 3个参数:最基本的 <font face="NSimsun">drawImage</font> 使用方法。一个参数指定图像位置,另两个参数设置图像在 canvas中的位置。
  • 5个参数:中级的 <font face="NSimsun">drawImage</font> 使用方法,包括上面所述3个参数,加两个参数指明插入图像宽度和高度 (如果你想改变图像大小)。
  • 9个参数:最复杂 <font face="NSimsun">drawImage</font> 杂使用方法,包含上述5个参数外,另外4个参数设置源图像中的位置和高度宽度。这些参数允许你在显示图像前动态裁剪源图像。

下面是上述三个使用方法的例子:

<code>// Three arguments: the element, destination (x,y) coordinates.
context.drawImage(<var>img_elem</var>, <var>dx</var>, <var>dy</var>);

// Five arguments: the element, destination (x,y) coordinates, and destination 
// width and height (if you want to resize the source image).
context.drawImage(<var>img_elem</var>, <var>dx</var>, <var>dy</var>, <var>dw</var>, <var>dh</var>);

// Nine arguments: the element, source (x,y) coordinates, source width and 
// height (for cropping), destination (x,y) coordinates, and destination width 
// and height (resize).
context.drawImage(<var>img_elem</var>, <var>sx</var>, <var>sy</var>, <var>sw</var>, <var>sh</var>, <var>dx</var>, <var>dy</var>, <var>dw</var>, <var>dh</var>);</code>

其效果见图3.

Example rendering of drawImage.

图 3: <font face="NSimsun">drawImage</font> 效果图。

像素级操作

2D Context API 提供了三个方法用于像素级操作:<font face="NSimsun">createImageData</font>, <font face="NSimsun">getImageData</font>, 和
<font face="NSimsun">putImageData</font>

<font face="NSimsun">ImageData</font>对象保存了图像像素值。每个对象有三个属性: width, height
datadata 属性类型为CanvasPixelArray,用于储存<font face="NSimsun"><var>width</var>*<var>height</var>*4</font>个像素值。每一个像素有RGB值和透明度alpha值(其值为 0 至
255,包括alpha在内!)。像素的顺序从左至右,从上到下,按行存储。

为了更好的理解其原理,让我们来看一个例子——绘制红色矩形

<code>// Create an ImageData object.
var imgd = context.createImageData(50,50);
var pix = imgd.data;

// Loop over each pixel 和 set a transparent red.
for (var i = 0; n = pix.length, i </code>

注意: 不是所有浏览器都实现了<font face="NSimsun"> createImageData</font>。在支持的浏览器中,需要通过<font face="NSimsun"> getImageData</font> 方法获取<font face="NSimsun"> ImageData</font> 对象。请参考示例代码。

通过 <font face="NSimsun">ImageData</font> 可以完成很多功能。如可以实现图像滤镜,或可以实现数学可视化 (如分形和其他特效)。下面特效实现了简单的颜色反转滤镜:

<code>// Get the <code>CanvasPixelArray</code> from the given coordinates and dimensions.
var imgd = context.getImageData(<var>x</var>, <var>y</var>, <var>width</var>, <var>height</var>);
var pix = imgd.data;

// Loop over each pixel and invert the color.
for (var i = 0, n = pix.length; i ImageData</code> at the given (x,y) coordinates.
context.putImageData(imgd, <var>x</var>, <var>y</var>);

图 4 显示了使用此滤镜后的 Opera
图像 (图 3是原图)。

Example rendering of the invert color filter.

图 4: 颜色反转滤镜

文字

虽然最近的 WebKit 版本和 Firefox 3.1 nightly build 才开始支持 Text API ,为了保证文章完整性我决定仍在这里介绍文字 API 。

<font face="NSimsun">context</font> 对象可以设置以下 text 属性:

  • <font face="NSimsun">font</font>:文字字体,同属性 属性
  • <font face="NSimsun">textAlign</font>:文字水平对齐方式。可取属性值: <font face="NSimsun">start</font>, <font face="NSimsun">end</font>, <font face="NSimsun">left</font>,
    <font face="NSimsun">right</font>, <font face="NSimsun">center</font>。默认值:
    <font face="NSimsun">start</font>.
  • <font face="NSimsun">textBaseline</font>:文字竖直对齐方式。可取属性值:<font face="NSimsun">top</font>, <font face="NSimsun">hanging</font>, <font face="NSimsun">middle</font>,
    <font face="NSimsun">alphabetic</font>, <font face="NSimsun">ideographic</font>, <font face="NSimsun">bottom</font>。默认值:<font face="NSimsun">alphabetic</font>.

有两个方法可以绘制文字: <font face="NSimsun">fillText</font><font face="NSimsun">strokeText</font>。第一个绘制带 fillStyle 填充的文字,后者绘制只有 strokeStyle 边框的文字。两者的参数相同:要绘制的文字和文字的位置(x,y) 坐标。还有一个可选选项——最大宽度。如果需要的话,浏览器会缩减文字以让它适应指定宽度。

文字对齐属性影响文字与设置的
(x,y) 坐标的相对位置。

下面是一个在 canvas 中绘制"hello world" 文字的例子

<code>context.fillStyle    = '#00f';
context.font         = 'italic 30px sans-serif';
context.textBaseline = 'top';
context.fillText  ('Hello world!', 0, 0);
context.font         = 'bold 30px sans-serif';
context.strokeText('Hello world!', 0, 50);</code>

图 5 是其效果图。

Example text render.

图 5: 文字效果

阴影

目前只有 Konqueror 和 Firefox 3.1 nightly build 支持 Shadows API 。API 的属性为:

  • <font face="NSimsun">shadowColor</font>:阴影颜色。其值和 CSS 颜色值一致。
  • <font face="NSimsun">shadowBlur</font>:设置阴影模糊程度。此值越大,阴影越模糊。其效果和 Photoshop 的高斯模糊滤镜相同。
  • <font face="NSimsun">shadowOffsetX</font><font face="NSimsun">shadowOffsetY</font>:阴影的 x 和 y 偏移量,单位是像素。

下面是 canvas 阴影的例子:

<code>context.shadowOffsetX = 5;
context.shadowOffsetY = 5;
context.shadowBlur    = 4;
context.shadowColor   = 'rgba(255, 0, 0, 0.5)';
context.fillStyle     = '#00f';
context.fillRect(20, 20, 150, 100);</code>

其效果见图 6。

Example canvas shadow - a blue rectangle with a red shadow.

图 6: canvas 阴影效果——蓝色矩形,红色阴影

颜色渐变

除了 CSS 颜色,<font face="NSimsun"> fillStyle</font><font face="NSimsun">strokeStyle</font> 属性可以设置为 <font face="NSimsun">CanvasGradient</font> 对象。——通过 <font face="NSimsun">CanvasGradient</font>可以为线条和填充使用颜色渐变。

欲创建 <font face="NSimsun">CanvasGradient</font> 对象,可以使用两个方法:<font face="NSimsun">createLinearGradient</font><font face="NSimsun">createRadialGradient</font>。前者创建线性颜色渐变,后者创建圆形颜色渐变。

创建颜色渐变对象后,可以使用对象的 <font face="NSimsun">addColorStop</font> 方法添加颜色中间值。

下面的代码演示了颜色渐变使用方法:

<code>// You need to provide the source 和 destination (x,y) coordinates 
// for the gradient (from where it starts 和 where it ends).
var gradient1 = context.createLinearGradient(<var>sx</var>, <var>sy</var>, <var>dx</var>, <var>dy</var>);

// Now you can add colors in your gradient.
// The first argument tells the position for the color in your gradient. The 
// accepted value range is from 0 (gradient start) to 1 (gradient end).
// The second argument tells the color you want, using the CSS color format.
gradient1.addColorStop(0,   '#f00'); // red
gradient1.addColorStop(0.5, '#ff0'); // yellow
gradient1.addColorStop(1,   '#00f'); // blue

// For the radial gradient you also need to provide source
// 和 destination circle radius.
// The (x,y) coordinates define the circle center points (start 和 
// destination).
var gradient2 = context.createRadialGradient(<var>sx</var>, <var>sy</var>, <var>sr</var>, <var>dx</var>, <var>dy</var>, <var>dr</var>);

// Adding colors to a radial gradient is the same as adding colors to linear 
// gradients.</code>

我也准备了一个更复杂的例子,使用了线性颜色渐变、阴影和文字。其效果见图 7。

Example rendering using a linear gradient.

图 7: 使用线性颜色渐变的例子

canvas 演示

如果你想知道使用 Canvas可以做些什么,可以参看以下的工程:

  • Opera Widget:
    • SimAquarium
    • Artist's
      Sketchbook
    • Spirograph
  • 在线工程和演示
    • Newton polynomial
    • Canvascape - "3D Walker"
    • Paint.Web - painting
      demo, open-source
    • Star-field
      flight
    • Interactive blob

小节

Canvas 是 HTML 5最让人期待的特性之一,目前已获得大部分 Web 浏览器支持。Canvas 可以帮助创建游戏、增强图形用户界面。2D context
API 提供大量图形绘制功能——我希望通过本文你了解了 canvas 使用,并且你有兴趣了解更多!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
H5:網絡標準和技術的發展H5:網絡標準和技術的發展Apr 15, 2025 am 12:12 AM

Web标准和技术从HTML4、CSS2和简单的JavaScript演变至今,经历了显著的发展。1)HTML5引入了Canvas、WebStorage等API,增强了Web应用的复杂性和互动性。2)CSS3增加了动画和过渡功能,使页面效果更加丰富。3)JavaScript通过Node.js和ES6的现代化语法,如箭头函数和类,提升了开发效率和代码可读性,这些变化推动了Web应用的性能优化和最佳实践的发展。

H5是HTML5的速記嗎?探索細節H5是HTML5的速記嗎?探索細節Apr 14, 2025 am 12:05 AM

H5不僅僅是HTML5的簡稱,它代表了一個更廣泛的現代網頁開發技術生態:1.H5包括HTML5、CSS3、JavaScript及相關API和技術;2.它提供更豐富、互動、流暢的用戶體驗,能在多設備上無縫運行;3.使用H5技術棧可以創建響應式網頁和復雜交互功能。

H5和HTML5:網絡開發中常用的術語H5和HTML5:網絡開發中常用的術語Apr 13, 2025 am 12:01 AM

H5與HTML5指的是同一個東西,即HTML5。 HTML5是HTML的第五個版本,帶來了語義化標籤、多媒體支持、畫布與圖形、離線存儲與本地存儲等新功能,提升了網頁的表現力和交互性。

H5指的是什麼?探索上下文H5指的是什麼?探索上下文Apr 12, 2025 am 12:03 AM

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

H5:工具,框架和最佳實踐H5:工具,框架和最佳實踐Apr 11, 2025 am 12:11 AM

H5開發需要掌握的工具和框架包括Vue.js、React和Webpack。 1.Vue.js適用於構建用戶界面,支持組件化開發。 2.React通過虛擬DOM優化頁面渲染,適合複雜應用。 3.Webpack用於模塊打包,優化資源加載。

HTML5的遺產:當前了解H5HTML5的遺產:當前了解H5Apr 10, 2025 am 09:28 AM

HTML5hassignificantlytransformedwebdevelopmentbyintroducingsemanticelements,enhancingmultimediasupport,andimprovingperformance.1)ItmadewebsitesmoreaccessibleandSEO-friendlywithsemanticelementslike,,and.2)HTML5introducednativeandtags,eliminatingthenee

H5代碼:可訪問性和語義HTMLH5代碼:可訪問性和語義HTMLApr 09, 2025 am 12:05 AM

H5通過語義化元素和ARIA屬性提升網頁的可訪問性和SEO效果。 1.使用、、等元素組織內容結構,提高SEO。 2.ARIA屬性如aria-label增強可訪問性,輔助技術用戶可順利使用網頁。

H5與HTML5相同嗎?H5與HTML5相同嗎?Apr 08, 2025 am 12:16 AM

"h5"和"HTML5"在大多數情況下是相同的,但它們在某些特定場景下可能有不同的含義。 1."HTML5"是W3C定義的標準,包含新標籤和API。 2."h5"通常是HTML5的簡稱,但在移動開發中可能指基於HTML5的框架。理解這些區別有助於在項目中準確使用這些術語。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。