Cordova如何从相机旋转一张图片

3

使用Cordova相机插件的camera.getPicture() API拍摄照片,获得一个base64图像。

如果要将这个base64图像向右旋转90度并获取新的base64字符串来保存,可以使用以下代码:

Camera.getPicture(options).then(function(imageURI) {
        var img = new Image();
        img.src = "data:image/png;base64," + imageURI;

        var rotate = false;

        if (img.width > img.height) {
            rotate = true;
        }

         uploadImage(imageURI, activeIndex, rotate);

    }, function(err) {
        console.log(err);
        $ionicLoading.hide();
    });

旋转图片的函数

 var rotateImage = function (base64ImageSrc) {
    var canvas = document.createElement('canvas');
    var img = new Image();
    img.src = base64ImageSrc;
    var context = canvas.getContext('2d');

    // translate context to center of canvas
    context.translate(canvas.width / 2, canvas.height / 2);

    // rotate 45 degrees clockwise
    context.rotate(Math.PI / 4);

    console.log(canvas.toDataURL());
    var ImageUrl = canvas.toDataURL();
    ImageUrl = ImageUrl.split("data:image/png;base64,");
    ImageUrl = ImageUrl[1];
    console.log(ImageUrl);
    return ImageUrl;
};
1个回答

2
使用画布可以实现图像旋转。
function rotateBase64Image() {
        var canvas = document.createElement('canvas');
        var ctx = canvas.getContext("2d");

        var image = new Image();
        image.src = base64data;
        image.onload = function() {
            ctx.translate(image.width, image.height);
            ctx.rotate(180 * Math.PI / 180);
            ctx.drawImage(image, 0, 0); 
            window.eval(""+callback+"('"+canvas.toDataURL()+"')");
        };

 }

base64data: 包含Base64编码的照片图像[原始图像]的字符串

canvas.toDataURL(): 旋转后的图像

参考链接


它返回图像的Base64字符串,但非常短,因此看起来没问题。 - Avishai Peretz

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接