K
K
Konstantin Vidyushchenko2022-02-25 18:36:46
JavaScript
Konstantin Vidyushchenko, 2022-02-25 18:36:46

I want to implement an improvement in the sharpness of a photo when changing the position of range (input)?

It is assumed that the image will be located on the canvas in order to edit the picture in real time. Implemented convolution with the matrix [0, -1, 0, -1, 5, -1.0, -1, 0], changes occur statically (immediately when uploading a photo to "canvas"). But I can't implement a change in the sharpening intensity with the help of a mix increase.
Please tell me how to implement this, using the processing of buffered typed arrays. It is planned to edit photos with a large size, on average 2500 px.

<canvas id="canvas"></canvas>
<input type="range" name="Sharp" id="mix" min="0.1" max="100" step="0.01" value="0">
<img src="" alt="" style="display: none;">

<script>
  //Setting the sharpness value
  let mix = document.getElementById("mix");
  mix.addEventListener("input", ()=>{update(mix)});  
  //create canvas
  canvas = document.getElementById("canvas");
  context = canvas.getContext("2d");
  //uploading a picture
  let img = new Image();  
  img.src = "";     
  //set the size of reserved memory
  canvas.width = img.width;
  canvas.height = img.height;
  //getting started with canvas
  img.onload = update;

  function sharpen (context, width, height, mix) {   
    //create an empty element with the given width/height
    let dstData = context.createImageData(width,height),
        dstBuff = new Uint32Array(dstData.data.buffer);        
    //collection of information
    let pixel = context.getImageData(0,0,width,height),
        data = new Uint32Array(pixel.data.buffer);    
    //Everything to work with the matrix
    let kernel = ,
        katet = Math.round(Math.sqrt(kernel.length))+1,//root 9=3
        half = (katet * 0.5) | 0,//3*0.5=1.5 discard values ​​after the decimal point
        offset = 0,//offset - coefficient
        div = 1.0;//div - divider        
    //pixel processing
    let dstIndex = 0;
      for (let y = 0; y < height; y++) {
        for (let x = 0; x < width; x++) {
          let r = 0, g = 0, b = 0;
          for (let sy = 0; sy < katet; sy++) {
            const yy = Math.min(height - 1, Math.max(0, y + sy - half));
            for (let sx = 0; sx < katet; sx++) {
              const xx = Math.min(width - 1, Math.max(0, x + sx - half));
              let pix = data[yy * width + xx];                    
              r += ((pix & 0xFF) * kernel[sy][sx]);
              g += ((((pix) >> 8) & 0xFF) * kernel[sy][sx]);
              b += ((((pix) >> 16) & 0xFF) * kernel[sy][sx]); 
            }
          }        
          const a = data[y * width + x] & 0xFF000000;
          r = (Math.min(255, Math.max(0, offset + (r / div)))) & 0xFF;
          g = (Math.min(255, Math.max(0, offset + (g / div)))) & 0xFF;
          b = (Math.min(255, Math.max(0, offset + (b / div)))) & 0xFF;             
          dstBuff[dstIndex++] = a | ((b) << 16) | ((g) << 8) | r;//fill with changes
        }
      }
      context.putImageData(dstData, 0, 0);//overwriting the canvas with new data         
      }
 
function update() {
  context.drawImage(img, 0, 0);  
  sharpen(context, img.width, img.height, parseInt(mix.value) * 0.01)
}
</script>

Answer the question

In order to leave comments, you need to log in

1 answer(s)
K
Konstantin Vidyushchenko, 2022-03-03
@VidKein

Issue resolved.
Below is the working code.

<canvas id="canvas"></canvas>
<input type="range" name="Sharp" id="mix" min="0.1" max="100" step="0.01" value="0">

//Setting the sharpness value
let mix = document.getElementById("mix");
  mix.addEventListener("input", ()=>{update(mix)});  
  //create canvas
  canvas = document.getElementById("canvas");
  context = canvas.getContext("2d");
  //uploading a picture
  let img = new Image();  
  img.src = "";     
  //set the size of reserved memory
  canvas.width = img.width;
  canvas.height = img.height;
  //getting started with canvas
  img.onload = update;

  function sharpen (context, width, height, mix) {   
    //create an empty element with the given width/height
    let dstData = context.createImageData(width,height),
        dstBuff = new Uint32Array(dstData.data.buffer);        
    //collection of information
    let pixel = context.getImageData(0,0,width,height),
        data = new Uint32Array(pixel.data.buffer);    
    //Everything to work with the matrix
    let kernel = ,
        katet = Math.round(Math.sqrt(kernel.length))+1,//root 9=3
        half = (katet * 0.5) | 0;//3*0.5=1.5 discard values ​​after the decimal point      
    //pixel processing
    let dstIndex = 0;
      for (let y = 0; y < height; y++) {
        for (let x = 0; x < width; x++) {
          let r = 0, g = 0, b = 0;
          for (let sy = 0; sy < katet; sy++) {
            const yy = Math.min(height - 1, Math.max(0, y + sy - half));
            for (let sx = 0; sx < katet; sx++) {
              const xx = Math.min(width - 1, Math.max(0, x + sx - half));
              let pix = data[yy * width + xx];                    
              r += ((pix & 0xFF) * kernel[sy][sx]);
              g += ((((pix) >> 8) & 0xFF) * kernel[sy][sx]);
              b += ((((pix) >> 16) & 0xFF) * kernel[sy][sx]); 
            }
          }        
          red = Math.min(255,Math.max(0, (r*mix)+((data[y * width + x] )&0xFF)*(1-mix) ))&0xFF;
          green = Math.min(255, Math.max(0, (g*mix)+(((data[y * width + x])>> 8)&0xFF)*(1-mix) ))&0xFF;
          blue = Math.min(255, Math.max(0, (b*mix)+(((data[y * width + x])>> 16)&0xFF)*(1-mix) ))&0xFF;
          const alfa = data[y * width + x] & 0xFF000000;

          dstBuff[dstIndex++] = red | ((green) << 8) | ((blue) << 16) | alfa | ((blue) << 16);//fill with changes
        }
      }
      context.putImageData(dstData, 0, 0);//overwriting the canvas with new data         
      }
 
function update() {
  canvas.width = img.width;
  canvas.height = img.height;
  context.drawImage(img, 0, 0);  
  sharpen(context, img.width, img.height, parseInt(mix.value) * 0.01)
}

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question