亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 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>

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久99精品视频一区97| 一本色道久久88综合亚洲精品ⅰ| 欧美极度另类性三渗透| 青青草一区二区| 久久久久久12| 人人澡人人澡人人看欧美| 成人国内精品久久久久一区| 97精品免费视频| 国产mv免费观看入口亚洲| 国产精品免费福利| 欧美黑人一级爽快片淫片高清| 国产成人av在线| 欧美亚洲国产日韩2020| 亚洲精品中文字幕有码专区| 国产成人免费av电影| 久久躁日日躁aaaaxxxx| 成人精品视频99在线观看免费| 久久国产加勒比精品无码| 欧美日韩高清在线观看| 亚洲区bt下载| 在线播放日韩欧美| 中文字幕日韩精品在线| 亚洲欧美成人一区二区在线电影| 中文字幕在线视频日韩| 中文字幕日本欧美| 亚洲精品资源美女情侣酒店| 欧美大片在线免费观看| 97国产成人精品视频| 欧美插天视频在线播放| 亚洲精品国产欧美| 国内精品久久久久影院优| 欧美在线视频免费| 欧美日韩国产区| 国产成人一区三区| 成人久久精品视频| 一区二区欧美亚洲| 欧美丰满片xxx777| 丁香五六月婷婷久久激情| 亚洲成人精品av| 国产伦精品免费视频| 欧美成人精品激情在线观看| 中文字幕日韩在线播放| 国产99在线|中文| 91精品国产91久久久| 国产精品偷伦免费视频观看的| 亚洲r级在线观看| 亚洲人成电影在线播放| 欧美成人激情在线| 亚洲人永久免费| 国产精品视频网址| 亚洲字幕在线观看| 国产欧美在线看| 国产综合久久久久久| 欧美一区亚洲一区| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲人成网7777777国产| 久久久女人电视剧免费播放下载| 亲子乱一区二区三区电影| 亚洲美女性视频| 日韩成人网免费视频| 国产精品十八以下禁看| 久久影视免费观看| 欧美激情喷水视频| 在线亚洲欧美视频| 国产一区玩具在线观看| 久久精品国产96久久久香蕉| 久久久亚洲精选| 欧美激情三级免费| 美女啪啪无遮挡免费久久网站| 成人黄色片在线| 久久影院在线观看| 欧美成人在线网站| 国产精品丝袜视频| 欧美刺激性大交免费视频| 欧美专区在线视频| 久久精品电影网站| 国产精品69久久久久| 国产欧美精品日韩精品| 国产噜噜噜噜久久久久久久久| 在线观看91久久久久久| 国产精品国内视频| 欧美怡红院视频一区二区三区| 97在线视频一区| 国产亚洲xxx| 日韩高清免费在线| 在线观看国产精品淫| 欧美www视频在线观看| 亚洲网在线观看| 97精品国产91久久久久久| 亚洲丁香婷深爱综合| 九九热这里只有在线精品视| 性色av一区二区咪爱| 国产日韩欧美自拍| xxxx欧美18另类的高清| 欧美高清视频一区二区| 91美女福利视频高清| 欧美精品免费在线观看| 欧美黑人性生活视频| 中文字幕在线看视频国产欧美| 国产日韩欧美在线播放| 国产日本欧美一区| 亚洲综合自拍一区| 97超碰国产精品女人人人爽| 亚洲韩国欧洲国产日产av| 久久久久久久久久久91| 日韩久久精品成人| 日韩在线免费av| 亚洲视频电影图片偷拍一区| 91精品国产一区| 中文字幕在线日韩| 欧美一区视频在线| 国产日韩综合一区二区性色av| 国产精品免费久久久久久| 精品欧美aⅴ在线网站| 国产亚洲精品久久| 亚洲国产另类 国产精品国产免费| 国产日韩亚洲欧美| 亚洲老司机av| 欧美成人午夜免费视在线看片| 欧美一区二区三区精品电影| 九九九久久久久久| 日韩免费av在线| 久久久久久久电影一区| 国产精品无av码在线观看| 日韩免费高清在线观看| 欧美日韩激情小视频| 日韩在线免费高清视频| 夜夜嗨av一区二区三区四区| 亚洲精品美女免费| 久久精品国产综合| 亚洲高清久久网| 国产网站欧美日韩免费精品在线观看| 亚洲男人的天堂在线播放| 精品久久香蕉国产线看观看亚洲| 日韩在线视频免费观看高清中文| 亚洲乱亚洲乱妇无码| 日韩国产激情在线| 国产欧美一区二区三区视频| 国产不卡av在线免费观看| 91香蕉嫩草影院入口| 国产精品日韩在线观看| 激情懂色av一区av二区av| 欧美电影免费观看高清| 亚洲成av人片在线观看香蕉| 亚洲色图18p| 伊人伊人伊人久久| 91青草视频久久| 国产国产精品人在线视| 国产精品丝袜高跟| 亚洲国产精品va在线| 欧美黄色片免费观看| 国产a∨精品一区二区三区不卡| 国产精品久久久久久久久久三级| 综合久久五月天| 国产精品户外野外| 日韩欧美成人免费视频| 欧美性做爰毛片| 国产精品99导航| 国产激情视频一区| 精品久久久国产精品999| 国产日韩精品在线观看| 国产精品一区=区| 久久久国产精品一区| 97在线视频免费播放|