Canvas での画像の処理方法

小云云
小云云オリジナル
2017-12-05 13:46:032017ブラウズ

Canvas (中国語では「キャンバス」と訳されます) には、HTML5 に新しい 5ba626b379994d53f7acf72a64f9b697 要素があり、JavaScript と組み合わせてキャンバス内にグラフィックを動的に描画できます。この記事では、Canvas でのグラフィック描画ではなく、画像の処理方法について説明します。

プロセスはおそらく非常に簡単で、主に次の 3 つのステップに分かれています:

はい、象を冷蔵庫に入れるのと同じくらい簡単です(笑)。

1. 主要な API

プロセス全体で使用される主な Canvas API は次のとおりです:

  1. 画像の描画:drawImage()

  2. 画像データの取得:getImageData()

  3. 画像データの書き換え: putImageData()

  4. 画像のエクスポート: 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)

上記のパラメータ値を以下で説明しますtable:


パラメータ説明img 使用する画像、キャンバス、またはビデオを指定します。 sxはオプションです。剪断を開始する x 座標の位置。 syオプション。せん断を開始する y 座標の位置。 幅オプション。トリミングされた画像の幅。 身長はオプションです。切り取られた画像の高さ。 x画像のx座標位置をキャンバス上に配置します。 y画像のy座標位置をキャンバス上に配置します。 幅オプション。使用する画像の幅。 (画像を拡大または縮小) 高さオプション。使用する画像の高さ。 (画像を拡大または縮小します)

2. getImageData()

このメソッドは、Canvas キャンバスから画像データを取得するために使用されます。

指定された範囲内のピクセル データを取得します。キャンバスの長方形の範囲: var ImageData = context.getImageData(x,y,width,height)

上記のパラメーター値については、次の表で説明します。座標のコピーを開始するには、左上隅の位置に

x

x を入力します。 widthheightこのメソッドは、幅、高さ、データの 3 つの属性を持つ ImageData オブジェクトを返します。これは、画像内の各ピクセルのデータを保存するため、最も重要です。これらのデータを取得した後、それらを処理し、最終的に Canvas キャンバスに書き換えることで、画像の加工と変換を実現します。データ配列の具体的な使用法については、次の例で確認できます。 このメソッドは非常に単純で、画像データを Canvas キャンバスに書き換えるために使用されます。具体的な使用方法は次のとおりです。 上記のパラメータ値は次の表で説明します。
y コピーを開始する左上隅の y 座標。
コピーされる長方形領域の幅。
コピーされる長方形領域の高さ。
3. putImageData()
context.putImageData(imgData,x,y,dirtyX,dirtyY,dirtyWidth,dirtyHeight)

Parameters

Description

imgData

キャンバスに戻す ImageData オブジェクトを指定します。 yダーティX汚いdirtyWidthdirtyHeight

4. toDataURL()

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

var dataURL = canvas.toDataURL(type, encoderOptions);

以上参数值描述如下表:


x ImageData オブジェクトの左上隅の x 座標 (ピクセル単位)。
ImageData オブジェクトの左上隅の y 座標 (ピクセル単位)。
オプション。キャンバス上の画像を配置する水平方向の値 (x) (ピクセル単位)。
オプション。キャンバス上の画像を配置する水平方向の値 (y) (ピクセル単位)。
オプション。キャンバス上に画像を描画するために使用される幅。
オプション。キャンバス上に画像が描画される高さ。
参数 描述
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);
        };
    };
};

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

以上内容就是Canvas处理图片的方法,希望对大家有帮助。

相关推荐:

HTML5里Canvas常用的绘图技巧

JavaScript+html5 canvas实现图片上画超链接的示例代码

html5 canvas制作一个跟着鼠标移动消失的一堆炫彩小球

以上がCanvas での画像の処理方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。