欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么用HTML5Canvas繪制直線或折線等線條

本篇內(nèi)容介紹了“怎么用HTML5 Canvas繪制直線或折線等線條”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)專注于企業(yè)營銷型網(wǎng)站、網(wǎng)站重做改版、茶陵網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)購物商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為茶陵等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

HTML5 Canvas基本概念講解
html5,這個應(yīng)該就不需要多作介紹了,只要是開發(fā)人員應(yīng)該都不會陌生。html5是「新興」的網(wǎng)頁技術(shù)標(biāo)準(zhǔn),目前,除IE8及其以下版本的IE瀏覽器之外,幾乎所有主流瀏覽器(FireFox、Chrome、Opera、Safari、IE9+)都已經(jīng)開始支持html5了。除此之外,在移動瀏覽器市場上,眾多的移動瀏覽器也紛紛展開關(guān)于「html5的支持能力以及性能表現(xiàn)」的軍備競賽。html作為革命性的網(wǎng)頁技術(shù)標(biāo)準(zhǔn),再加上眾多瀏覽器廠商或組織的鼎力支持,可以想見,html5將會成為未來網(wǎng)頁技術(shù)的領(lǐng)頭羊。

html5,說其是「新興」的,其實也不算新了。畢竟,html5早在2008年其第一份正式草案就已經(jīng)對外公布。從2008年算起,到現(xiàn)在也算是有些年頭了。不過,到目前為止,對于大多數(shù)開發(fā)人員而言,仍然是「雷聲大,雨點(diǎn)小」——聽說html5的多,實際使用html5的卻很少。

眾所周知,html5中增加了許多新特性。在html5的眾多特性中,Canvas應(yīng)該算是最引人注目的新特性之一。我們使用html5的Canvas對象可以直接在瀏覽器的網(wǎng)頁上繪制圖形。這意味著瀏覽器可以脫離Flash等第三方插件,直接在網(wǎng)頁上顯示圖形或動畫。

現(xiàn)在,我們就來為html5初學(xué)者介紹如何使用html5 Canvas繪制基本的圖形。

首先,我們需要準(zhǔn)備如下html基礎(chǔ)代碼:

XML/HTML 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. </body>  

  10. </html>  

上述代碼是一個html5頁面的基本代碼模板。其中,第一行代碼<!DOCTYPE html>是一個文檔類型標(biāo)簽指令,這也是html5頁面的標(biāo)準(zhǔn)文檔類型指令,用于告訴瀏覽器「這是一個html5頁面,請按照html5的網(wǎng)頁標(biāo)準(zhǔn)來解析顯示該頁面」。第4行代碼<meta charset="UTF-8">用于告訴瀏覽器「這個html5頁面的字符編碼為UTF-8」,這也是html5網(wǎng)頁設(shè)置字符編碼的標(biāo)準(zhǔn)寫法。這與以往的html字符編碼指令有所不同。

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

  1. <!-- 以往的html字符編碼指令如下 -->  

  2. <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">  

現(xiàn)在,我們就在包含上述代碼的html文件中進(jìn)行Canvas繪制圖形的實例講解。首先,我們在上述html代碼的body部分添加如下canvas標(biāo)簽。

XML/HTML 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)簽,并加上紅色邊框以便于在頁面上查看效果 -->  

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

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

  12. </canvas>  

  13.   

  14. </body>  

  15. </html>  

此時,我們使用支持html5的瀏覽器打開該頁面,將會看到如下內(nèi)容:
怎么用HTML5 Canvas繪制直線或折線等線條

在html5中,canvas標(biāo)簽本身并沒有任何行為,僅僅只是在頁面上占用指定大小的頁面空白空間。canvas標(biāo)簽就相當(dāng)于一塊空白的畫布,還需要我們自己使用JavaScript提供的canvas API編寫相應(yīng)的代碼從而在這塊畫布上繪制出我們想要的圖形。

備注:canvas標(biāo)簽體內(nèi)的文字內(nèi)容將會在不支持html5的瀏覽器中顯示。如上述html代碼所示,如果你的瀏覽器不支持html5的canvas標(biāo)簽,那么將會在canvas標(biāo)簽處顯示文字「您的瀏覽器不支持canvas標(biāo)簽」。
作為「畫家」的我們,首先需要熟悉我們手中的畫筆,也就是JavaScript中的Canvas對象及其相關(guān)內(nèi)容。

在html5中,一個canvas標(biāo)簽就對應(yīng)一個Canvas對象,我們在JavaScript可以使用document.getElementById()等常規(guī)函數(shù)來獲取該對象。值得注意的是,在JavaScript中,我們并不是直接操作Canvas對象,而是通過Canvas對象來獲取對應(yīng)的圖形繪制上下文對象CanvasRenderingContext2D,然后我們再利用CanvasRenderingContext2D對象自帶的許多繪制圖形的函數(shù)來繪圖。

這就好像是每一張畫布都對應(yīng)一支畫筆,要想在畫布上繪畫,我們就先要拿到對應(yīng)的畫筆,然后使用這支畫筆在畫布上繪圖。CanvasRenderingContext2D對象就相當(dāng)于這支畫筆。現(xiàn)在,我們就先來嘗試在JavaScript中拿到這支畫筆。

XML/HTML 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)簽,并加上紅色邊框以便于在頁面上查看效果 -->  

  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對象(畫布)   

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

  17.   

  18. //簡單地檢測當(dāng)前瀏覽器是否支持Canvas對象,以免在一些不支持html5的瀏覽器中提示語法錯誤   

  19. if(canvas.getContext){   

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

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

  22. }   

  23. </script>  

  24. </body>  

  25. </html>  

如上述代碼所示,我們可以使用Canvas對象的getContext()方法來獲取CanvasRenderingContext2D對象。比較細(xì)心的讀者應(yīng)該注意到了:getContext()方法需要傳入一個字符串&mdash;&mdash;2d,獲取到的CanvasRenderingContext2D對象的名稱中也帶有2D。這是因為,目前html5只支持2D繪圖,但是在未來的html5中也可能支持3D或其他形式的繪圖。屆時,我們可能就需要使用getContext("3d")來獲取CanvasRenderingContext3D對象并繪制3D圖形了。

使用html5 canvas繪制線條(直線、折線等)
使用html5 Canvas繪制直線所需的CanvasRenderingContext2D對象的主要屬性和方法(有"()"者為方法)如下:

屬性或方法基本描述
strokeStyle用于設(shè)置畫筆繪制路徑的顏色、漸變和模式。該屬性的值可以是一個表示css顏色值的字符串。如果你的繪制需求比較復(fù)雜,該屬性的值還可以是一個CanvasGradient對象或者CanvasPattern對象
globalAlpha定義繪制內(nèi)容的透明度,取值在0.0(完全透明)和1.0(完全不透明)之間,默認(rèn)值為1.0。
lineWidth定義繪制線條的寬度。默認(rèn)值是1.0,并且這個屬性必須大于0.0。較寬的線條在路徑上居中,每邊各有線條寬的一半。
lineCap指定線條兩端的線帽如何繪制。合法的值是 "butt"、"round"和"square"。默認(rèn)值是"butt"。
beginPath()開始一個新的繪制路徑。每次繪制新的路徑之前記得調(diào)用該方法。它將重置內(nèi)存中現(xiàn)有的路徑。
moveTo(int x, int y)移動畫筆到指定的坐標(biāo)點(diǎn)(x,y),該點(diǎn)就是新的子路徑的起始點(diǎn)
lineTo(int x, int y)使用直線連接當(dāng)前端點(diǎn)和指定的坐標(biāo)點(diǎn)(x,y)
stroke(int x, int y)沿著繪制路徑的坐標(biāo)點(diǎn)順序繪制直線
closePath()如果當(dāng)前的繪制路徑是打開的,則關(guān)閉掉該繪制路徑。此外,調(diào)用該方法時,它會嘗試用直線連接當(dāng)前端點(diǎn)與起始端點(diǎn)來關(guān)閉路徑,但如果圖形已經(jīng)關(guān)閉(比如先調(diào)用了stroke())或者只有一個點(diǎn),它會什么都不做。


在Canvas的圖形繪制過程中,幾乎都是先按照一定順序先定下幾個坐標(biāo)點(diǎn),也就是所謂的繪制路徑,然后再根據(jù)我們的需要將這些坐標(biāo)點(diǎn)用指定的方式連接起來,就形成了我們所需要的圖形。當(dāng)我們了解了CanvasRenderingContext2D對象的上述API后,那么繪制線條就顯得非常簡單了。

使用canvas繪制基本的直線

現(xiàn)在,我們就使用canvas來繪制最基本的直線。

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)簽,并加上紅色邊框以便于在頁面上查看 -->   

  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對象(畫布)  

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

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

  18. if(canvas.getContext){     

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

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

  21.        

  22.     //注意,Canvas的坐標(biāo)系是:Canvas畫布的左上角為原點(diǎn)(0,0),向右為橫坐標(biāo),向下為縱坐標(biāo),單位是像素(px)。  

  23.        

  24.     //開始一個新的繪制路徑  

  25.     ctx.beginPath();   

  26.     //定義直線的起點(diǎn)坐標(biāo)為(10,10)  

  27.     ctx.moveTo(10, 10);   

  28.     //定義直線的終點(diǎn)坐標(biāo)為(50,10)  

  29.     ctx.lineTo(50, 10);   

  30.     //沿著坐標(biāo)點(diǎn)順序的路徑繪制直線  

  31.     ctx.stroke();   

  32.     //關(guān)閉當(dāng)前的繪制路徑  

  33.     ctx.closePath();   

  34. }   

  35. </script>   

  36. </body>   

  37. </html>  

顯示效果如下:
怎么用HTML5 Canvas繪制直線或折線等線條

使用canvas繪制帶顏色的直線

大家都知道,在現(xiàn)實世界中,畫筆也是多種多樣的,并且具有各種不同的顏色。同樣的,Canvas的畫筆CanvasRenderingContext2D對象也同樣可以具有你所需要的各種顏色。在上面的代碼示例中,我們沒有指定顏色的話,Canvas的畫筆就默認(rèn)為最常見的黑色。

現(xiàn)在我們再次使用Canvas的畫筆繪制一條藍(lán)色的直線(基于頁面簡潔考慮,下面只給出關(guān)鍵的JavaScript代碼,請同時參考上面完整的代碼示例)。

XML/HTML 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)簽,并加上紅色邊框以便于在頁面上查看 -->  

  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對象(畫布)   

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

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

  18. if(canvas.getContext){     

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

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

  21.        

  22.     //開始一個新的繪制路徑   

  23.     ctx.beginPath();   

  24.     //定義直線的起點(diǎn)坐標(biāo)為(10,10)   

  25.     ctx.moveTo(10, 10);   

  26.     //定義直線的終點(diǎn)坐標(biāo)為(50,10)   

  27.     ctx.lineTo(50, 10);   

  28.     //沿著坐標(biāo)點(diǎn)順序的路徑繪制直線   

  29.     ctx.stroke();   

  30.     //關(guān)閉當(dāng)前的繪制路徑   

  31.     ctx.closePath();   

  32.   

  33.     //繪制一條帶顏色的直線   

  34.     ctx.moveTo(10, 30);   

  35.     ctx.lineTo(50, 30);   

  36.     //支持css顏色值的各種表現(xiàn)形式,例如:"blue"、"#0000ff"、"#00f"、"rgb(0,0,255)"、"rgba(0,0,255,1)"   

  37.     //顏色等各種設(shè)置,必須在最終的繪制函數(shù)stroke()之前調(diào)用   

  38.     ctx.strokeStyle = "blue";    

  39.     ctx.stroke();   

  40.     //關(guān)閉當(dāng)前的繪制路徑   

  41.     ctx.closePath();   

  42. }   

  43. </script>  

  44. </body>  

  45. </html>  

對應(yīng)的顯示效果如下圖:
怎么用HTML5 Canvas繪制直線或折線等線條

使用canvas繪制基本的折線

當(dāng)我們掌握了Canvas繪制直線之后,繪制折線等其他形式的線條就簡單多了。我們只需要多繪制幾個路徑中間點(diǎn),并依次將它們連接起來即可。

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

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

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

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

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

  5. if(canvas.getContext){     

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

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

  8.        

  9.     //開始一個新的繪制路徑  

  10.     ctx.beginPath();   

  11.     //設(shè)置線條顏色為藍(lán)色  

  12.     ctx.strokeStyle = "blue";   

  13.     //設(shè)置路徑起點(diǎn)坐標(biāo)  

  14.     ctx.moveTo(20, 50);   

  15.     //定義中間點(diǎn)坐標(biāo)1  

  16.     ctx.lineTo(60, 50);   

  17.     //定義中間點(diǎn)坐標(biāo)2  

  18.     ctx.lineTo(60, 90);   

  19.     //定義中間點(diǎn)坐標(biāo)3(這是最后一個中間點(diǎn),也就是終點(diǎn))  

  20.     ctx.lineTo(100, 90);   

  21.     //按照繪制路徑順序連接各個坐標(biāo)點(diǎn)  

  22.     ctx.stroke();   

  23.     //關(guān)閉繪制路徑  

  24.     ctx.closePath();   

  25. }   

  26. </script>  

對應(yīng)的顯示效果如下圖:
怎么用HTML5 Canvas繪制直線或折線等線條

掌握上述內(nèi)容后,相信大家對使用Canvas繪制線條有一些基本的了解了吧。由于對線條的寬度、透明度等控制只是設(shè)置單個屬性即可,請參考上面的相關(guān)API,這里就不再贅述了。

強(qiáng)烈注意:在繪制圖形路徑時,一定要先調(diào)用beginPath()。beginPath()方法將會清空內(nèi)存中之前的繪制路徑信息。如果不這樣做,對于繪制單個圖形可能沒什么影響,但是在繪制多個圖形時(例如上面示例的兩條直線),將會導(dǎo)致路徑繪制或者顏色填充等操作出現(xiàn)任何意料之外的結(jié)果。
此外,對于closePath()方法,初學(xué)者一定要稍加注意,尤其是上面API表格中closePath()方法描述中的紅色文字。在上面繪制折線的代碼示例中,我們先調(diào)用了stroke(),再調(diào)用了closePath()。其實在調(diào)用stroke()方法時,折線就已經(jīng)繪制好了,當(dāng)前的繪制路徑也就被關(guān)閉掉了,所以再調(diào)用closePath()方法時,它就不會使用直線連接當(dāng)前端點(diǎn)和起始端點(diǎn)(也就是說,這里的closePath()是可有可無的,不過為了保持良好的習(xí)慣,還是建議寫上)。如果我們交換一下stroke()和closePath()的調(diào)用順序,則情況完全不一樣了。由于closePath()先調(diào)用,此時繪制路徑并沒有關(guān)閉,那么closePath()將會用直線連接當(dāng)前端點(diǎn)和起始端點(diǎn)。

交換stroke()和closePath()調(diào)用順序后的示例代碼如下:

交換調(diào)用順序后,對應(yīng)的顯示效果如下:
怎么用HTML5 Canvas繪制直線或折線等線條 

“怎么用HTML5 Canvas繪制直線或折線等線條”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

新聞名稱:怎么用HTML5Canvas繪制直線或折線等線條
轉(zhuǎn)載源于:http://aaarwkj.com/article8/iiogip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計公司、手機(jī)網(wǎng)站建設(shè)品牌網(wǎng)站建設(shè)、全網(wǎng)營銷推廣、用戶體驗網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
日韩成人激情在线观看| 日本韩国黄色三级三级| 中文字幕一区侵犯人妻| 日本福利资源在线观看| 亚洲日本久久久午夜精品| 亚洲日本精品一区二区三区| 日韩国产精品视频二区| 亚洲国产黄色美女视频| 国内丰满少妇嗷嗷叫在线播放| 国产精品久久久久精品综合| 亚洲欧美日韩另类精品一区二区三区| 国产又大又黄又粗的黄色| 久久久久久这里都是精品| 中文字幕国产精品一区二| 中文字幕日韩激情欧美一区| 久久色综合色悠悠色综合色| 国产午夜精品自拍视频| 中文字幕伦理一区二区三区| 日韩在线视频 一区二区三区| 国产亚洲精品福利视频| 黑人巨大欧美一区二区| 老熟女露脸吞精一二三四区| 91九色午夜在线观看| 国产亚洲精品视频热| 91伊人久热精品午夜福利| 午夜福利视频欧美成人| 91成人大片在线观看| 黄色av手机在线观看| 日本区一区二区三视频| 熟女人妻视频一区二区| 国产原创av剧情在线播放| 巨乳人妻一区二区三区| 亚洲欧美综合区丁香六月| 日日干夜夜射天天操| 日本 午夜 在线 视频| 精品在欧美一区二区少妇| 欧美亚洲综合另类色妞| 日韩不卡一区二区在线观看| 亚洲精品不卡一区二区| 国产91黑丝在线播放| 亚洲av日韩欧美精品|