Dynamically Changing Image Colours

Dynamically changing image colours

I would use jQuery for this and set the color behind the png or of the png regarding the css class/es of the table.

Dont use too much php like Imagemagick because it slows down the rendering of the page dramatically.

take a look at Pixastic (coloradjust)

https://github.com/jseidelin/pixastic
http://www.pixastic.com/lib/docs/actions/coloradjust/

or PaintbrushJS (colour tint)

https://github.com/mezzoblue/PaintbrushJS

http://mezzoblue.github.com/PaintbrushJS/demo/

or CamanJS (colorize)

http://camanjs.com/

http://camanjs.com/guides/#BuiltIn

https://github.com/meltingice/CamanJS/

or VintageJS
http://rendro.github.io/vintageJS/

https://github.com/rendro/vintageJS

Dynamically Change Image Object Color and Set Text

What I recommend to do is split (in any graphic tool) the image to 3 parts: background, gift body, and strap.

The gift image will be overlay of this 3. when the gift body is grayscale, drawn with canvas, and go over color filter anytime the color change.

Something like this:

var canvas = document.getElementById('gift-body');    var ctx = canvas.getContext('2d');    var mCanvas = document.createElement('canvas');    var mCtx = mCanvas.getContext('2d');    mCanvas.width = canvas.width;    mCanvas.height = canvas.height;    var img = new Image();    img.onload = function(){        mCtx.drawImage(img, 0, 0, canvas.width, canvas.height);        updateImage('#1013a1');    };    img.src = '';
function colorize(r, g, b) { var imageData = mCtx.getImageData(0, 0, canvas.width, canvas.height); for (var i=0; i<imageData.data.length; i+=4){ imageData.data[i] *= r/255; imageData.data[i+1] *= g/255; imageData.data[i+2] *= b/255; } ctx.putImageData(imageData, 0, 0); } function hexToRgb(hex) { hex = parseInt(hex, 16); var r = hex >>16; var g = (hex - (r<<16)) >>8; var b = hex - (r<<16) - (g<<8); return [r, g, b]; } function updateImage(color) { color = hexToRgb(color.replace('#', '')); colorize(color[0], color[1], color[2]); }
#img-cont {            position: relative;            width: 500px;            height: 500px;            margin: auto;        }        img, canvas {            position: absolute;            display: block;            top:0;            left:0;            width: 100%;            height: 100%;        }        label {            display: block;            text-align: center;            margin: 20px;        }
<label>Pick  a color: <input type="color" onchange="updateImage(this.value)" value="#1013a1"/></label><div id="img-cont">    <img id="gift-bg" src="https://i.stack.imgur.com/QdB9U.png"/>    <canvas id="gift-body" width="500" height="500"></canvas>    <img id="gift-strap" src="https://i.stack.imgur.com/Y9DND.png"/></div>

How to change color of certain parts of an image dynamically?

You would use multiple svgs that would be layered on top of each other. And then using javascript you could modify the color and replace content of svg with different variation.

You would have different layer for hair, eyes, lips, face, nose, ears, and so on. User would be able to just change one item at a time, and it'd affect one layer.

Once user is happy he would click save, and then you could save information about all layers in json format and this way always be able to recreate it, but if you wanted you can also convert it to png.

One way to do it would be this: Drawing an SVG file on a HTML5 canvas

But ideally i'd want backend to take just information on configuration like below and build picture there.

 {
face: {
eyes: 3,
nose: 1,
hair: 4,
skin: 3
},
colors: {
eyes: 3,
general: 1,
nose: 4
},
accessories: [{
{
name: 'hat',
x: 30,
y: 10,
type: 3
}, {
name: 'sticker_star',
x: 20,
y: 10,
type: 1
}, {
name: 'glasses',
x: 550,
y: 30,
type: 1
}
}]
}

SVG change dynamic color

You can convert the given svg url into text and then you can change the color by using the fill and stroke methods in CSS.

the code would be,

    function getTheSvg(url) {
return fetch(url).then((res) => res.text());
}
const getTextFromSvg = async (url) => {

let svgVal = await getTheSvg(url).then((res) => {

return res;
});
getTextFromSvg("https://yoururl.svg");

Changing colors of an image dynamically

That's not going to be easy the way the image is. You have no way to tell the computer which part is the bow, which part is the stripes, and which part is the box. However, if you pre-colored them, you could do a color replace using GD library or imagemagick pretty easily. You'd do this in PHP. Here are some examples of how you could do it, I'd personally go the imagemagick route.

How can I replace one color with another in a png 24 alpha transparent image with GD

http://www.imagemagick.org/Usage/color_basics/#replace
(this example even has a similar gift box as the usage case, hehe)



Related Topics



Leave a reply



Submit