• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

javascript - Cordova 如何从相机旋转图片

[复制链接]
菜鸟教程小白 发表于 2022-12-13 10:07:14 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我用 Cordova 相机插件拍照 camera.getPicture() 接口(interface)

并获取 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;
};



Best Answer-推荐答案


可以使用 Canvas 实现图像旋转,

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():旋转图像

Refer

关于javascript - Cordova 如何从相机旋转图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32242151/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap