调用h5+ 相机方法,并将照片转为base64格式

调用h5+ 相机方法,并将照片转为base64格式

plus.camera.getCamera

// 调用相机
    chooseImage(o) {
      try {
        const camera = plus.camera.getCamera();
        camera.captureImage(function (path) {
          // path  为获取拍照照片的url
          plus.io.resolveLocalFileSystemURL(path, async (entry) => {
            // entry 为获取的文件对象
            // 图片太大,进行压缩
            const res = await _this.compressImage(
              entry.toLocalURL(),
              entry.name
            );
            // 将压缩后的转化为base64格式
            const url = await _this.showPics(res.target, entry.name);
          
          });
        });
      } catch (err) {
        alert("请使用手机操作");
        console.log("请使用手机操作");
      }
    },
        // 压缩
    compressImage(url, filename) {
      return new Promise((resolve, reject) => {
        var name = "_doc/upload/" + filename;
        plus.zip.compressImage(
          {
            src: url, //src: (String 类型 )压缩转换原始图片的路径
            dst: name, //压缩转换目标图片的路径
            quality: 90, //quality: (Number 类型 )压缩图片的质量.取值范围为1-100
            overwrite: true, //overwrite: (Boolean 类型 )覆盖生成新文件
            width: "250",
            height: "320",
          },
          function (zip) {
            //页面显示图片
            // showPics(zip.target, name);
            resolve(zip);
          },
          function (error) {
            reject(error);
            // plus.nativeUI.toast("压缩图片失败,请稍候再试");
          }
        );
      });
    },
    // 转base64
    showPics(url, name) {
      return new Promise((resolve, reject) => {
        //根据路径读取到文件
        plus.io.resolveLocalFileSystemURL(url, function (entry) {
          entry.file(function (file) {
            var fileReader = new plus.io.FileReader();
            fileReader.readAsDataURL(file);
            fileReader.onloadend = function (e) {
              var picUrl = e.target.result.toString();
              resolve(picUrl);
            };
          });
        });
      });
    },
posted @ 2022-06-15 18:08  --奇--  阅读(795)  评论(0)    收藏  举报