⼩程序拍照和摄像实例代码
⼩程序拍照和摄像实例代码
拍照原先的想法是使⽤的camera 组件来实现,并且模拟发朋友圈的样⼦来进⾏相机的设置,其实就是将camera 组件的⼤⼩设置成根屏幕⼀样⼤,并在上⾯使⽤⼀个cover-image 组件来给⽤户进⾏点击,可是实际上的情况是第⼀,cover-image 组件有时候会消失,第⼆,整个流程实现起来很僵硬,页⾯跳转也是卡的要死,后来⽆意间发现了另⼀个API :wx.chooseImage ,这个会⾃⼰去调⽤相机和相册,之后的⼯作完全交给底层去实现,简直是简单到没朋友:
其中封装在app.js 中的函数可以看我这篇⽂章:。
摄影其实跟上⾯的原理是⼀样的,对应的API就是wx.chooseVideo ,其中可以设置拍摄时间,⽤户拍摄结束以及⽤户拍摄时间超时等,都会调⽤success 的回调函数,所以⼜是可以安⼼处理接下来的业务流程,⽽不⽤需要调⽤camera 组件。// 拍照功能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 (){            }        })    },
1
2
3
4
代码转换
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
实现起来也是很简单,但是有⼀个问题就是没有办法像调⽤camera 组件⼀样获取视频的缩略图,这是现在唯⼀的缺陷。但是总体来说,⽐起调⽤camera 组件,这样实现起来的确简单了很多。// 摄像功能    getLocalVideo:function (){        var  that=this ;        var  session_StorageSync('sessio
n_key');        wx.chooseVideo({            maxDuration:10,            success:function (res1){                app.startOperating("上传中")                // 这个就是最终拍摄视频的临时路径了                var  pFilePath;            },            fail:function (){                ("获取本地视频时出错");            }        })    },
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。