Как сжать рисунок уже при выборе файла (после съемки в случае фото на смартфоне) в коде обрезки для фото профиля на java script?

Пример (демо) работающего кода здесь https://habarlas.kz/. Можно ли сжать рисунок после выбора файла или съемки фото до кода обрезки и обрезать уже сжатый файл (рисунок)?

<script>
    $("body").on("change", "#browse_image", function(e) {
        var files = e.target.files;
        var done = function(url) {        
            $('#display_image_div').html('');
            $("#display_image_div").html('<img name="display_image_data" id="display_image_data" src="'+url+'" alt="Uploaded Picture">');
        
        };
        if (files && files.length > 0) {
            file = files[0];

        if (URL) {
            done(URL.createObjectURL(file));
        } else if (FileReader) {
            reader = new FileReader();
            reader.onload = function(e) {
                done(reader.result);
            };
            reader.readAsDataURL(file);
        }
    }
    
    var image = document.getElementById('display_image_data');
    var button = document.getElementById('crop_button');
    var result = document.getElementById('cropped_image_result');
    var croppable = false;
    var cropper = new Cropper(image, {
    aspectRatio: 1,
    viewMode: 1,
    ready: function () {
    croppable = true;
    },
    });

     button.onclick = function () {
  
    var croppedCanvas;
    var roundedCanvas;
    var roundedImage;

    if (!croppable) {
      return;
    }

    // Crop
    croppedCanvas = cropper.getCroppedCanvas();

    // Round
    roundedCanvas = getRoundedCanvas(croppedCanvas);

    // Show
    roundedImage = document.createElement('img');
        
    roundedImage.src = roundedCanvas.toDataURL()
    result.innerHTML = '';
    result.appendChild(roundedImage);
    };  
});

function getRoundedCanvas(sourceCanvas) {
  var canvas = document.createElement('canvas');
  var context = canvas.getContext('2d');
  var width = sourceCanvas.width;
  var height = sourceCanvas.height;

  canvas.width = width;
  canvas.height = height;
  context.imageSmoothingEnabled = true;
  context.drawImage(sourceCanvas, 0, 0, width, height);
  context.globalCompositeOperation = 'destination-in';
  context.beginPath();
  context.arc(width / 2, height / 2, Math.min(width, height) / 2, 0, 2 * Math.PI, true);
  context.fill();
  return canvas;
}

function download()
{
    var linkSource = $('#cropped_image_result img').attr('src');
    var fileName = 'download.png';  
    const downloadLink = document.createElement("a");
    downloadLink.href = linkSource;
    downloadLink.download = fileName;
    downloadLink.click();
}

function upload()
{
    var base64data = $('#cropped_image_result img').attr('src');
    //alert(base64data);
    $.ajax({
        type: "POST",
        dataType: "json",
        url: "crop_image_upload.php",
        data: {image: base64data},
        success: function(response) { 
             if(response.status == true)
             {
                alert(response.msg);
             }
             else
             {
                 alert("Image not uploaded.");
             }
        }
    });
}

Ответы (0 шт):