微信小程序:自定义扫码功能

2024-09-02 06:12

本文主要是介绍微信小程序:自定义扫码功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们今天主要是介绍小程序自定义扫码的应用,相关业务处理可以根据自己需求来填补

WXML: 

<view class="scan-box direction-column" wx:if="{{ showCanScan }}"><camera class="camera" resolution="high" device-position="back" binderror="error" flash='{{flashBtn}}'><image class="camera-img" src="{{iconScanBgGif}}"></image></camera><view><view class="scan-tip">请将摄像头对准VIN号</view><view class="margin-top-40 flex-center direction-column"><view class="flashlight-btn" bind:tap="changeflashBtn"><image src="{{flashBtn=='on'?'手电筒打开图标':'手电筒关闭图标'}}"></image></view><view class="margin-top-20">轻触照亮</view><view class="margin-top-20"><van-button plain hairline type="primary" bind:tap="recognition">扫一扫</van-button></view><view class="margin-top-20"><van-button plain hairline type="primary" bind:tap="hideScanWindow">取消</van-button></view></view></view>
</view>

WXSS:

page {font-family: PingFang SC-Regular, PingFang SC;font-size: 24rpx;background-color: #F8F7FB;
}.flex-center {display: flex;justify-content: center;align-items: center;
}.direction-column {flex-direction: column;
}.margin-top-20 {margin-top: 20rpx;
}.margin-top-40{margin-top: 40rpx;
}.scan-box {position: fixed;top: 0;width: 100%;height: 100vh;background-color: #000000;z-index: 999999;
}.scan-box .camera {position: relative;width: 100vw;height: 10vw;margin: 20vh auto 0;
}.scan-box .camera-img{position: absolute;top: 0;left: 0;width: 100%;height: 100%;z-index: 99999;
}.scan-box .scan-tip {padding: 20rpx 0 0 0;font-size: 32rpx;text-align: center;color: #fff;
}.scan-box .flashlight-btn{background: transparent !important;width: 100rpx;height: 80rpx;padding: 0 !important;
}.scan-box .flashlight-btn>image{width: 100%;height: 100%;
}

JS:

const app = getApp()
Page({/*** 页面的初始数据*/data: {windowHeight: app.globalData.windowHeight + 400,showCanScan: false,flashBtn: 'off',checked: true},numberRecognition: function () {this.takePhoto();},uploadAndRecognition(paths) {Toast.loading({duration: 0,message: '识别中...',forbidClick: true,});let _this = this;//  图片上传处理接口},//拍照takePhoto: function () {var that = this;//创建拍照上下文对象const ctx = wx.createCameraContext()ctx.takePhoto({quality: 'high',//拍照成功success: (res) => {that.uploadAndRecognition(res.tempImagePath);},fail: err => {console.log(err)}})},changeflashBtn: function () {let _this = this;_this.setData({flashBtn: _this.data.flashBtn == 'off' ? 'on' : 'off'})},hideScanWindow: function () {let _this = this;_this.setData({ showCanScan: false })}
})

这篇关于微信小程序:自定义扫码功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129216

相关文章

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

C#实现高性能拍照与水印添加功能完整方案

《C#实现高性能拍照与水印添加功能完整方案》在工业检测、质量追溯等应用场景中,经常需要对产品进行拍照并添加相关信息水印,本文将详细介绍如何使用C#实现一个高性能的拍照和水印添加功能,包含完整的代码实现... 目录1. 概述2. 功能架构设计3. 核心代码实现python3.1 主拍照方法3.2 安全HBIT

录音功能在哪里? 电脑手机等设备打开录音功能的技巧

《录音功能在哪里?电脑手机等设备打开录音功能的技巧》很多时候我们需要使用录音功能,电脑和手机这些常用设备怎么使用录音功能呢?下面我们就来看看详细的教程... 我们在会议讨论、采访记录、课堂学习、灵感创作、法律取证、重要对话时,都可能有录音需求,便于留存关键信息。下面分享一下如何在电脑端和手机端上找到录音功能

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv