Is there any way to manipulate the brightness of the image through Canvas?

3

I am developing a system where the user can make small adjustments in images, being able to rotate and cut currently. Before this whole part was being done through coordinates, where I sent the parameters to the server and from there processed the images.

I've now started to use canvas , where I can already make these edits directly in the client (browser) and then send the final image already edited.

When viewing the power of canvas I thought of adding other features, such as increasing / decreasing the brightness of some images.

Is there any way to control the brightness of the image through canvas ?

Please, if the answer involves mathematical calculations, I would like an explanation, not just the code that generates the desired result.

Let's re-use the parrot picture as an example:

window.addEventListener('load', onLoadPage)

function qs(selector) {
    return document.querySelector(selector);
}

function onLoadPage()
{
  
    var canvas    = qs('#canvas');
    var image     = qs('#image');

    canvas.height = image.height;
    canvas.width = image.width;

    var context = canvas.getContext('2d');

    context.drawImage(image, 0, 0);

}
<img id="image" src=''>
<canvas id="canvas" height="0"></canvas>
    
asked by anonymous 11.05.2017 / 16:58

1 answer

4

In summary, and in an easy way, simply multiply the values of RGB (separately) by a value. If the value is greater than 1, you are increasing the brightness. With this, of course, if the value is less than 1, you will decrease the brightness.

Starting from this method, just apply it in your model.

Below I'll be adding an example of how to do this in canvas .

var canvas = document.getElementById('myCanvas');
var context = canvas.getContext('2d');
var imagem = document.getElementById('image');


var img = new Image();
img.onload = function() {
  var imgX = canvas.width - img.width;
  var imgY = canvas.height - img.height;

  context.drawImage(img, imgX, imgY);

  var imageData = context.getImageData(imgX, imgY, img.width, img.height);
  var ia = imageData.data;

  //Valor multiplicador
  var multiplicador = 1.5;

  for (var i = 0; i < ia.length; i += 4) {
    //Obter o valor de RGB
    var red = ia[i];
    var green = ia[i + 1];
    var blue = ia[i + 2];

    //Multiplica pelo multiplicador
    var brilhoRed = multiplicador * red;
    var brilhoGreen = multiplicador * green;
    var brilhoBlue = multiplicador * blue;

    //Retorna o valor do RGB novo
    ia[i] = brilhoRed;
    ia[i + 1] = brilhoGreen;
    ia[i + 2] = brilhoBlue;
  }

  context.putImageData(imageData, imgX, imgY);
};

img.src = imagem.src;
<canvas id="myCanvas" width="578" height="200"></canvas>

<img id="image" src=''>

Now, if you do not want to do this "manually", you could use the CanvasEffect , so you can change things more easily .

See an example usage here.

References:

11.05.2017 / 20:40