溫馨提示×

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

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

如何使用HTML5 canvas實(shí)現(xiàn)繪制陰影的效果

發(fā)布時(shí)間:2020-07-16 09:38:45 來(lái)源:億速云 閱讀:465 作者:Leah 欄目:web開發(fā)

本篇文章給大家分享的是有關(guān)如何使用HTML5 canvas實(shí)現(xiàn)繪制陰影的效果,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

<canvas></canvas>是HTML5中新增的標(biāo)簽,用于繪制圖形,實(shí)際上,這個(gè)標(biāo)簽和其他的標(biāo)簽一樣,其特殊之處在于該標(biāo)簽可以獲取一個(gè)CanvasRenderingContext2D對(duì)象,我們可以通過(guò)JavaScript腳本來(lái)控制該對(duì)象進(jìn)行繪圖。

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

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

陰影繪制

  • shadowColor 設(shè)置或返回用于陰影的顏色。

  • shadowBlur 設(shè)置或返回用于陰影的模糊級(jí)別(數(shù)值越大越模糊)。

  • shadowOffsetX 設(shè)置或返回陰影與形狀的水平距離。

  • shadowOffsetY 設(shè)置或返回陰影與形狀的垂直距離。

我們?yōu)橹袄L制的五角星添加一下陰影

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

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

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

  3. context.beginPath();

  4. //設(shè)置是個(gè)頂點(diǎn)的坐標(biāo),根據(jù)頂點(diǎn)制定路徑

  5. for (var i = 0; i < 5; i++) {

  6. context.lineTo(Math.cos((18+i*72)/180*Math.PI)*200+200,

  7. -Math.sin((18+i*72)/180*Math.PI)*200+200);

  8. context.lineTo(Math.cos((54+i*72)/180*Math.PI)*80+200,

  9. -Math.sin((54+i*72)/180*Math.PI)*80+200);

  10. }

  11. context.closePath();

  12. //設(shè)置邊框樣式以及填充顏色

  13. context.lineWidth="3";

  14. context.fillStyle = "#F6F152";

  15. context.strokeStyle = "#F5270B";

  16. context.shadowColor = "#F7F2B4";

  17. context.shadowOffsetX = 30;

  18. context.shadowOffsetY = 30;

  19. context.shadowBlur = 2;

  20. context.fill();

  21. context.stroke();

效果如下:

如何使用HTML5 canvas實(shí)現(xiàn)繪制陰影的效果

以上就是如何使用HTML5 canvas實(shí)現(xiàn)繪制陰影的效果,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(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