簡體   English   中英

從 Cropper 保存圓形裁剪圖像

[英]Save the circular crop image from Cropper

我正在使用 Cropper 從這個例子中以圓形裁剪圖像: https : //github.com/fengyuanchen/cropperjs/blob/master/examples/crop-a-round-image.html

這是一個小提琴: http : //jsfiddle.net/7hsr98w4/7/

這就是裁剪后的圖像的樣子:

<img src="">

然后我使用 Ajax 將該 blob 發送到 PHP 以上傳該圖像:

document.getElementById('button').addEventListener('click', function(){
    var imgurl = cropper.getCroppedCanvas().toDataURL();
    cropper.getCroppedCanvas().toBlob(function (blob) {
        var formData = new FormData();
        formData.append('avatar', blob);
        // Use `jQuery.ajax` method
        $.ajax('upload.php', {
            method: "POST",
            data: formData,
            processData: false,
            contentType: false,
            success: function (response) {
                console.log(response);
            },
            error: function () {
                console.log('Upload error');
            }
        });
    });
});

此代碼可以在這里找到: https : //github.com/fengyuanchen/cropperjs#getcroppedcanvasoptions

在upload.php中:

print_r($_FILES);
if(isset($_FILES['avatar']) and !$_FILES['avatar']['error']){
   file_put_contents("uploads/image.png", file_get_contents($_FILES['avatar']['tmp_name']));
}   
exit();

這是來自print_r($_FILES)response

Array
(
    [avatar] => Array
        (
            [name] => blob
            [type] => image/png
            [tmp_name] => C:\xampp\tmp\php2BDA.tmp
            [error] => 0
            [size] => 2135
        )

)

當我console.log() blob ,我得到和Object

Blob(2135) {size: 2135, type: "image/png"}

但是當我查看uploads文件夾中的圖像時,它是一個矩形圖像而不是圓形。

這是裁剪后的預覽方式: 圓 這就是它在uploads文件夾中的預覽方式: 矩形的 兩個圖像(預覽和保存)都是 360x360。

如何像裁剪后的預覽那樣將裁剪后的圖像保存為圓形?

您還需要為.cropper-crop-box添加舍入框 css

.cropper-crop-box, .cropper-view-box {
    border-radius: 50%;
}

如果你想要圓形視圖框,你可以使用這個

.cropper-view-box {
    box-shadow: 0 0 0 1px #39f;
    outline: 0;
}

更新:抱歉,我誤解了您的問題,實際上您想要的是非常簡單的

您已經有了getRoundedCanvas() ,它可以為您提供裁剪的圓形版本,因此只需在您的 ajax 調用中使用它,例如

document.getElementById('button').addEventListener('click', function(){
    var imgurl = cropper.getCroppedCanvas().toDataURL();

    //only this line is changed
    getRoundedCanvas(cropper.getCroppedCanvas()).toBlob(function (blob) { 
        var formData = new FormData();
        formData.append('avatar', blob);
        // Use `jQuery.ajax` method
        $.ajax('upload.php', {
            method: "POST",
            data: formData,
            processData: false,
            contentType: false,
            success: function (response) {
                console.log(response);
            },
            error: function () {
                console.log('Upload error');
            }
        });
    });
});

我認為這個函數 getroundedcanvas() 不存在於 jquery-cropper.js,如果是你,你已經用你的函數做得很好,我真的很需要它,這就是我添加和上傳的PHP。

case 'getCroppedCanvas':
      if (result) {
        // Upload cropped image to server if the browser supports `HTMLCanvasElement.toBlob`.
        // The default value for the second parameter of `toBlob` is 'image/png', change it if necessary.

        // Round
        var roundedCanvas = getRoundedCanvas(result);
        // Show
        $('img.MyImage').attr('src',roundedCanvas.toDataURL());
        var roundedBlob ;
        roundedCanvas.toBlob((blob) => {
          roundedBlob = blob;
        });
        result.toBlob((blob) => {
          const formData = new FormData();

          // Pass the image file name as the third parameter if necessary.
          formData.append('UploadPhoto', blob, 'profil.png' );
          formData.append('CircleBlob', roundedBlob, 'circle.png' );
          $.ajax(document.location.pathname, {
            method: 'POST',
            data: formData,
            processData: false,
            contentType: false,
            success(response) {
              console.log(response);
              console.log('Upload success');
              $('#imgResizeModal').modal("hide");
            },
            error() {
              console.log('Upload error');
            },
          });
        }/*, 'image/png' */);
      }

      break;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM