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

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

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql