溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

HTML5 Canvas怎么繪制文本及圖片

發(fā)布時(shí)間:2021-08-10 14:39:32 來源:億速云 閱讀:170 作者:chen 欄目:web開發(fā)

這篇文章主要講解了“HTML5 Canvas怎么繪制文本及圖片”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“HTML5 Canvas怎么繪制文本及圖片”吧!

繪制文本

在HTML5中,我們還可以在Canvas「畫布」上繪制我們所需的文本文字,其中所涉及到的CanvasRenderingContext2D對(duì)象的主要屬性和方法如下:

屬性或方法基本描述
font設(shè)置繪制文字所使用的字體,例如20px 宋體,默認(rèn)值為10px sans-serif。該屬性的用法與css font屬性一致,例如italic bold 14px/30px Arial,宋體
fillStyle用于設(shè)置畫筆填充路徑內(nèi)部的顏色、漸變和模式。該屬性的值可以是一個(gè)表示CSS顏色值的字符串。如果你的繪制需求比較復(fù)雜,該屬性的值還可以是一個(gè)CanvasGradient對(duì)象或者CanvasPattern對(duì)象
strokeStyle用于設(shè)置畫筆繪制路徑的顏色、漸變和模式。該屬性的值可以是一個(gè)表示CSS顏色值的字符串。如果你的繪制需求比較復(fù)雜,該屬性的值還可以是一個(gè)CanvasGradient對(duì)象或者CanvasPattern對(duì)象
fillText(string text, int x, int y[, int maxWidth])從指定坐標(biāo)點(diǎn)位置開始繪制填充的文本文字。參數(shù)maxWidth是可選的,如果文本內(nèi)容寬度超過該參數(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)位置開始繪制非填充的文本文字(文字內(nèi)部是空心的)。參數(shù)maxWidth是可選的,如果文本內(nèi)容寬度超過該參數(shù)設(shè)置,則會(huì)自動(dòng)按比例縮小字體以適應(yīng)寬度。該方法與fillText()用法一致,不過strokeText()繪制的文字內(nèi)部是非填充(空心)的,fillText()繪制的文字是內(nèi)部填充(實(shí)心)的。與本方法對(duì)應(yīng)的樣式設(shè)置屬性為strokeStyle


從上面的API描述信息中我們可以得知,在Canvas中可以使用兩種方式來繪制文本文字:一種是使用fillText()+fillStyle來繪制填充(實(shí)心)的文字;一種是使用strokeText()+strokeStyle繪制非填充(空心)的文字。

下面,我們先來看看如何使用canvas繪制實(shí)心文字,具體html代碼如下:

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. <!DOCTYPE html>   

  2. <html>   

  3. <head>   

  4. <meta charset="UTF-8">   

  5. <title>HTML5 Canvas繪制文本文字入門示例</title>   

  6. </head>   

  7. <body>   

  8.   

  9. <!-- 添加canvas標(biāo)簽,并加上紅色邊框以便于在頁(yè)面上查看 -->   

  10. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   

  11. 您的瀏覽器不支持canvas標(biāo)簽。   

  12. </canvas>   

  13.   

  14. <script type="text/javascript">   

  15. //獲取Canvas對(duì)象(畫布)   

  16. var canvas = document.getElementById("myCanvas");   

  17. //簡(jiǎn)單地檢測(cè)當(dāng)前瀏覽器是否支持Canvas對(duì)象,以免在一些不支持html5的瀏覽器中提示語法錯(cuò)誤   

  18. if(canvas.getContext){     

  19.     //獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫筆)   

  20.     var ctx = canvas.getContext("2d");   

  21.        

  22.     //設(shè)置字體樣式   

  23.     ctx.font = "30px Courier New";   

  24.     //設(shè)置字體填充顏色   

  25.     ctx.fillStyle = "blue";   

  26.     //從坐標(biāo)點(diǎn)(50,50)開始繪制文字   

  27.     ctx.fillText("CodePlayer+中文測(cè)試", 50, 50);   

  28. }   

  29. </script>   

  30. </body>   

  31. </html>  

對(duì)應(yīng)的顯示效果如下:
HTML5 Canvas怎么繪制文本及圖片

接著,我們使其他環(huán)境條件均保持不變,再次使用strokeText()+strokeStyle方式來繪制上述示例中的文字,對(duì)應(yīng)的JavaScript代碼如下:

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. <script type="text/javascript">   

  2. //獲取Canvas對(duì)象(畫布)   

  3. var canvas = document.getElementById("myCanvas");   

  4. //簡(jiǎn)單地檢測(cè)當(dāng)前瀏覽器是否支持Canvas對(duì)象,以免在一些不支持html5的瀏覽器中提示語法錯(cuò)誤   

  5. if(canvas.getContext){     

  6.     //獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫筆)   

  7.     var ctx = canvas.getContext("2d");   

  8.        

  9.     //設(shè)置字體樣式   

  10.     ctx.font = "30px Courier New";   

  11.     //設(shè)置字體顏色   

  12.     ctx.strokeStyle = "blue";   

  13.     //從坐標(biāo)點(diǎn)(50,50)開始繪制文字   

  14.     ctx.strokeText("CodePlayer+中文測(cè)試", 50, 50);   

  15. }   

  16. </script>  

我們?cè)俅问褂脼g覽器訪問頁(yè)面,將會(huì)看到如下顯示效果(效果圖片中的"CodePlayer"字樣其實(shí)也是空心的,只是由于字體較小導(dǎo)致兩側(cè)看起來重疊在了一起):
HTML5 Canvas怎么繪制文本及圖片


繪制圖片
在html5中,除了利用canvas繪制矢量圖形之外,我們還可以在canvas「畫布」上繪制現(xiàn)有的圖像文件。

首先,我們來看看使用canvas繪制圖像文件需要用到CanvasRenderingContext2D對(duì)象的哪些主要屬性和方法:

XML/HTML Code復(fù)制內(nèi)容到剪貼板

  1. drawImage(mixed image, int x, int y)  

以canvas上指定的坐標(biāo)點(diǎn)開始,按照?qǐng)D像的原始尺寸大小繪制整個(gè)圖像。這里的image可以是Image對(duì)象,也可以是Canvas對(duì)象(下同)。

XML/HTML Code復(fù)制內(nèi)容到剪貼板

  1. drawImage(mixed image, int x, int y, int width, int height)  

以canvas上指定的坐標(biāo)點(diǎn)開始,以指定的大小(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ū)域中
是的,你沒有看錯(cuò)。要在canvas中繪制圖像,我們可以使用一個(gè)名為drawImage()的方法,不過該方法具有三種不同的變體,每個(gè)方法變體允許接收的參數(shù)不僅數(shù)量不同,連參數(shù)的含義也不盡相同。

在這里,我們對(duì)上述三個(gè)變體分別舉例說明。

首先,我們使用drawImage()的第一個(gè)變體在canvas上繪制Google的logo圖片(原始尺寸為550 x 190)。

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. <!DOCTYPE html>   

  2. <html>   

  3. <head>   

  4. <meta charset="UTF-8">   

  5. <title>HTML5 Canvas繪制圖像入門示例</title>   

  6. </head>   

  7. <body>   

  8.   

  9. <!-- 添加canvas標(biāo)簽,并加上紅色邊框以便于在頁(yè)面上查看 -->   

  10. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   

  11. 您的瀏覽器不支持canvas標(biāo)簽。   

  12. </canvas>   

  13.   

  14. <script type="text/javascript">   

  15. //獲取Canvas對(duì)象(畫布)   

  16. var canvas = document.getElementById("myCanvas");   

  17. //簡(jiǎn)單地檢測(cè)當(dāng)前瀏覽器是否支持Canvas對(duì)象,以免在一些不支持html5的瀏覽器中提示語法錯(cuò)誤   

  18. if(canvas.getContext){     

  19.     //獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫筆)   

  20.     var ctx = canvas.getContext("2d");   

  21.        

  22.     //創(chuàng)建新的圖片對(duì)象   

  23.     var img = new Image();   

  24.     //指定圖片的URL   

  25.     img.src = "http://www.365mini.com/image/google_logo.png";   

  26.     //瀏覽器加載圖片完畢后再繪制圖片   

  27.     img.onload = function(){   

  28.         //以Canvas畫布上的坐標(biāo)(10,10)為起始點(diǎn),繪制圖像   

  29.         ctx.drawImage(img, 10, 10);                

  30.     };   

  31. }   

  32. </script>   

  33. </body>   

  34. </html>  

對(duì)應(yīng)的顯示效果如下:
HTML5 Canvas怎么繪制文本及圖片

由于Google的Logo圖像過大,超過了canvas的尺寸范圍,因此只能顯示出圖像的一部分。此時(shí),我們使用第2個(gè)變體將Google的logo圖像縮小到指定的寬度和高度,并繪制到canvas中。

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. <script type="text/javascript">   

  2. //獲取Canvas對(duì)象(畫布)   

  3. var canvas = document.getElementById("myCanvas");   

  4. //簡(jiǎn)單地檢測(cè)當(dāng)前瀏覽器是否支持Canvas對(duì)象,以免在一些不支持html5的瀏覽器中提示語法錯(cuò)誤   

  5. if(canvas.getContext){     

  6.     //獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫筆)   

  7.     var ctx = canvas.getContext("2d");   

  8.        

  9.     //創(chuàng)建新的圖片對(duì)象   

  10.     var img = new Image();   

  11.     //指定圖片的URL   

  12.     img.src = "http://www.365mini.com/image/google_logo.png";   

  13.     //瀏覽器加載圖片完畢后再繪制圖片   

  14.     img.onload = function(){   

  15.         //以Canvas畫布上的坐標(biāo)(10,10)為起始點(diǎn),繪制圖像   

  16.         //圖像的寬度和高度分別縮放到350px和100px   

  17.         ctx.drawImage(img, 10, 10, 350, 100);                

  18.     };   

  19. }   

  20. </script>  

我們將Google的logo圖像進(jìn)行縮放后,此時(shí)就可以在canvas中看到整個(gè)圖像了:
HTML5 Canvas怎么繪制文本及圖片

最后,我們使用第三個(gè)方法變體將Google logo中的"Goo"部分圖像繪制到canvas中("Goo"部分的圖像大小可以使用Photoshop等工具測(cè)量得出,這里直接使用測(cè)量后的結(jié)果)。

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. <script type="text/javascript">   

  2. //獲取Canvas對(duì)象(畫布)   

  3. var canvas = document.getElementById("myCanvas");   

  4. //簡(jiǎn)單地檢測(cè)當(dāng)前瀏覽器是否支持Canvas對(duì)象,以免在一些不支持html5的瀏覽器中提示語法錯(cuò)誤   

  5. if(canvas.getContext){     

  6.     //獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫筆)   

  7.     var ctx = canvas.getContext("2d");   

  8.        

  9.     //創(chuàng)建新的圖片對(duì)象   

  10.     var img = new Image();   

  11.     //指定圖片的URL   

  12.     img.src = "http://www.365mini.com/image/google_logo.png";   

  13.     //瀏覽器加載圖片完畢后再繪制圖片   

  14.     img.onload = function(){   

  15.         /*  

  16.          * 將圖像左側(cè)的"Goo"部分(即以坐標(biāo)(0,0)為左上角坐標(biāo)、寬度為332px、高度為190px的部分圖像)  

  17.          * 繪制到canvas中以坐標(biāo)(10,10)為左上角、寬度為332px、高度為190px的矩形區(qū)域  

  18.          *  

  19.          * canvas繪制圖像的目標(biāo)區(qū)域的寬度和高度與截取的部分圖像尺寸保持一致,  

  20.          * 就表示不進(jìn)行縮放,以原始尺寸截取部分圖像  

  21.          */           

  22.         ctx.drawImage(img, 0, 0, 332, 190, 10, 10, 332, 190);                

  23.     };   

  24. }   

  25. </script>  

此時(shí),我們就可以看到canvas中顯示的"Goo"局部圖像了:
HTML5 Canvas怎么繪制文本及圖片

感謝各位的閱讀,以上就是“HTML5 Canvas怎么繪制文本及圖片”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)HTML5 Canvas怎么繪制文本及圖片這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI