一文看懂h5+app拍照上传图片
程序员文章站
2022-03-07 12:12:06
h5+app上传图片一、引入axios等组件二、相机拍照三、上传图片一、引入axios等组件import axios from 'axios';import qs from 'qs';import { MessageBox } from 'mint-ui';二、相机拍照先定义div容器和按钮,用于点击拍照和上传图片
+ 拍摄现场照片
h5+app上传图片
一、引入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