English 中文(简体)
• 如何选择和改变一套带有“一个特殊标准”的颜色,将其改成“ Java”图像的另一种具体颜色
原标题:How to select and change a set of pixels with ONE SPECIFIC COLOR and change them to another specific color on an image in JavaScript [closed]
Closed. This question needs details or clarity. It is not currently accepting answers.

Want to improve this question? Add details and clarify the problem by editing this post.

Closed yesterday.

This post was edited and submitted for review 7 hours ago.

我目前正在开展一个项目,记录每个单方gam季的 record,并登上。 罗马尼亚 因此,在这种情况下,我需要找到所有与彩色编码(0,255,2)

www.un.org/Depts/DGACM/index_spanish.htm 我愿意使用原始产品。

EDIT

我找到了一种解决办法,也扩大了形象:

var img = document.getElementById( img );

img.onload = function() {

    var scale = 8;

    var src_canvas = document.createElement( canvas );
    src_canvas.width = this.width;
    src_canvas.height = this.height;
    
    var src_ctx = src_canvas.getContext( 2d );
    src_ctx.drawImage(this, 0, 0);
    var src_data = src_ctx.getImageData(0, 0, this.width, this.height).data;
    
    var dst_canvas = document.getElementById( canvas );
    dst_canvas.width = this.width * scale;
    dst_canvas.height = this.height * scale;
    var dst_ctx = dst_canvas.getContext( 2d );

    var offset = 0;
    for (var y = 0; y < this.height; ++y) {
        for (var x = 0; x < this.width; ++x) {
            var r = src_data[offset++];
            var g = src_data[offset++];
            var b = src_data[offset++];
            var rgb =  rgb(  + [r, g, b].join( , ) +  ) ;
            if (rgb ==  rgb(0,255,0) ) {
                r = 48;
              g = 63;
              b = 223;
            }
            var a = src_data[offset++] / 100.0;
            dst_ctx.fillStyle =  rgba(  + [r, g, b, a].join( , ) +  ) ;
            dst_ctx.fillRect(x * scale, y * scale, scale, scale);
        }
    }
};
<canvas id="canvas" />
<img src="http://image-tester.gtoy118.repl.co/players/0.png" id="img">

View the results on 页: 1

问题回答

You can draw an image on a canvas, get the image s data and manipulate the pixels and save the canvas as an image. An example how you can manipulate an image s pixels (here we change color (hue)). In your case find pixels with the needed color and change them.

const img = document.querySelector( img )

const canvas = document.querySelector( canvas )
const ctx = canvas.getContext( 2d )

img.onload = () =>{
    canvas.width = img.naturalWidth
    canvas.height = img.naturalHeight

    ctx.drawImage(img, 0, 0)
};

canvas.addEventListener( click , () => {

    const image = ctx.getImageData(0, 0, canvas.width, canvas.height);
    const { data } = image;

    const transformed = ctx.createImageData(image);
    const newdata = transformed.data;

    let idx = 3;
    while (idx < data.length) {
        if (data[idx]) {
            const hsl = rgbToHsl(data[idx - 3], data[idx - 2], data[idx - 1]);
            hsl[0] = 1;
            const rgb = hslToRgb(...hsl);
            newdata[idx - 3] = rgb[0];
            newdata[idx - 2] = rgb[1];
            newdata[idx - 1] = rgb[2];
            newdata[idx] = data[idx];
        }
        idx += 4;
    }

    ctx.putImageData(transformed, 0, 0);
});

// taken from https://gist.github.com/emanuel-sanabria-developer/5793377

function rgbToHsl(r, g, b) {
    r /= 255, g /= 255, b /= 255;
    var max = Math.max(r, g, b), min = Math.min(r, g, b);
    var h, s, l = (max + min) / 2;

    if (max == min) {
        h = s = 0; // achromatic
    } else {
        var d = max - min;
        s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
        switch (max) {
            case r: h = (g - b) / d + (g < b ? 6 : 0); break;
            case g: h = (b - r) / d + 2; break;
            case b: h = (r - g) / d + 4; break;
        }
        h /= 6;
    }

    return [h, s, l];
}

function hslToRgb(h, s, l) {
    var r, g, b;

    if (s == 0) {
        r = g = b = l; // achromatic
    } else {
        function hue2rgb(p, q, t) {
            if (t < 0) t += 1;
            if (t > 1) t -= 1;
            if (t < 1 / 6) return p + (q - p) * 6 * t;
            if (t < 1 / 2) return q;
            if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;
            return p;
        }

        var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
        var p = 2 * l - q;
        r = hue2rgb(p, q, h + 1 / 3);
        g = hue2rgb(p, q, h);
        b = hue2rgb(p, q, h - 1 / 3);
    }

    return [r * 255, g * 255, b * 255];
}
<div>Click the image:</div>
<canvas style="cursor:pointer"></canvas>
<img hidden src="">




相关问题
selected text in iframe

How to get a selected text inside a iframe. I my page i m having a iframe which is editable true. So how can i get the selected text in that iframe.

How to fire event handlers on the link using javascript

I would like to click a link in my page using javascript. I would like to Fire event handlers on the link without navigating. How can this be done? This has to work both in firefox and Internet ...

How to Add script codes before the </body> tag ASP.NET

Heres the problem, In Masterpage, the google analytics code were pasted before the end of body tag. In ASPX page, I need to generate a script (google addItem tracker) using codebehind ClientScript ...

Clipboard access using Javascript - sans Flash?

Is there a reliable way to access the client machine s clipboard using Javascript? I continue to run into permissions issues when attempting to do this. How does Google Docs do this? Do they use ...

javascript debugging question

I have a large javascript which I didn t write but I need to use it and I m slowely going trough it trying to figure out what does it do and how, I m using alert to print out what it does but now I ...

Parsing date like twitter

I ve made a little forum and I want parse the date on newest posts like twitter, you know "posted 40 minutes ago ","posted 1 hour ago"... What s the best way ? Thanx.

热门标签