在此示例中,我使用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。
如何像裁剪后的预览一样将裁剪后的图像保存为圆形?
答案 0 :(得分:1)
您还需要为.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()
可以获取农作物的四舍五入版本,因此只需在ajap调用中使用它,例如
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');
}
});
});
});
答案 1 :(得分:0)
我认为jquery-cropper.js不存在此功能getroundedcanvas(),如果是您,则您的功能已经做得很好,我真的很需要它,这就是我添加的内容,用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;