Need help with reloading canvas on button click

Hello,
My name is Claudiu,
I have a javascript code that loads an image and then on that image its apply an spray effect.
I need to reload the script after the gwd-taparea_1 button is clicked
document.getElementById('gwd-taparea_1').addEventListener('click', function() {

Here is the code:

<script>
    (function() {

      'use strict';

      var isDrawing, lastPoint;
      var container = document.getElementById('js-container'),
        canvas = document.getElementById('js-canvas'),
        canvasWidth = canvas.width,
        canvasHeight = canvas.height,
        ctx = canvas.getContext('2d'),
        image = new Image(),
        brush = new Image();

      // base64 Workaround because Same-Origin-Policy
      image.src = "image1"; // here i load the image
      image.onload = function() {
        ctx.drawImage(image, 0, 0);
        // Show the form when Image is loaded.
        document.querySelectorAll('.form')[0].style.visibility = 'visible';
      };
// hext is the brush image
      brush.src = '';

      canvas.addEventListener('mousedown', handleMouseDown, false);
      canvas.addEventListener('touchstart', handleMouseDown, false);
      canvas.addEventListener('mousemove', handleMouseMove, false);
      canvas.addEventListener('touchmove', handleMouseMove, false);
      canvas.addEventListener('mouseup', handleMouseUp, false);
      canvas.addEventListener('touchend', handleMouseUp, false);




      function distanceBetween(point1, point2) {
        return Math.sqrt(Math.pow(point2.x - point1.x, 2) + Math.pow(point2.y - point1.y, 2));
      }

      function angleBetween(point1, point2) {
        return Math.atan2(point2.x - point1.x, point2.y - point1.y);
      }

      // Only test every `stride` pixel. `stride`x faster,
      // but might lead to inaccuracy
      function getFilledInPixels(stride) {
        if (!stride || stride < 1) {
          stride = 1;
        }


        var pixels = ctx.getImageData(0, 0, canvasWidth, canvasHeight),
          pdata = pixels.data,
          l = pdata.length,
          total = (l / stride),
          count = 0;


        // Iterate over all pixels
        for (var i = count = 0; i < l; i += stride) {
          if (parseInt(pdata[i]) === 0) {
            count++;
          }
        }

        return Math.round((count / total) * 100);

      }



      function getMouse(e, canvas) {
        var offsetX = 0,
          offsetY = 0,
          mx, my;

        if (canvas.offsetParent !== undefined) {
          do {
            offsetX += canvas.offsetLeft;
            offsetY += canvas.offsetTop;
          } while ((canvas = canvas.offsetParent));
        }

        mx = (e.pageX || e.touches[0].clientX) - offsetX;
        my = (e.pageY || e.touches[0].clientY) - offsetY;

        return {
          x: mx,
          y: my
        };
      }

      function handlePercentage(filledInPixels) {
        filledInPixels = filledInPixels || 0;
        console.log(filledInPixels + '%');
        if (filledInPixels > 40) { // here is a step - when it reach to 40% the reload button apear
          document.getElementById("rBs").style.display = 'block';
          // canvas.parentNode.removeChild(canvas);
          document.getElementById("gwd-taparea_1").style.zIndex = 1002; //reload button
          document.getElementById("rBs").style.zIndex = 1001; //reload image

          // canvas = document.getElementById("canvas");

        }
        //  console.log('filledInPixels'+filledInPixels);
      }

      function handleMouseDown(e) {
        isDrawing = true;
        lastPoint = getMouse(e, canvas);
      }

      function handleMouseMove(e) {
        if (!isDrawing) {
          return;
        }

        e.preventDefault();

        var currentPoint = getMouse(e, canvas),
          dist = distanceBetween(lastPoint, currentPoint),
          angle = angleBetween(lastPoint, currentPoint),
          x, y;

        for (var i = 0; i < dist; i++) {
          x = lastPoint.x + (Math.sin(angle) * i) - 25;
          y = lastPoint.y + (Math.cos(angle) * i) - 25;
          ctx.globalCompositeOperation = 'destination-out';
          ctx.drawImage(brush, x, y);
        }

        lastPoint = currentPoint;
        handlePercentage(getFilledInPixels(32));
      }

      function handleMouseUp(e) {
        isDrawing = false;
      }



      document.getElementById('gwd-taparea_1').addEventListener('click', function() { 
// here i want to start all the script from the beginning  ============================   <=
   // ctx.clearRect(0,0,canvas.width,canvas.height); // try to clear the canvas and then reload but not working
  //  canvas = document.getElementById('js-canvas');

          
      }, false);
    })();
  </script>

On the botton of the script is the

document.getElementById('gwd-taparea_1').addEventListener('click', function() { 
// here i want to start all the script from the beginning  ============================   <=

try to clear the canvas and then reload but not working :cry:.
Thanks in advance!

<div id="js-container">
      <canvas id="js-canvas"></canvas>
 </div>
        
 <button id="gwd-taparea_1">Clear</button>

<script>
         'use strict';

         var isDrawing, lastPoint;
         var container = document.getElementById('js-container'),
         canvas = document.getElementById('js-canvas'),
         canvasWidth = canvas.width,
         canvasHeight = canvas.height,
         ctx = canvas.getContext('2d'),
         image = new Image(),
         brush = new Image();             
  
         image.src = "https://wallpaperbrowse.com/media/images/Dubai-Photos-Images-Oicture-Dubai-Landmarks-800x600.jpg"; // here i load the image
         image.onload = function() {
         ctx.drawImage(image, 0, 0);        
         };  
            
         brush.src = '';
          
    function drawCanvas(arg){
              
          arg.addEventListener('mousedown', handleMouseDown, false);
          arg.addEventListener('touchstart', handleMouseDown, false);
          arg.addEventListener('mousemove', handleMouseMove, false);
          arg.addEventListener('touchmove', handleMouseMove, false);
          arg.addEventListener('mouseup', handleMouseUp, false);
          arg.addEventListener('touchend', handleMouseUp, false);
              
              function distanceBetween(point1, point2) {
              return Math.sqrt(Math.pow(point2.x - point1.x, 2) + Math.pow(point2.y - point1.y, 2));
              }

              function angleBetween(point1, point2) {
              return Math.atan2(point2.x - point1.x, point2.y - point1.y);
              }

      // Only test every `stride` pixel. `stride`x faster,
      // but might lead to inaccuracy
              function getFilledInPixels(stride) {
              if (!stride || stride < 1) {
              stride = 1;
              }


            var pixels = ctx.getImageData(0, 0, canvasWidth, canvasHeight),
              pdata = pixels.data,
              l = pdata.length,
              total = (l / stride),
              count = 0;


        // Iterate over all pixels
            for (var i = count = 0; i < l; i += stride) {
               if (parseInt(pdata[i]) === 0) {
                 count++;
               }
            }

            return Math.round((count / total) * 100);

            }

          function getMouse(e, canvas) {
            var offsetX = 0,
            offsetY = 0,
            mx, my;

            if (canvas.offsetParent !== undefined) {
              do {
                 offsetX += canvas.offsetLeft;
                 offsetY += canvas.offsetTop;
              } while ((canvas = canvas.offsetParent));
            }

            mx = (e.pageX || e.touches[0].clientX) - offsetX;
            my = (e.pageY || e.touches[0].clientY) - offsetY;

            return {
            x: mx,
             y: my
            };
             }

        function handlePercentage(filledInPixels) {
        filledInPixels = filledInPixels || 0;
        console.log(filledInPixels + '%');
          if (filledInPixels > 40) { 
          document.getElementById("rBs").style.display = 'block';
          
          document.getElementById("gwd-taparea_1").style.zIndex = 1002; 
          document.getElementById("rBs").style.zIndex = 1001; 
           }
        
        }

        function handleMouseDown(e) {
         isDrawing = true;
         lastPoint = getMouse(e, canvas);
         
        }

        function handleMouseMove(e) {
            if (!isDrawing) {
            return;
        }

        e.preventDefault();

        var currentPoint = getMouse(e, canvas),
          dist = distanceBetween(lastPoint, currentPoint),
          angle = angleBetween(lastPoint, currentPoint),
          x, y;

        for (var i = 0; i < dist; i++) {
          x = lastPoint.x + (Math.sin(angle) * i) - 25;
          y = lastPoint.y + (Math.cos(angle) * i) - 25;
          ctx.globalCompositeOperation = 'destination-out';
          ctx.drawImage(brush, x, y);
        }

        lastPoint = currentPoint;
        handlePercentage(getFilledInPixels(32));
         }

         function handleMouseUp(e) {
        isDrawing = false;
        }
       }
       
//Call the function drawCanvas
       drawCanvas(canvas);
//Click event listener below       
       document.getElementById('gwd-taparea_1').addEventListener('click', function() {
//Remove the old canvas element
       var oldcanv = document.getElementById('js-canvas');
       container.removeChild(oldcanv);
//Create a new canvas element with tha same Id and append it to container
       var canvas = document.createElement('canvas');
       canvas.id = 'js-canvas';
       container.appendChild(canvas);
       canvasWidth = canvas.width,
       canvasHeight = canvas.height,
       ctx = canvas.getContext('2d');
       image.src='https://wallpaperbrowse.com/media/images/Dubai-Photos-Images-Oicture-Dubai-Landmarks-800x600.jpg';
       ctx.drawImage(image, 0, 0);
//Recall the drawCanvas function    
       drawCanvas(canvas);
          
      });
            
            
        </script>
1 Like

Hey,
Thanks a lot!
It’s really a great help to me.

I m trying to figured out how to make the reload canvas 100% width and height… now its only loading 300x150 px.
And i think it shall reload the spray pointer to.
Here its one preview:

https://www.google.com/doubleclick/studio/externalpreview/#/vL62GIYYSR68WTpaoSLYxQ?creativeId=60190396

Many thanks again.

You welcome.

1 Like

This topic was automatically closed 91 days after the last reply. New replies are no longer allowed.