首頁 web前端 H5教程 使用Canvas處理圖片的方法介紹

使用Canvas處理圖片的方法介紹

Jul 03, 2018 am 09:31 AM

本篇文章主要介紹了教你使用Canvas處理圖片的方法,內容挺不錯的,現在分享給大家,也給大家做個參考。

Canvas,中文翻譯為“畫布”,HTML5中新增了元素,可以結合JavaScript動態地在畫布中繪製圖形。

今天,我們不講Canvas的圖形繪製,而是講如何處理圖片。

大概流程非常簡單,主要分成以下三個步驟:

#是的,就像把大象裝進冰箱一樣簡單,哈哈。

一、主要API

整個流程中所用到的主要Canvas API有:

  1. 繪製圖片: drawImage( )

  2. 取得影像資料:getImageData()

  3. #重寫影像資料:putImageData()



#匯出影像: toDataURL()1. drawImage()顧名思義,該方法就是用於將影像繪製於Canvas畫布當中,具體用法有三種:① 在畫布上定位圖像:context.drawImage(img,x,y)② 在畫布上定位圖像,並規定圖像的寬度和高度:context. drawImage(img,x,y,width,height)③ 剪切圖像,並在畫布上定位被剪切的部分:context.drawImage(img,sx,sy,swidth,sheight,x,y,width ,height)以上參數值描述如下表:規定要使用的圖像、畫布或影片。 可選。開始剪切的 x 座標位置。 可選。開始剪切的 y 座標位置。 可選。被剪切影像的寬度。 可選。被剪切影像的高度。 在畫布上放置影像的 x 座標位置。
#參數 描述
img
sx
sy
swidth
sheight
x

y

在畫布上放置影像的 y 座標位置。


width

可選。要使用的圖像的寬度。 (伸展或縮小影像)height可選。要使用的圖像的高度。 (伸展或縮小影像)2. getImageData()該方法用於從Canvas畫布中取得影像數據,具體用法如下:以上參數值說明如下表:開始複製的左上角位置的x座標。
取得畫布指定矩形範圍內的像素資料:var ImageData = context.getImageData(x,y,width,height)
參數 描述
#x

y

開始複製的左上角位置的 y 座標。

width

將要複製的矩形區域的寬度。

height將要複製的矩形區域的高度。 該方法會傳回一個ImageData對象,該物件有三個屬性分別為:width、height和data,而我們最主要用到的就是這個data數組,因為它保存著影像中每一個像素的資料。有了這些資料之後我們便可以對它們進行處理,最後再將其重寫至Canvas畫布中,這樣就實現了對圖片的處理轉換。對於該data數組具體用法,我們可以在後面的實例中看到。 3. putImageData() 方法很簡單,就是用來將影像資料重寫到Canvas畫布中,具體用法如下:#
context.putImageData(imgData,x,y,dirtyX,dirtyY,dirtyWidth,dirtyHeight)
登入後複製
以上參數值描述如下表:##描述imgData規定要放回畫布的ImageData 物件。 xImageData 物件左上角的 x 座標,以像素為單位。 yImageData 物件左上角的 y 座標,以像素為單位。 dirtyX可選。水平值(x),以像素計,在畫布上放置影像的位置。
#參數
###dirtyY######可選。水平值(y),以像素計,在畫布上放置影像的位置。 ############dirtyWidth#######可選。在畫布上繪製圖像所使用的寬度。 ############dirtyHeight######可選。在畫布上繪製圖像所使用的高度。 ############

4. toDataURL()

这个方法与以上三种方法不同,它是Canvas对象的方法,该方法返回的是一个包含data URI的字符串,该字符串可直接作为图片路径地址填入标签的src属性当中,具体用法如下:

var dataURL = canvas.toDataURL(type, encoderOptions);
登入後複製

以上参数值描述如下表:

参数描述
type可选。图片格式,默认为 image/png。
encoderOptions可选。在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。如果超出取值范围,将会使用默认值 0.92。其他参数会被忽略。

二、图片处理实例

本实例将通过代码简单介绍如何把彩色图片处理成黑白图片。

<!--HTML-->
<canvas id="canvas" width="600" height="600"></canvas>
<input id="handle" type="button" value="处理图片" />
<input id="create" type="button" value="生成图片" />
<p id="result"></p>
登入後複製

//JavaScript
window.onload = function(){
    var canvas = document.getElementById("canvas"),   //获取Canvas画布对象
        context = canvas.getContext(&#39;2d&#39;);  //获取2D上下文对象,大多数Canvas API均为此对象方法
    var image = new Image();  //定义一个图片对象
    image.src = &#39;imgs/img.jpg&#39;;  
    image.onload = function(){  //此处必须注意!后面所有操作均需在图片加载成功后执行,否则图片将处理无效
        context.drawImage(image,0,0);  //将图片从Canvas画布的左上角(0,0)位置开始绘制,大小默认为图片实际大小
        var handle = document.getElementById("handle");
        var create = document.getElementById("create");
        handle.onclick = function(){  // 单击“处理图片”按钮,处理图片
            var imgData = context.getImageData(0,0,canvas.width,canvas.height);   //获取图片数据对象
            var data = imgData.data;  //获取图片数据数组,该数组中每个像素用4个元素来保存,分别表示红、绿、蓝和透明度值
            var average = 0;
            for (var i = 0; i < data.length; i+=4) {
                average = Math.floor((data[i]+data[i+1]+data[i+2])/3);  //将红、绿、蓝色值求平均值后得到灰度值
                data[i] = data[i+1] = data[i+2] = average;  将每个像素点的色值重写
            }
            imgData.data = data;
            context.putImageData(imgData,0,0);  //将处理后的图像数据重写至Canvas画布,此时画布中图像变为黑白色
        };
        create.onclick = function(){  // 单击“生成图片”按钮,导出图片
            var imgSrc = canvas.toDataURL();  //获取图片的DataURL
            var newImg = new Image();
            var result = document.getElementById("result");
            newImg.src = imgSrc;  //将图片路径赋值给src
            result.innerHTML = &#39;&#39;;
            result.appendChild(newImg);
        };
    };
};
登入後複製

可能上面代码写得不是很好,看起来也不是那么好理解,最好自己能够亲自写一写,这样对于自己理解会更加深刻一些。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

HTML5 Plus 实现手机APP拍照或相册选择图片上传的功能

利用HTML5中的Canvas绘制笑脸的代码

以上是使用Canvas處理圖片的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

h5項目怎麼運行 h5項目怎麼運行 Apr 06, 2025 pm 12:21 PM

運行 H5 項目需要以下步驟:安裝 Web 服務器、Node.js、開發工具等必要工具。搭建開發環境,創建項目文件夾、初始化項目、編寫代碼。啟動開發服務器,使用命令行運行命令。在瀏覽器中預覽項目,輸入開發服務器 URL。發布項目,優化代碼、部署項目、設置 Web 服務器配置。

H5頁面製作究竟指什麼 H5頁面製作究竟指什麼 Apr 06, 2025 am 07:18 AM

H5 頁面製作是指使用 HTML5、CSS3 和 JavaScript 等技術,創建跨平台兼容的網頁。其核心在於瀏覽器解析代碼,渲染結構、樣式和交互功能。常見技術包括動畫效果、響應式設計和數據交互。為避免錯誤,應使用開發者工具調試;而性能優化和最佳實踐則包括圖像格式優化、減少請求和代碼規範等,以提高加載速度和代碼質量。

h5怎麼製作點擊圖標 h5怎麼製作點擊圖標 Apr 06, 2025 pm 12:15 PM

製作 H5 點擊圖標的步驟包括:在圖像編輯軟件中準備方形源圖像。在 H5 編輯器中添加交互性,設置點擊事件。創建覆蓋整個圖標的熱點。設置點擊事件的操作,如跳轉頁面或觸發動畫。導出 H5 文檔為 HTML、CSS 和 JavaScript 文件。將導出的文件部署到網站或其他平台。

H5指的是什麼?探索上下文 H5指的是什麼?探索上下文 Apr 12, 2025 am 12:03 AM

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

什麼是H5編程語言? 什麼是H5編程語言? Apr 03, 2025 am 12:16 AM

H5不是獨立編程語言,而是HTML5、CSS3和JavaScript的集合,用於構建現代Web應用。 1.HTML5定義網頁結構和內容,提供新標籤和API。 2.CSS3控製樣式和佈局,引入動畫等新特性。 3.JavaScript實現動態交互,通過DOM操作和異步請求增強功能。

h5怎麼製作彈窗 h5怎麼製作彈窗 Apr 06, 2025 pm 12:12 PM

H5 彈窗製作步驟:1. 確定觸發方式(點擊式、時間式、退出式、滾動式);2. 設計內容(標題、正文、行動按鈕);3. 設置樣式(大小、顏色、字體、背景);4. 實現代碼(HTML、CSS、JavaScript);5. 測試和部署。

H5頁面製作適合哪些應用場景 H5頁面製作適合哪些應用場景 Apr 05, 2025 pm 11:36 PM

H5(HTML5)適合應用於輕量級應用,如營銷活動頁面、產品展示頁面和企業宣傳微網站。它優勢在於跨平台性和豐富的交互性,但局限性在於復雜的交互和動畫、本地資源訪問和離線功能。

H5頁面製作的優勢有哪些 H5頁面製作的優勢有哪些 Apr 05, 2025 pm 11:48 PM

H5 頁面製作的優勢包括:輕量級體驗,加載速度快,提升用戶留存率。跨平台兼容性,無需針對不同平台適配,提升開發效率。靈活性和動態更新,無需審核,便於內容修改和更新。成本效益,開發成本比原生 App 低。

See all articles