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


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 相关文章推荐
javascript生成随机颜色示例代码
May 05 Javascript
js文字横向滚动特效
Nov 11 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
Oct 27 Javascript
详解Angular CLI + Electron 开发环境搭建
Jul 20 Javascript
vue组件 $children,$refs,$parent的使用详解
Jul 31 Javascript
Vue 重置组件到初始状态的方法示例
Oct 10 Javascript
webpack4 SplitChunks实现代码分隔详解
May 23 Javascript
jquery ajax 请求小技巧实例分析
Nov 11 jQuery
JS实现点击下拉列表文本框中出现对应的网址,点击跳转按钮实现跳转
Nov 25 Javascript
js校验开始时间和结束时间
May 26 Javascript
vue-simple-uploader上传成功之后的response获取代码
Sep 07 Javascript
JS数组方法some、every和find的使用详情
Oct 05 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
PHPWind 发帖回帖Api PHP版打包下载
2010/02/08 PHP
那些年一起学习的PHP(一)
2012/03/21 PHP
PHP 获取文件路径(灵活应用__FILE__)
2013/02/15 PHP
js中复制行和删除行的操作实例
2013/06/25 Javascript
jQuery替换字符串(实例代码)
2013/11/13 Javascript
使用iframe window的scroll方法控制iframe页面滚动
2014/03/05 Javascript
基于jquery实现轮播特效
2016/04/22 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
微信小程序 空白页重定向解决办法
2017/06/27 Javascript
JS判断Android、iOS或浏览器的多种方法(四种方法)
2017/06/29 Javascript
浅析Vue.js 中的条件渲染指令
2018/11/19 Javascript
微信小程序环境下将文件上传到OSS的方法步骤
2019/05/31 Javascript
Vue组件间通信 Vuex的用法解析
2019/08/05 Javascript
[02:00]DOTA2英雄COSPLAY闹市街头巡游助威2015国际邀请赛
2015/08/02 DOTA
Python实现针对中文排序的方法
2017/05/09 Python
python 二分查找和快速排序实例详解
2017/10/13 Python
TensorFlow如何实现反向传播
2018/02/06 Python
pycharm 配置远程解释器的方法
2018/10/28 Python
python判断列表的连续数字范围并分块的方法
2018/11/16 Python
如何在django里上传csv文件并进行入库处理的方法
2019/01/02 Python
python中class的定义及使用教程
2019/09/18 Python
python 回溯法模板详解
2020/02/26 Python
python适合做数据挖掘吗
2020/06/16 Python
用Python爬取LOL所有的英雄信息以及英雄皮肤的示例代码
2020/07/13 Python
Python 实现RSA加解密文本文件
2020/12/30 Python
英国排名第一的停车场运营商:NCP
2019/08/26 全球购物
日本最大化妆品和美容产品的综合口碑网站:cosme shopping
2019/08/28 全球购物
Lovedrobe官网:英国领先的大码服装品牌
2019/09/19 全球购物
外企测试工程师面试题
2015/02/01 面试题
写好求职信第一句话的技巧
2013/10/26 职场文书
团队精神的演讲稿
2014/05/14 职场文书
村党支部群众路线教育实践活动对照检查材料
2014/09/26 职场文书
2014年流动人口工作总结
2014/11/26 职场文书
求职简历自荐信怎么写
2015/03/26 职场文书
会议通知
2015/04/15 职场文书
Java使用jmeter进行压力测试
2021/07/09 Java/Android