国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

Canvas 像素處理之改變透明度的實現代碼

2024-08-26 00:21:16
字體:
來源:轉載
供稿:網友

一 定義和用法

getImageData()方法返回 ImageData 對象,該對象拷貝了畫布指定矩形的像素數據。

注意:ImageData對象不是圖像,它規定了畫布上一個部分(矩形),并保存了該矩形內每個像素的信息。

對于ImageData對象中的每個像素,都存在著四方面的信息,即RGBA值:

  • R - 紅色(0-255)
  • G - 綠色(0-255)
  • B - 藍色(0-255)

A - alpha 通道(0-255; 0 是透明的,255 是完全可見的)

color/alpha 信息以數組形式存在,并存儲于 ImageData 對象的 data 屬性中。

提示:在操作完成數組中的 color/alpha 信息之后,您可以使用 putImageData() 方法將圖像數據拷貝回畫布上。

二 代碼

<!DOCTYPE html><html><head> <meta name="author" content="Yeeku.H.Lee(CrazyIt.org)" /> <meta http-equiv="Content-Type" content="text/html; charset=GBK" /> <title> 改變透明度 </title></head><body><h2> 改變透明度 </h2><canvas id="mc" width="600" height="460" style="border:1px solid black"></canvas><script type="text/javascript"> // 獲取canvas元素對應的DOM對象 var canvas = document.getElementById('mc'); // 獲取在canvas上繪圖的CanvasRenderingContext2D對象 var ctx = canvas.getContext('2d'); var image = new Image(); image.src = "test.png"; image.onload = function() {  // 用帶透明度參數的方法繪制圖片  drawImage(image , 124  , 20 , 0.4); } var drawImage = function(image , x  , y , alpha) {  // 繪制圖片  ctx.drawImage(image , x , y);  // 獲取從x、y開始,寬為image.width、高為image.height的圖片數據  // 也就是獲取繪制的圖片數據  var imgData = ctx.getImageData(x , y , image.width , image.height);  for (var i = 0 , len = imgData.data.length ; i < len ; i += 4 )  {   // 改變每個像素的透明度   imgData.data[i + 3] = imgData.data[i + 3] * alpha;  }  // 將獲取的圖片數據放回去。  ctx.putImageData(imgData , x , y); }</script></body></html>

三 運行結果

Canvas,像素處理,透明度,代碼

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天长市| 峨边| 谢通门县| 广水市| 石嘴山市| 花莲县| 长治市| 保定市| 扬中市| 奉贤区| 张掖市| 安吉县| 遂平县| 高平市| 浮梁县| 仪陇县| 阿拉善盟| 株洲市| 凤翔县| 汾阳市| 盱眙县| 紫金县| 南康市| 山丹县| 大悟县| 漠河县| 资中县| 木兰县| 龙门县| 翼城县| 慈利县| 丹棱县| 靖远县| 福安市| 南召县| 九江县| 安塞县| 通化县| 贵港市| 巧家县| 邓州市|