HTML5中drawImage()方法如何使用

這期內(nèi)容當中小編將會給大家?guī)碛嘘P(guān)HTML5 中drawImage()方法如何使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供周至網(wǎng)站建設(shè)、周至做網(wǎng)站、周至網(wǎng)站設(shè)計、周至網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、周至企業(yè)網(wǎng)站模板建站服務(wù),十年周至做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

drawImage()是一個很關(guān)鍵的方法,它可以引入圖像、畫布、視頻,并對其進行縮放或裁剪。

一共有三種表現(xiàn)形式:

語法 1

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

  1. context.drawImage(img,dx,dy);  

語法 2

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

  1. context.drawImage(img,dx,dy,dw,dw);  

語法 3

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

  1. context.drawImage(img,sx,sy,sw,sh,dx,dy,dw,dh);   

來看一下坐標草圖:
HTML5 中drawImage()方法如何使用

PS: 不要在樣式中定義<canvas> 的寬和高,否則,里面所畫的圖片會自動放大或者縮小。
三參數(shù)的是標準形式,可用于加載圖像、畫布或視頻;五參數(shù)的除了可以加載圖像還可以對圖像進行指定寬高的縮放;九參數(shù)的除了縮放,還可以裁剪。各參數(shù)意義見下表。

參數(shù)
描述
img
sx可選。開始剪切的 x 坐標位置。
sy可選。開始剪切的 y 坐標位置。
swidth可選。被剪切圖像的寬度。
sheight可選。被剪切圖像的高度。
x在畫布上放置圖像的 x 坐標位置。
y在畫布上放置圖像的 y 坐標位置。
width可選。要使用的圖像的寬度。(伸展或縮小圖像)
height要使用的圖像的高度。(伸展或縮小圖像)

下面,我們加載一個圖片試試。

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

  1. <!DOCTYPE html>   

  2. <html lang="zh">   

  3. <head>   

  4.     <meta charset="UTF-8">   

  5.     <title>drawImage()</title>   

  6.     <style>   

  7.         body { background: url("./images/bg3.jpg") repeat; }  

  8.         #canvas { border: 1px solid #aaaaaa; display: block; margin: 50px auto; }  

  9.     </style>   

  10. </head>   

  11. <body>   

  12. <div id="canvas-warp">   

  13.     <canvas id="canvas">   

  14.         你的瀏覽器居然不支持Canvas?!趕快換一個吧??!   

  15.     </canvas>   

  16. </div>   

  17.   

  18. <script>   

  19.     window.onload = function(){   

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

  21.         canvas.width = 800;   

  22.         canvas.height = 600;   

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

  24.         context.fillStyle = "#FFF";   

  25.         context.fillRect(0,0,800,600);   

  26.   

  27.         var img = new Image();   

  28.         img.src = "./images/20-1.jpg";   

  29.         img.onload = function(){   

  30.             context.drawImage(img,200,50);   

  31.         }   

  32.     };   

  33. </script>   

  34. </body>   

  35. </html>  

運行結(jié)果:
HTML5 中drawImage()方法如何使用

創(chuàng)建相框:
這里,我們結(jié)合clip()和drawImage()以及三次貝塞爾曲線bezierCurveTo(),來為上面一個案例,加上一個心形的相框~

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

  1. <!DOCTYPE html>   

  2. <html lang="zh">   

  3. <head>   

  4.     <meta charset="UTF-8">   

  5.     <title>繪制心形相框</title>   

  6.     <style>   

  7.         body { background: url("./images/bg3.jpg") repeat; }  

  8.         #canvas { border: 1px solid #aaaaaa; display: block; margin: 50px auto; }  

  9.     </style>   

  10. </head>   

  11. <body>   

  12. <div id="canvas-warp">   

  13.     <canvas id="canvas">   

  14.         你的瀏覽器居然不支持Canvas?!趕快換一個吧?。?  

  15.     </canvas>   

  16. </div>   

  17.   

  18. <script>   

  19.     window.onload = function(){   

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

  21.         canvas.width = 800;   

  22.         canvas.height = 600;   

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

  24.         context.fillStyle = "#FFF";   

  25.         context.fillRect(0,0,800,600);   

  26.   

  27.         context.beginPath();   

  28.         context.moveTo(400,260);   

  29.         context.bezierCurveTo(450,220,450,300,400,315);   

  30.         context.bezierCurveTo(350,300,350,220,400,260);   

  31.         context.clip();   

  32.         context.closePath();   

  33.   

  34.         var img = new Image();   

  35.         img.src = "./images/20-1.jpg";   

  36.         img.onload = function(){   

  37.             context.drawImage(img,348,240,100,100);   

  38.         }   

  39.     };   

  40. </script>   

  41. </body>   

  42. </html>  

上述就是小編為大家分享的HTML5 中drawImage()方法如何使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章題目:HTML5中drawImage()方法如何使用
標題來源:http://muchs.cn/article44/ihdhee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化、商城網(wǎng)站電子商務(wù)、自適應網(wǎng)站品牌網(wǎng)站制作、關(guān)鍵詞優(yōu)化

廣告

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

網(wǎng)站托管運營