欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

一文看懂h5+app拍照上传图片

程序员文章站 2022-06-17 10:17:41
h5+app上传图片一、引入axios等组件二、相机拍照三、上传图片一、引入axios等组件import axios from 'axios';import qs from 'qs';import { MessageBox } from 'mint-ui';二、相机拍照先定义div容器和按钮,用于点击拍照和上传图片
+ 拍摄现场照片
...

一、引入axios等组件

import axios from 'axios';
import qs from 'qs';
import { MessageBox } from 'mint-ui';

二、相机拍照

先定义div容器和按钮,用于点击拍照和上传图片

 <div class="camera" @click="camera">+ 拍摄现场照片</div>
 <div class="button">
   		<el-button type="primary" class="submit" @click="addForm">提交巡检数据</el-button>
 </div>

调用摄像头拍照(可进行适当的图片压缩转换)

// 调用摄像头
camera() {
	let that = this;
  	var cmr = plus.camera.getCamera(); //获取摄像头管理对象
 	var res = cmr.supportedImageResolutions[0]; //字符串数组,摄像头支持的拍照分辨率
  	var fmt = cmr.supportedImageFormats[0]; //字符串数组,摄像头支持的拍照文件格式
  	console.log("拍照分辨率: " + res + ", 拍照文件格式: " + fmt);
	cmr.captureImage(function(path) {
	    //进行拍照操作
    	// 通过URL参数获取目录对象或文件对象
	    plus.io.resolveLocalFileSystemURL(path, function(entry) {
		    var tmpPath = entry.toLocalURL(); //获取目录路径转换为本地路径URL地址
		    that.fileSrc = tmpPath
		    that.setImg(that.fileSrc);
	    });
   }
},

// 对图片进行适当处理
setImg(fileSrc) {
  	let that = this;
  	var name = JSON.stringify(fileSrc).split('/')
  	var file_name = name[name.length - 1].split('.')[0]
  	plus.zip.compressImage(
	    {
	      	src: fileSrc,
		    dst: "_doc/" + file_name + ".jpg",    //定义图片地址
		    overwrite: true,  //是否覆盖原来文件
		    //width: '270px',  //图片宽度 设置则表示缩放
		    //height:'270px',  //图片高度 设置则表示缩放
		    format: 'jpg',  //图片压缩后的格式
		    quality: 50   //图片压缩的质量 最高100 默认50
	    },
	    function(e) {
		    var image = new Image();
		    image.src = e.target;
		    image.width = e.width;
		    image.height = e.height;
		    image.size = e.size;
		    image.index = index;
		    that.scanFileArr.push(image);
	    },
	    function(err) {
		    plus.nativeUI.alert('未知错误!', function() { });
	    }
  )
}

三、上传图片

// 提交巡检数据
addForm() {
  let that = this
  if(that.fileSrc == ''){
      MessageBox.alert('上传附件不能为空!').then(action => {});
      return
  }
  // 请求上传管理创建新的上传任务,创建成功则返回Upload对象,用于管理上传任务。
  var task = plus.uploader.createUpload(that.api+ "接口地址",{ method:"POST"},
     function ( t, status ) {
     	//  解析上传成功返回的数据
        that.uploaderBackData = JSON.parse( t.responseText)
        that.uploadFileArr = []
        that.uploadFileArr.push(that.uploaderBackData.file_guid)
            // 上传完成
            if ( that.uploaderBackData.status == 200 ) {
                // 图片上传完成,可进行下一步的操作(可以进行添加一类的操作)
                if(that.note == ''){
	                 MessageBox.alert('巡检描述不能为空!').then(action => {});
	                 return
                }
            } else {
              	MessageBox.alert('图片上传失败!').then(action => {});
            }
      });
      // 向上传任务中添加文件,必须在任务开始上传前调用。  
      // 第一个参数是文件上传的路径,支持本地的文件,可以将刚才拍照得到的路径放在这里
      // 第二个参数是要添加上传文件的参数
      task.addFile( that.fileSrc, {key:"files"} );
      // 向上传任务中添加数据,必须在任务开始上传前调用
	  task.addData("current_project_id", that.project_id);
	  // 开始上传任务
      task.start();
},

这样一个简单的h5+app上传图片就完成啦!

本文地址:https://blog.csdn.net/qq_43958325/article/details/110939139

相关标签: h5+app javascript