zoukankan      html  css  js  c++  java
  • ionic中调用cordova插件upload上传的问题,拍照and调用相册

      第一次写博客直接怼代码

    首先应该

    ionic cordova plugin add cordova-plugin-file-transfer
    npm install --save @ionic-native/file-transfer

    添加对象ImagePickerOptions 和 CameraOptions  是因为可以直接的看到错误提示

    import { ImagePicker, ImagePickerOptions } from '@ionic-native/image-picker';
    import { Camera, CameraOptions } from '@ionic-native/camera';
     
     
    // 拍照
    public takePhoto() {
    let imgData = '';
    let base64ImgData = '';
    let options: CameraOptions = {
    quality: 100, //相片质量0-100
    destinationType: 0, //返回类型:DATA_URL= 0,返回作为 base64 編碼字串。 FILE_URI=1,返回影像档的 URI。NATIVE_URI=2,返回图像本机URI (例如,資產庫)
    sourceType: this.camera.PictureSourceType.CAMERA, //从哪里选择图片:PHOTOLIBRARY=0,相机拍照=1,SAVEDPHOTOALBUM=2。0和1其实都是本地图库
    allowEdit: false, //在选择之前允许修改截图
    encodingType: this.camera.EncodingType.JPEG, //保存的图片格式: JPEG = 0, PNG = 1
    targetWidth: 200, //照片宽度
    targetHeight: 200, //照片高度
    mediaType: 0, //可选媒体类型:圖片=0,只允许选择图片將返回指定DestinationType的参数。 視頻格式=1,允许选择视频,最终返回 FILE_URI。ALLMEDIA= 2,允许所有媒体类型的选择。
    cameraDirection: 0, //枪后摄像头类型:Back= 0,Front-facing = 1
    saveToPhotoAlbum: true //保存进手机相册
    };
    this.camera.getPicture(options).then((imageData) => {
    this.upload(imageData);
    imgData = "data:image/jpeg;base64," + imageData;//“……” 就是一张图片的Data URL
    }, (err) => {
    //输出你的错误信息
    });
    }
     
     
    // 选取头像
    public checkImg() {
    let imgData = '';
    let options: ImagePickerOptions = {
    quality: 100,
    maximumImagesCount: 1,
    outputType: 1 //0 是文件路径 1 是base64
    };
    this.imagePicker.getPictures(options).then((results) => {
    for(let i = 0; i < results.length; i++) {
    this.upload(results[i]);
    imgData = "data:image/jpeg;base64," + results[i];//
    }
    },(err)=> {
    //输出你的错误提示
    });
    }
     
       //上传头像
      public upload(fileURL) {
        let options: FileUploadOptions = {
        fileKey: 'file',
        fileName: fileURL.substr(fileURL.lastIndexOf('/') + 1),
        mimeType: 'image/jpeg',
        httpMethod: 'POST'//请求方式 put或post
      }
      let params = {
        'key': 'value',
        '参数': '传给后台的数据'
    };
    options.params = params;
    let tempFileUrl = fileURL;
    let tempServe = '你的后台服务接口';
    this.fileTransfer.upload(fileURL,encodeURI(tempServe), options)//fileURL 本地文件路径
    .then((data) => {
    let resuleData = JSON.parse(data.response);//data.response这里可以获取请求后台返回的数据
    this.headImg = this.domSanitizer.bypassSecurityTrustUrl(resuleData.pam);//不会去angular 查
    },(err) => {
    this.globalFunction.showAlert('上传失败');
    });
    }
     
      cordova 官网地址 第一次写不是很有经验,如果看不得不是很清楚,可以去官网查看
      http://cordova.apache.org/docs/en/latest/reference/cordova-plugin-file-transfer/index.html#backwards-compatibility-notes
     
      下面是上传请求成功后通过以下数据获得你需要的数据,
     
     
  • 相关阅读:
    课程安排及脉络
    面向对象 魔法方法 单例(五)
    练习项目:选课系统
    面向对象 多态 类方法 反射 (四)
    面向对象(三) 组合 封装
    面向对象编程(二)
    面向对象编程(一)
    python入门总复习
    模块(四)
    模块(三)
  • 原文地址:https://www.cnblogs.com/ChineseLiao/p/7306006.html
Copyright © 2011-2022 走看看