屬性或方法 | 基本描述 |
---|---|
font | 設(shè)置繪制文字所使用的字體,例如20px 宋體 ,默認(rèn)值為10px sans-serif 。該屬性的用法與css font屬性一致,例如italic bold 14px/30px Arial,宋體 |
fillStyle | 用于設(shè)置畫(huà)筆填充路徑內(nèi)部的顏色、漸變和模式。該屬性的值可以是一個(gè)表示CSS顏色值的字符串。如果你的繪制需求比較復(fù)雜,該屬性的值還可以是一個(gè)CanvasGradient 對(duì)象或者CanvasPattern 對(duì)象 |
strokeStyle | 用于設(shè)置畫(huà)筆繪制路徑的顏色、漸變和模式。該屬性的值可以是一個(gè)表示CSS顏色值的字符串。如果你的繪制需求比較復(fù)雜,該屬性的值還可以是一個(gè)CanvasGradient 對(duì)象或者CanvasPattern 對(duì)象 |
fillText(string text, int x, int y[, int maxWidth]) | 從指定坐標(biāo)點(diǎn)位置開(kāi)始繪制填充的文本文字。參數(shù)maxWidth 是可選的,如果文本內(nèi)容寬度超過(guò)該參數(shù)設(shè)置,則會(huì)自動(dòng)按比例縮小字體以適應(yīng)寬度。與本方法對(duì)應(yīng)的樣式設(shè)置屬性為fillStyle 。 |
strokeText(string text, int x, int y[, int maxWidth]) | 從指定坐標(biāo)點(diǎn)位置開(kāi)始繪制非填充的文本文字(文字內(nèi)部是空心的)。參數(shù)maxWidth 是可選的,如果文本內(nèi)容寬度超過(guò)該參數(shù)設(shè)置,則會(huì)自動(dòng)按比例縮小字體以適應(yīng)寬度。該方法與fillText() 用法一致,不過(guò)strokeText() 繪制的文字內(nèi)部是非填充(空心)的,fillText() 繪制的文字是內(nèi)部填充(實(shí)心)的。與本方法對(duì)應(yīng)的樣式設(shè)置屬性為strokeStyle 。 |
下面,我們先來(lái)看看如何使用canvas繪制實(shí)心文字,具體html代碼如下:
對(duì)應(yīng)的顯示效果如下:
接著,我們使其他環(huán)境條件均保持不變,再次使用strokeText()+strokeStyle方式來(lái)繪制上述示例中的文字,對(duì)應(yīng)的JavaScript代碼如下:
我們?cè)俅问褂脼g覽器訪問(wèn)頁(yè)面,將會(huì)看到如下顯示效果(效果圖片中的"CodePlayer"字樣其實(shí)也是空心的,只是由于字體較小導(dǎo)致兩側(cè)看起來(lái)重疊在了一起):
繪制圖片
在html5中,除了利用canvas繪制矢量圖形之外,我們還可以在canvas「畫(huà)布」上繪制現(xiàn)有的圖像文件。
首先,我們來(lái)看看使用canvas繪制圖像文件需要用到CanvasRenderingContext2D對(duì)象的哪些主要屬性和方法:
以canvas上指定的坐標(biāo)點(diǎn)開(kāi)始,按照?qǐng)D像的原始尺寸大小繪制整個(gè)圖像。這里的image可以是Image對(duì)象,也可以是Canvas對(duì)象(下同)。
以canvas上指定的坐標(biāo)點(diǎn)開(kāi)始,以指定的大小(width和height)繪制整個(gè)圖像,圖像將根據(jù)指定的尺寸自動(dòng)進(jìn)行相應(yīng)的縮放。
drawImage(mixed image, int imageX, int imageY, int imageWidth, int imageHeight, int canvasX, int canvasY, int canvasWidth, int canvasHeight)
將指定圖像的局部圖像(以(imageX, imageY)為左上角、寬度為imageWidth、高度為imageHeight的矩形部分)繪制到canvas中以(canvasX,canvasY)為左上角坐標(biāo)、寬度為canvasWidth、高度為canvasHeight的矩形區(qū)域中
是的,你沒(méi)有看錯(cuò)。要在canvas中繪制圖像,我們可以使用一個(gè)名為drawImage()的方法,不過(guò)該方法具有三種不同的變體,每個(gè)方法變體允許接收的參數(shù)不僅數(shù)量不同,連參數(shù)的含義也不盡相同。
在這里,我們對(duì)上述三個(gè)變體分別舉例說(shuō)明。
首先,我們使用drawImage()的第一個(gè)變體在canvas上繪制Google的logo圖片(原始尺寸為550 x 190)。
對(duì)應(yīng)的顯示效果如下:
由于Google的Logo圖像過(guò)大,超過(guò)了canvas的尺寸范圍,因此只能顯示出圖像的一部分。此時(shí),我們使用第2個(gè)變體將Google的logo圖像縮小到指定的寬度和高度,并繪制到canvas中。
我們將Google的logo圖像進(jìn)行縮放后,此時(shí)就可以在canvas中看到整個(gè)圖像了:
最后,我們使用第三個(gè)方法變體將Google logo中的"Goo"部分圖像繪制到canvas中("Goo"部分的圖像大小可以使用Photoshop等工具測(cè)量得出,這里直接使用測(cè)量后的結(jié)果)。
此時(shí),我們就可以看到canvas中顯示的"Goo"局部圖像了:
標(biāo)簽:甘南 蘇州 咸陽(yáng) 惠州 營(yíng)口 萍鄉(xiāng) 紅河 文山
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5 Canvas繪制文本及圖片的基礎(chǔ)教程》,本文關(guān)鍵詞 HTML5,Canvas,繪制,文本,及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。