专栏首页小程序之家如何在小程序中实现拍照功能
原创

如何在小程序中实现拍照功能

在小程序使用的过程中,难免会用到相机组件,本文将教大家配置入门小程序camera组件的使用,并自己制作一个小程序相机的demo出来。

在教程开始之前,需要搭建搭建好小程序的基础开发环境,关于如何配置,大家可以参考如何入门小程序开发这篇文章的入门教程。

相机组件的使用

小程序调用相机很简单,只用一行代码即可实现,修改你的index.wxml文件,为如下代码。

<camera style="width: 100%; height: 450px;"></camera>

当然这行代码仅仅实现了相机在小程序内显示,无法实现更多功能,我们可以参考官方文档来实现更多功能。

属性名

类型

默认值

说明

mode

String

normal

有效值为 normal, scanCode

device-position

String

back

前置或后置,值为front, back

flash

String

auto

闪光灯,值为auto, on, off

bindstop

EventHandle

摄像头在非正常终止时触发,如退出后台等情况

binderror

EventHandle

用户不允许使用摄像头时触发

bindscancode

EventHandle

在扫码识别成功时触发,仅在 mode="scanCode" 时生效

参考上表,我们来实现一个“镜子”的小功能,打开小程序,自动将摄像头转换为前置摄像头,然后默认打开闪光灯,修改代码如下。

<camera device-position="front" flash="on" style="width: 100%; height: 450px;"></camera>

通过上面的代码,就可以将小程序变为“镜子”。

拍照功能API的使用

我们已经学会了使用相机的基本组件的调用,但是在表中我们并没有看到拍照等功能的配置。为了前后端分离,小程序将拍照等功能封装成了API,我们需要在camera组件中调用相关函数才能实现拍照功能。关于拍照API的参数,我们可以参考下表。

属性

类型

默认值

是否必填

说明

quality

string

normal

成像质量

success

function

接口调用成功的回调函数

fail

function

接口调用失败的回调函数

complete

function

接口调用结束的回调函数(调用成功、失败都会执行)

参考上表,我们要用到JavaScript语言对相机API进行封装,首先,我们打开index.js文件,在page()中,写出下面的函数。

takePhoto(){
  
},

这是第一步,创建一个takePhoto函数,接下来,我们调用小程序相机的API。

takePhoto(){
  const ctx = wx.createCameraContext()
},

创建ctx对象,该对象为wx.createCameraContext()函数。接下来,需要调用createCameraContext()takePhoto组件。

takePhoto(){
  const ctx = wx.createCameraContext()
  ctx.takePhoto({
    
  })
},

接下来,参考上表,我们设置我们所需要的参数。

  takePhoto() {
    const ctx = wx.createCameraContext()
    ctx.takePhoto({
      quality: 'high',
      success: (res) => {
        this.setData({
          src: res.tempImagePath
        })
      }
    })
  },

这段代码中,我们定义了拍照的图像质量,并将图片文件存放在tempImagePath临时路径中,然后通过serData函数,将路径写给src变量,后面我们去调用这张图片的地址。后台逻辑处理功能已经写完了,接下来,我们需要去写前端界面,将图片展示出来。

打开index.wxml文件,我们修改代码如下。

<camera device-position="front" flash="on" style="width: 100%; height: 450px;"></camera>
<button type="primary" bindtap="takePhoto">拍照</button>
<image mode="widthFix" src="{{src}}"></image>

我们使用button按钮调用takePhoto函数进行拍照,然后将图片地址返回到src中显示。

总结

这就是基本的小程序相机拍照基本使用方法,你学会了嘛?赶快去体验下吧!后续我将会对其他组件做详细的介绍。喜欢的小伙伴请持续关注本专栏。腾讯云联合小程序给大家带来了小程序·云开发解决方案,为开发者提供完整的云端支持,弱化后端和运维操作,使用平台原生 API 进行核心业务开发,实现快速上线和迭代。欢迎免费使用!

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaScript 中对象的深拷贝

    在JavaScript中,对对象进行拷贝的场景比较常见。但是简单的复制语句只能对对象进行浅拷贝,即复制的是一份引用,而不是它所引用的对象。而更多的时候,我们希望...

    哲洛不闹
  • 爬虫入门到精通-爬虫之异步加载(实战花瓣网)

    本文章属于爬虫入门到精通系统教程第八讲 本次我们会讲解两个知识点 异步加载 headers中的Accept 本次我们要抓取的是花瓣网美女照片美女花瓣,陪你做生活...

    爬虫
  • 【漏洞简析】weblogic CVE-2019-2647等相关XXE漏洞分析

    按照惯例,Oracle发布了4月份的补丁,详情见链接(https://www.oracle.com/technetwork/security-advisory/...

    绿盟科技安全情报
  • 程序员怎么追女生?用代码呀~

    不管是Java,PHP还是C… ---------------- 不过话说程序员浪漫起来真的好帅!好帅!好帅!

    老九君
  • 三张图看遍Linux 性能监控、测试、优化工具

    小小科
  • 云开发数据库又增新技能!

    点击上方蓝字关注我们吧 开篇彩蛋 由于近期小程序·云开发将上线付费功能(付费功能针对非基础资源配额,基础资源配额仍可免费使用)。为了给开发者更充足的时间进行调...

    腾讯云数据库 TencentDB
  • JS浅拷贝与深拷贝的学习记录

    大象无痕
  • python深拷贝浅拷贝

    (个人理解)深拷贝就是将原有的数据一模一样的拷贝一份,然后存到另一个地址中,而不是引用地址

    py3study
  • 结构体成员赋值到底是深拷贝还是浅拷贝?

    在《C语言容易忽略的知识点》一文中,有读者说这种结构体复杂成员赋值的的拷贝是浅拷贝(感谢读者提出),那么到底什么是深拷贝,什么是浅拷贝?

    编程珠玑
  • C/C++学习之路(二)

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_35512245/articl...

    大黄大黄大黄

扫码关注云+社区

领取腾讯云代金券