麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > HTML5 > 正文

canvas 陰影和圖形變換的示例代碼

2024-09-05 07:22:17
字體:
來源:轉載
供稿:網友

本文介紹了canvas 陰影和圖形變換的示例代碼,分享給大家,具體如下:

一、陰影設置

1、陰影的顏色:值為標準的CSS顏色值,用于設定陰影顏色效果,默認是全透明的黑色

context.shadowColor = color;

2、陰影模糊度:用戶設定陰影的模糊程度,其數值不跟像素掛鉤,默認為0

context.shadowBlur = 5;

3、陰影的偏移:

shadowOffsetX 和 shadowOffsetY 用來設定陰影在 X 和 Y 軸的延伸距離。負值表示陰影會往上或左延伸,正值則表示會往下或右延伸,它們默認都為 0

context.shadowOffsetX = 10; //正值:往右context.shadowOffsetY = 10;  //正值:往下

4、設置文字陰影的例子

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style type="text/css">            canvas{                border:1px solid red;            }        </style>    </head>    <body>        <canvas id="mycanvas" width="500" height="500"></canvas>    </body>    <script type="text/javascript">        var canvas = document.getElementById("mycanvas");        var context = canvas.getContext("2d");        context.font = "bold 50px 微軟雅黑";        context.fillStyle="red";        //陰影的顏色        context.shadowColor = "orangered";        //陰影模糊度        context.shadowBlur = 20;        //陰影的偏移        context.shadowOffsetX = 10; //正值:往右        context.shadowOffsetY = 10;  //正值:往下        context.fillText("你好",100,100);    </script></html>


 

二、圖形變換

我們之前在2D變換中也學習過這些知識,但是我們canvas圖形變換有所不同,不同點就是這里的變換并不是變換圖形,而是變換坐標系,因此,我們在變換完一個圖形之后,坐標系就發生變換了,那么我們如果再直接繪圖的話就會出現問題,下面我們來具體是什么情況吧

1、為了驗證我們上面的說法,我們來看一個例子

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style type="text/css">            canvas{                border:1px solid red;            }        </style>    </head>    <body>        <canvas id="mycanvas" width="800" height="800"></canvas>    </body>    <script type="text/javascript">        var canvas = document.getElementById("mycanvas");        var context = canvas.getContext("2d");        //用黑色直線線表示開始的x/y軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.lineTo(800,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.lineTo(0,800);        context.stroke();        //原矩形:藍色        context.beginPath();        context.fillStyle = "cornflowerblue";        context.fillRect(0,0,50,50);        context.fill();        //平移矩形:粉色        context.beginPath();        context.translate(200,0)  //正:往右、下        context.fillStyle = "deeppink";        context.fillRect(0,0,50,50);        context.fill();        //用藍色直線表示平移以后的坐標軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.lineTo(400,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.lineTo(0,400);        context.stroke();    </script></html>

得到如下效果:證明圖形變換以后是改變了坐標系的


 

2、旋轉

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style type="text/css">            canvas{                border:1px solid red;            }        </style>    </head>    <body>        <canvas id="mycanvas" width="800" height="800"></canvas>    </body>    <script type="text/javascript">        var canvas = document.getElementById("mycanvas");        var context = canvas.getContext("2d");        //用黑色直線表示平移以后的坐標軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.lineTo(800,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.lineTo(0,800);        context.stroke();        //原圖:藍色        context.beginPath();        context.fillStyle = "cornflowerblue";        context.fillRect(100,0,50,50);        context.fill();         //旋轉:綠色        context.beginPath();        context.fillStyle = "limegreen";        context.rotate(Math.PI/4);        context.fillRect(100,0,50,50);        //用藍色直線表示平移以后的坐標軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.strokeStyle = "blue";        context.lineTo(800,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 5;        context.strokeStyle = "blue";        context.lineTo(0,800);        context.stroke();    </script></html>

效果如下:


 

說明我們圖形默認是繞canvas坐標系原點旋轉的,圖形在旋轉的過程中,坐標系也會跟著旋轉

3、圖形縮放

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style type="text/css">            canvas{                border:1px solid red;            }        </style>    </head>    <body>        <canvas id="mycanvas" width="800" height="800"></canvas>    </body>    <script type="text/javascript">        var canvas = document.getElementById("mycanvas");        var context = canvas.getContext("2d");        //用黑色直線線表示開始的坐標系        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 30;        context.lineTo(100,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 30;        context.lineTo(0,100);        context.stroke();        //原圖:藍色        context.beginPath();        context.fillStyle = "cornflowerblue";        context.fillRect(100,0,50,50);        context.fill();        //縮放:粉色  ,放大/小坐標系,圖形大小也縮放        context.scale(2,1);   //第一個參數是X軸縮放比例,第二個參數是Y軸縮放比例        context.beginPath();        context.fillStyle = "pink";        context.fillRect(100,0,50,50);    //用藍色直線表示平移以后的坐標軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.strokeStyle = "blue";        context.lineTo(100,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.strokeStyle = "blue";        context.lineTo(0,100);        context.stroke();    </script></html>

效果如下:


 

我們可以看到,我們在放大X軸圖形的寬度時,我們的坐標系的X軸也跟著放大了

那我們在對canvas圖形做變換之后,怎么才能重新再canvas上繪制我們我們想要的圖形而又不用繁瑣的方式將他改變的坐標系恢復呢?
 

剛好canvas有狀態的保存和獲取

比如我們拿上面寫過的例子進行演示一下狀態的保存和獲取效果

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style type="text/css">            canvas{                border:1px solid red;            }        </style>    </head>    <body>        <canvas id="mycanvas" width="800" height="800"></canvas>    </body>    <script type="text/javascript">        var canvas = document.getElementById("mycanvas");        var context = canvas.getContext("2d");        //用黑色直線線表示開始的坐標系        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 30;        context.lineTo(100,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 30;        context.lineTo(0,100);        context.stroke();        //原圖:藍色        context.beginPath();        context.fillStyle = "cornflowerblue";        context.fillRect(100,0,50,50);        context.fill();        //縮放:粉色  ,放大/小坐標系,圖形大小也縮放        context.save();        context.scale(2,1);   //第一個參數是X軸縮放比例,第二個參數是Y軸縮放比例        context.beginPath();        context.fillStyle = "pink";        context.fillRect(100,0,50,50);        context.restore();    //用藍色直線表示平移以后的坐標軸        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.strokeStyle = "blue";        context.lineTo(100,0);        context.stroke();        context.beginPath();        context.moveTo(0,0);        context.lineWidth = 10;        context.strokeStyle = "blue";        context.lineTo(0,100);        context.stroke();    </script></html>

正如你看到的效果圖,我們在縮放之前保存了坐標系的狀態,也就是一開始未做任何變動的狀態,然后在圖像縮放之后我們又將這種狀態獲取到,也就是回到一開始未做任何變動的狀態,這就是狀態的保存和獲取,這樣就可以解決我們圖形變換對坐標系的影響了。
 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品久久国产精麻豆96堂 | 日韩视频一区二区三区四区 | 亚洲人成在线播放网站 | 国产一区二区在线免费播放 | 国产亚洲精品成人a | 国产精品一区二区日韩 | 天堂福利电影 | 精品国产一区二区三区四区在线 | 在线看小早川怜子av | 国产二区三区在线播放 | 国产精品九九久久一区hh | 玩偶姐姐 在线观看 | 高清一区二区在线观看 | 成人在线精品视频 | 国产亚洲精彩视频 | 国产视频在线观看免费 | 精品国产一区二区三区四区在线 | 国产精品区一区二区三区 | 91福利国产在线观一区二区 | 国产精品6区 | www久久综合 | 成人羞羞在线观看网站 | 亚洲小视频网站 | 久久国产成人午夜av浪潮 | 综合网日日天干夜夜久久 | 免费看日韩片 | 国产青草视频在线观看视频 | 久久久久久久久久久久99 | 中文字幕在线观看成人 | 激情综合网俺也去 | 亚洲综合91 | av日韩一区二区 | 9999视频| 草人人| 日日草夜夜 | 免费国产精品视频 | 久久亚洲线观看视频 | 中国字幕av | 久久国精品 | 国产精品自拍av | 亚洲国产网站 |