⼩程序拍照和摄像功能实现⽅法⽰例
本⽂实例讲述了⼩程序拍照和摄像功能实现⽅法。分享给⼤家供⼤家参考,具体如下:
拍照
原先的想法是使⽤的camera组件来实现,并且模拟发朋友圈的样⼦来进⾏相机的设置,其实就是将camera组件的⼤⼩设置成根屏幕⼀样⼤,并在上⾯使⽤⼀个cover-image组件来给⽤户进⾏点击,可是实际上的情况是第⼀,cover-image组件有时候会消失,第⼆,整个流程实现起来很僵硬,页⾯跳转也是卡的要死,后来⽆意间发现了另⼀个API:wx.chooseImage,这个API会⾃⼰去调⽤相机和相册,之后的⼯作完全交给底层去实现,简直是简单到没朋友:
// 拍照功能
getLocalImage:function(){中秋节的好词好句
var that=this;
你就这样越走越远wx.chooseImage({
count:1,
success:function(res){
// 这⾥⽆论⽤户是从相册选择还是直接⽤相机拍摄,拍摄完成后的图⽚临时路径都会传递进来
奔驰女车主事件最新消息
app.startOperating("保存中")
var pFilePaths[0];
var session_StorageSync('session_key');
// 这⾥顺道展⽰⼀下如何将上传上来的⽂件返回给后端,就是调⽤wx.uploadFile函数于组词
wx.uploadFile({
url: app.globalData.url+'/home/upload/uploadFile/session_key/'+session_key,
filePath: filePath,
name: 'file',
success:function(res){
app.stopOperating();
// 下⾯的处理其实是跟我⾃⼰的业务逻辑有关
var data=JSON.parse(res.data);
if(parseInt(data.status)===1){
演员杜敏赫app.showSuccess('⽂件保存成功');
邯郸学步告诉我们什么道理}else{
app.showError("⽂件保存失败");
}
}
})
},
fail:function(error){
<("调⽤本地相册⽂件时出错")
console.warn(error)
},
complete:function(){
}
})
},
其中封装在app.js中的函数可以看我这篇⽂章:。
摄影
其实跟上⾯的原理是⼀样的,对应的API就是wx.chooseVideo,其中可以设置拍摄时间,⽤户拍摄结
束以及⽤户拍摄时间超时等,都会调⽤success的回调函数,所以⼜是可以安⼼处理接下来的业务流程,⽽不⽤需要调⽤camera组件。
// 摄像功能
getLocalVideo:function(){
var that=this;
var session_StorageSync('session_key');
wx.chooseVideo({
maxDuration:10,
success:function(res1){
app.startOperating("上传中")
// 这个就是最终拍摄视频的临时路径了
var pFilePath;
},
fail:function(){
<("获取本地视频时出错");
}
})
},
实现起来也是很简单,但是有⼀个问题就是没有办法像调⽤camera组件⼀样获取视频的缩略图,这是现在唯⼀的缺陷。但是总体来说,⽐起调⽤camera组件,这样实现起来的确简单了很多。
希望本⽂所述对⼤家⼩程序开发有所帮助。