时间:2021-05-18
本文实例讲述了微信小程序拍照和摄像功能实现方法。分享给大家供大家参考,具体如下:
拍照
原先的想法是使用微信的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 filePath=res.tempFilePaths[0]; var session_key=wx.getStorageSync('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.error("调用本地相册文件时出错") console.warn(error) }, complete:function(){ } }) },其中封装在app.js中的函数可以看我这篇文章:微信小程序一些简易小函数总结。
摄影
其实跟上面的原理是一样的,对应的API就是wx.chooseVideo,其中可以设置拍摄时间,用户拍摄结束以及用户拍摄时间超时等,都会调用success的回调函数,所以又是可以安心处理接下来的业务流程,而不用需要调用camera组件。
// 摄像功能 getLocalVideo:function(){ var that=this; var session_key=wx.getStorageSync('session_key'); wx.chooseVideo({ maxDuration:10, success:function(res1){ app.startOperating("上传中") // 这个就是最终拍摄视频的临时路径了 var tempFilePath=res1.tempFilePath; }, fail:function(){ console.error("获取本地视频时出错"); } }) },实现起来也是很简单,但是有一个问题就是没有办法像调用camera组件一样获取视频的缩略图,这是现在唯一的缺陷。但是总体来说,比起调用camera组件,这样实现起来的确简单了很多。
希望本文所述对大家微信小程序开发有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们在微信小程序中经常会使用到分享商品海报,或者是重绘微信小程序分享链的图片功能。实现该功能只要跟着如下几个步骤就可以快速实现啦!(本文示例代码使用的是uni-
微信不能拍照片是因为没有打开摄像头权限,微信的摄像头权限可以在手机系统的隐私功能里打开。操作方法: 摄像头(CAMERA或WEBCAM)又称为电脑相机、电脑眼
在微信小程序项目中,开发模块涉及到手写签名功能,微信小程序canvas闪亮登场前言微信小程序canvas实现签名功能核心内容简介:(1)签名实现,开始,移动,结
电脑微信开摄像头的方法是: 1、打开微信,打开聊天对话框。 2、点击发送图片,选择拍照。 3、选择允许微信获取使用摄像头权限,点击快门即可。 微信电脑版
本文实例讲述了微信小程序实现图片上传、删除和预览功能的方法。分享给大家供大家参考,具体如下:这里主要介绍一下微信小程序的图片上传图片删除和图片预览布局JS处理d