javascript - 从 Cropper 保存圆形裁剪图像

标签 javascript php ajax image blob

我使用 Cropper 将本示例中的图像裁剪为圆形: https://github.com/fengyuanchen/cropperjs/blob/master/examples/crop-a-round-image.html

这是一个 fiddle :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)响应:

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 文件夹中的图像时,它是一个矩形图像,而不是圆形。

以下是裁剪后的预览方式: Circular 这就是在 uploads 文件夹中预览的方式: Rectangular 两个图像(预览和保存)均为 360x360。

如何将裁剪后的图像保存为圆形,就像裁剪后预览的那样?

最佳答案

您还需要为.cropper-crop-box添加舍入框CSS

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

如果你想要圆形 View 框,你可以使用这个

.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');
            }
        });
    });
});

关于javascript - 从 Cropper 保存圆形裁剪图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52133624/

相关文章:

javascript - cfselect 绑定(bind)和 jquery 事件冲突

javascript - 突出显示电话号码并用标签 javascript 括起来

php insert语句未在mysql中插入数据

jquery - 使用jquery和参数调用WCF服务

javascript - html 如何将用户字段输入作为 json 对象发送

javascript - 打印图像时无法读取数据 - GCP

javascript - 之前的web form录入数据后,如何让web form出现?

php - Markdown 文件到 HTML

php - Twitter api 1.1 图像未显示在提要中

Android 2.3.3 网页 View