溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5 canvas如何實現(xiàn)繪制矩形

發(fā)布時間:2020-07-20 10:47:22 來源:億速云 閱讀:161 作者:Leah 欄目:web開發(fā)

這篇文章將為大家詳細講解有關HTML5 canvas如何實現(xiàn)繪制矩形,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

<canvas></canvas>只是一個繪制圖形的容器,除了id、class、style等屬性外,還有height和width屬性。在<canvas>>元素上繪圖主要有三步:

1.獲取<canvas>元素對應的DOM對象,這是一個Canvas對象;
2.調(diào)用Canvas對象的getContext()方法,得到一個CanvasRenderingContext2D對象;
3.調(diào)用CanvasRenderingContext2D對象進行繪圖。

繪制矩形rect()、fillRect()和strokeRect()

?context.rect( x , y , width , height ):只定義矩形的路徑;
?context.fillRect( x , y , width , height ):直接繪制出填充的矩形;
?context.strokeRect( x , y , width , height ):直接繪制出矩形邊框;

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

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

  2. var canvas = document.getElementById("canvas");

  3. var context = canvas.getContext("2d");

  4. //使用rect方法  

  5. context.rect(10,10,190,190);

  6. context.lineWidth = 2;

  7. context.fillStyle = "#3EE4CB";

  8. context.strokeStyle = "#F5270B";

  9. context.fill();

  10. context.stroke();

  11. //使用fillRect方法  

  12. context.fillStyle = "#1424DE";

  13. context.fillRect(210,10,190,190);

  14. //使用strokeRect方法  

  15. context.strokeStyle = "#F5270B";

  16. context.strokeRect(410,10,190,190);

  17. //同時使用strokeRect方法和fillRect方法  

  18. context.fillStyle = "#1424DE";

  19. context.strokeStyle = "#F5270B";

  20. context.strokeRect(610,10,190,190);

  21. context.fillRect(610,10,190,190);

  22. </script>

HTML5 canvas如何實現(xiàn)繪制矩形

這里需要說明兩點:第一點就是stroke()和fill()繪制的前后順序,如果fill()后面繪制,那么當stroke邊框較大時,會明顯的把stroke()繪制出的邊框遮住一半;第二點:設置fillStyle或strokeStyle屬性時,可以通過“rgba(255,0,0,0.2)”的設置方式來設置,這個設置的最后一個參數(shù)是透明度。

另外還有一個跟矩形繪制有關的:清除矩形區(qū)域:context.clearRect(x,y,width,height)。
接收參數(shù)分別為:清除矩形的起始位置以及矩形的寬和長。
在上面的代碼中繪制圖形的最后加上:

context.clearRect(100,60,600,100);

可以得到以下效果:

HTML5 canvas如何實現(xiàn)繪制矩形

關于HTML5 canvas如何實現(xiàn)繪制矩形就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

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

AI