实现HTML画布图像着色功能

时间:2014-07-30 07:14:27

标签: javascript html5 canvas

第一次StackOverflow海报在这里请温柔:)

我正在尝试在HTML画布中实现图像着色,以用于我正在开发的游戏。这里有很多好的建议:

How do i tint an image with HTML5 Canvas?

我成功地实现了其中之一,但图像颜色看起来太褪色了。结果给我留下了深刻的印象:

http://www.playmycode.com/blog/2011/06/realtime-image-tinting-on-html5-canvas/

我尝试使用代码,但它并没有在我弄乱的小提琴中工作(不能发布链接到JS Fiddle,因为我没有足够的代表:

    function generateRGBKs( img ) {
    var w = img.width;
    var h = img.height;
    var rgbks = [];

    var canvas = document.createElement("canvas");
    canvas.width = w;
    canvas.height = h;

    var ctx = canvas.getContext("2d");
    ctx.drawImage( img, 0, 0 );

    var pixels = ctx.getImageData( 0, 0, w, h ).data;

    // 4 is used to ask for 3 images: red, green, blue and
    // black in that order.
    for ( var rgbI = 0; rgbI < 4; rgbI++ ) {
        var canvas = document.createElement("canvas");
        canvas.width  = w;
        canvas.height = h;

        var ctx = canvas.getContext('2d');
        ctx.drawImage( img, 0, 0 );
        var to = ctx.getImageData( 0, 0, w, h );
        var toData = to.data;

        for (
                var i = 0, len = pixels.length;
                i < len;
                i += 4
        ) {
            toData[i  ] = (rgbI === 0) ? pixels[i  ] : 0;
            toData[i+1] = (rgbI === 1) ? pixels[i+1] : 0;
            toData[i+2] = (rgbI === 2) ? pixels[i+2] : 0;
            toData[i+3] =                pixels[i+3]    ;
        }

        ctx.putImageData( to, 0, 0 );

        // image is _slightly_ faster then canvas for this, so convert
        var imgComp = new Image();
        imgComp.src = canvas.toDataURL();

        rgbks.push( imgComp );
    }

    return rgbks;
}

function generateTintImage( img, rgbks, red, green, blue ) {
    var buff = document.createElement( "canvas" );
    buff.width  = img.width;
    buff.height = img.height;

    var ctx  = buff.getContext("2d");

    ctx.globalAlpha = 1;
    ctx.globalCompositeOperation = 'copy';
    ctx.drawImage( rgbks[3], 0, 0 );

    ctx.globalCompositeOperation = 'lighter';
    if ( red > 0 ) {
        ctx.globalAlpha = red   / 255.0;
        ctx.drawImage( rgbks[0], 0, 0 );
    }
    if ( green > 0 ) {
        ctx.globalAlpha = green / 255.0;
        ctx.drawImage( rgbks[1], 0, 0 );
    }
    if ( blue > 0 ) {
        ctx.globalAlpha = blue  / 255.0;
        ctx.drawImage( rgbks[2], 0, 0 );
    }

    return buff;
}

var img = new Image();
img.onload = function() {
    var rgbks = generateRGBKs( img );
    var tintImg = generateTintImage( img, rgbks, 200, 50, 100 );

    var canvas = document.getElementById("canvas");
    var ctx = canvas.getContext("2d");
    ctx.fillStyle = "black";
    ctx.fillRect( 0, 0, 100, 100 );

    ctx.drawImage( tintImg, 50, 50 );
}

img.src = "https://pbs.twimg.com/profile_images/413816438701309953/uvZMK_gT_normal.jpeg";

我确定我做过的事情很愚蠢而Joe的代码没有任何问题 - 任何人都可以帮我搞定吗?

非常感谢:)

1 个答案:

答案 0 :(得分:0)

因为您正在访问像素数据,所以图片需要与代码位于同一个域中,或者您可以尝试使用base64 src。

img.src = "";

您正在违反CORS政策

继承人工作JSFiddle