我正在使用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();
那是来自response
的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
文件夹上查看图像时,它是一个不是圆形的矩形图像。
以下是裁剪后的预览方法:这就是它在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');
}
});
});
});