微信小程序拍照和摄像功能实现方法示例


Posted in Javascript onFebruary 01, 2019

本文实例讲述了微信小程序拍照和摄像功能实现方法。分享给大家供大家参考,具体如下:

拍照

原先的想法是使用微信的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组件,这样实现起来的确简单了很多。

希望本文所述对大家微信小程序开发有所帮助。

Javascript 相关文章推荐
jQuery动画效果-fadeIn fadeOut淡入浅出示例代码
Aug 28 Javascript
详细介绍8款超实用JavaScript框架
Oct 25 Javascript
教你用javascript实现随机标签云效果_附代码
Mar 16 Javascript
详解数组Array.sort()排序的方法
May 09 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
Jul 12 Javascript
Node.js实现发送邮件功能
Nov 06 Javascript
解决vue 更改计算属性后select选中值不更改的问题
Mar 02 Javascript
详解Javascript中new()到底做了些什么?
Mar 29 Javascript
在vue中使用vue-echarts-v3的实例代码
Sep 13 Javascript
JavaScript模板引擎应用场景及实现原理详解
Dec 14 Javascript
JS实现移动端点击按钮复制文本内容
Jul 28 Javascript
JavaScript 实现自己的安卓手机自动化工具脚本(推荐)
May 13 Javascript
微信小程序常用简易小函数总结
Feb 01 #Javascript
使用Angular自定义字段校验指令的方法示例
Feb 01 #Javascript
angular中如何绑定iframe中src的方法
Feb 01 #Javascript
Javascript迭代、递推、穷举、递归常用算法实例讲解
Feb 01 #Javascript
JS集合set类的实现与使用方法示例
Feb 01 #Javascript
详解如何使用webpack打包多页jquery项目
Feb 01 #jQuery
详解Vue中watch对象内属性的方法
Feb 01 #Javascript
You might like
简单的过滤字符串中的HTML标记
2006/12/25 PHP
php利用curl抓取新浪微博内容示例
2014/04/27 PHP
php版微信发红包接口用法示例
2016/09/23 PHP
详解如何在云服务器上部署Laravel
2017/06/30 PHP
CI框架网页缓存简单用法分析
2018/12/26 PHP
JavaScript实现从数组中选出和等于固定值的n个数
2014/09/03 Javascript
javascript实现仿腾讯游戏选择
2015/05/14 Javascript
理解 JavaScript Scoping & Hoisting(二)
2015/11/18 Javascript
一些实用性较高的js方法
2016/04/19 Javascript
jQuery+php实时获取及响应文本框输入内容的方法
2016/05/24 Javascript
简单实现js拖拽效果
2017/07/25 Javascript
vue项目打包后怎样优雅的解决跨域
2019/05/26 Javascript
Python中的并发编程实例
2014/07/07 Python
python实现通过shelve修改对象实例
2014/09/26 Python
Python简单获取自身外网IP的方法
2016/09/18 Python
高效测试用例组织算法pairwise之Python实现方法
2017/07/19 Python
Django如何自定义model创建数据库索引的顺序
2019/06/20 Python
pandas DataFrame 行列索引及值的获取的方法
2019/07/02 Python
python3+django2开发一个简单的人员管理系统过程详解
2019/07/23 Python
Python HTMLTestRunner库安装过程解析
2020/05/25 Python
python解包用法详解
2021/02/17 Python
Lime Crime官网:美国一家主打梦幻精灵系的彩妆品牌
2019/03/22 全球购物
编辑求职信样本
2013/12/16 职场文书
关于廉洁的广播稿
2014/01/30 职场文书
软弱涣散基层党组织整改方案
2014/10/25 职场文书
孝老爱亲事迹材料
2014/12/24 职场文书
幼儿园开学家长寄语(2015秋季)
2015/05/27 职场文书
2016教师暑期培训学习心得体会
2016/01/09 职场文书
Python爬虫爬取全球疫情数据并存储到mysql数据库的步骤
2021/03/29 Python
vue使用v-model进行跨组件绑定的基本实现方法
2021/04/28 Vue.js
goland设置颜色和字体的操作
2021/05/05 Golang
只用20行Python代码实现屏幕录制功能
2021/06/02 Python
Spring Security中用JWT退出登录时遇到的坑
2021/10/16 Java/Android
SQLServer权限之只开启创建表权限
2022/04/12 SQL Server
Redis官方可视化工具RedisInsight安装使用教程
2022/04/19 Redis
Python如何快速找到多个字典中的公共键(key)
2022/04/29 Python