gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 01:13:09 25 4
gpt4 key购买 nike

我使用 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com