微信小程序拍照和摄像实例代码

微信小程序拍照和摄像实例代码

拍照

原先的想法是使用微信的camera组件来实现,并且模拟发朋友圈的样子来进行相机的设置,其实就是将camera组件的大小设置成根屏幕一样大,并在上面使用一个cover-image组件来给用户进行点击,可是实际上的情况是第一,cover-image组件有时候会消失,第二,整个流程实现起来很僵硬,页面跳转也是卡的要死,后来无意间发现了另一个APIwx.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组件,这样实现起来的确简单了很多。

  • 12
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
微信小程序和JSP销售系统代码是两种不同的开发技术,在不同的应用场景中有着不同的用途。 微信小程序是一种基于微信平台的应用程序,用户可以在微信内直接使用,无需下载安装,具有轻量、快速、便捷的特点。开发微信小程序需要使用微信开发者工具和小程序开发框架,通常使用的是JavaScript语言。 微信小程序适用于各种业务场景,可以实现商品展示、购物、在线支付、社交分享等功能。开发人员可以通过编写前端代码实现界面设计、逻辑交互,也可以通过调用后台API实现数据的获取和处理。 而JSP销售系统代码则是一种基于Java语言的web应用程序开发技术,通常用于开发企业级的销售系统。JSP(Java Server Pages)是Java的一种服务器端技术,可以在HTML页面中嵌入Java代码,实现动态网页的生成。 JSP销售系统代码可以实现复杂的业务逻辑,包括用户登录注册、商品管理、订单管理、数据统计等功能。开发人员可以通过Java代码编写后台逻辑,与数据库进行数据交互,通过JSP页面与用户进行交互。 总之,微信小程序和JSP销售系统代码是两种不同的开发技术,适用于不同的应用场景。微信小程序侧重于移动应用开发,适用于微信用户使用的小型应用;而JSP销售系统代码适用于企业级销售系统的开发,具有更高的复杂性和灵活性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值