微信小程序使用图片实现红包雨功能

微信小程序红包雨功能实现:从组件封装到页面调用的完整实践

先看示例截图:
红包雨示例截图

一、背景与技术选型
在微信小程序营销活动中,红包雨是一种极具吸引力的互动形式。实现红包雨效果主要有 Canvas 和图片两种方案:

(1)Canvas 方案:性能优异,资源占用小,但视觉表现依赖绘图 API
(2)图片方案:视觉效果真实,可灵活设计红包样式,但资源加载与内存占用较高

本文将采用图片方案实现红包雨组件,通过组件化设计提升代码复用性,并分享性能优化经验,帮助开发者在真实感与性能间找到平衡点。
二、组件设计与实现
2.1 组件结构设计
首先创建组件文件夹components/img-rain,目录结构如下:

components/
└─ img-rain/├── index.js         // 逻辑层├── index.wxml       // 视图层├── index.wxss       // 样式层├── index.json       // 配置文件└── images/             // 红包图片资源├── img1.png├── img2.png└── img3.png

2.2 组件核心代码实现
以下是图片红包雨组件的完整实现:

Component({properties: {petalCount: {type: Number,value: 60},speed: {type: Number,value: 2},wind: {type: Number,value: 0.3},images: {type: Array,value: ['/images/5.png','/images/100.png','/images/500.png','/images/1000.png']}},data: {petals: []},lifetimes: {attached() {this.createPetals();this.startAnimation();},detached() {this.stopAnimation();}},methods: {createPetals() {const {petalCount,images} = this.properties;const {windowWidth,windowHeight} = wx.getWindowInfo();const petals = [];for (let i = 0; i < petalCount; i++) {const size = 40 + Math.random() * 20;const left = Math.random() * (windowWidth - size);const top = -size - Math.random() * windowHeight;petals.push({id: `petal-${i}`,image: images[Math.floor(Math.random() * images.length)],x: left,y: top,size,speed: 5 + Math.random() * this.properties.speed,windEffect: (Math.random() - 0.5) * this.properties.wind});}this.setData({petals});},// 开始动画startAnimation() {const {windowHeight} = wx.getWindowInfo();this.animationInterval = setInterval(() => {this.setData({petals: this.data.petals.map(petal => {// 更新位置和旋转petal.y += petal.speed;petal.x += petal.windEffect;// 如果花瓣超出屏幕,重置到顶部if (petal.y > windowHeight + petal.size || petal.x < -petal.size || petal.x > wx.getWindowInfo().windowWidth + petal.size) {petal.y = -petal.size - Math.random() * windowHeight;petal.x = Math.random() * (wx.getWindowInfo().windowWidth - petal.size);}return petal;})});}, 30); // 约30ms一帧},// 停止动画stopAnimation() {if (this.animationInterval) {clearInterval(this.animationInterval);}},}
});

2.3 视图层实现

<view class="rain-container"><image wx:for="{{petals}}" wx:key="id" src="{{item.image}}" style="position: fixed;left: {{item.x}}px;top: {{item.y}}px;width: {{item.size}}px;height: {{item.size+20}}px;pointer-events: none;z-index: -1;"></image>
</view>

2.4 样式层实现

.rain-container {position: fixed;top: 0;left: 0;width: 100%;height: 100%;pointer-events: none;z-index: 9998;overflow: hidden;
}

三、页面调用与集成
3.1 页面配置
在需要调用的界面的json文件处引入组件

{"usingComponents": {"img-rain": "/components/img-rain/index"},"navigationStyle": "custom"
}

3.2 页面布局

<img-rain petalCount="10" speed="0" wind="0."></img-rain>

四、总结与拓展
本文通过组件化设计实现了微信小程序中基于图片的红包雨效果,兼顾了视觉真实感与代码复用性。实际项目中,可根据活动预算和性能要求选择合适的实现方案:

(1)对性能要求高、视觉要求低的场景推荐使用 Canvas 方案
(2)对视觉效果要求高、预算充足的场景推荐使用图片方案

编写不易,谢谢点赞+收藏+关注,后续更新更多示例呦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/83685.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python day31

浙大疏锦行 数据拆分的基本框架&#xff0c;拆分后让项目结构更加清晰

Chapter10-XXE

文章目录 1.XXE介绍1.1 XXE产生的原因1.1.1 什么是XML&#xff1f;1.1.2 什么是XML实体1.1.3 什么是文档类型定义&#xff08;document type definition&#xff09;1.1.4 什么是XML自定义实体1.1.5 什么是XML外部实体 2.XXE攻击类型2.1 利用XXE检索文件2.2 利用XXE执行SSRF攻击…

Ribbon负载均衡实战指南:7种策略选择与生产避坑

引言&#xff1a;客户端负载均衡的不可替代性 当面试官问你&#xff1a;“Ribbon 和 Nginx 有什么区别&#xff1f;”——Ribbon 是进程内 LB 这一句话值 20K 月薪。 作为微服务调用的核心枢纽&#xff0c;Ribbon 通过 ​​本地服务清单动态分发请求​​&#xff0c;避免中心化…

Webpack:现代前端构建工具的核心解析

Hi&#xff0c;我是布兰妮甜 &#xff01;在前端工程化日益重要的今天&#xff0c;Webpack作为主流构建工具&#xff0c;已成为现代前端开发的核心基础设施。它通过模块化打包机制&#xff0c;优雅地解决了复杂应用中的资源管理问题&#xff0c;使开发者能够专注于业务逻辑的实…

Elasticsearch索引wildcard查询

在之前的文章 Elasticsearch索引的字段映射 中介绍过关于索引中字段查询的多种方式。可以根据需要通过设置索引字段的type以及fields来实现分词,精确匹配等多种方式的查询。 elasticSearch中检索核心类型大概可以分为:精准匹配检索(Term-level queries)和基于分词的全文匹…

1.3、SDH光接口类型

接口类型的命名遵循一个特定的代码结构&#xff0c;格式通常为&#xff1a;应用代码-速率等级.波长/距离代码。 代码的第一位字母表示应用场合&#xff1a;I 表示局内通信&#xff1b;S 表示短距离局间通信&#xff1b;L 表示长距离局间通信。字母横杠后的第一位表示 STM 的速率…

浅析MySQL数据迁移与恢复:从SQLServer转型到MySQL

文章目录 前言一、MySQL与SQLServer数据管理方式对比1.1 文件结构差异&#xff1a;1.2 存储引擎多样性&#xff1a;1.3 备份恢复方式&#xff1a; 二、MySQL数据迁移方法与技术2.1 逻辑备份与恢复2.2 物理备份与恢复2.3 异构数据库迁移(从SQLServer到MySQL) 三、MySQL数据恢复策…

HarmonyOS 5中UniApp的调试步骤

在 HarmonyOS 5 中调试 UniApp 应用的完整步骤如下&#xff0c;涵盖环境配置、设备连接及调试方法&#xff1a; 一、环境准备 ‌开发工具‌ 安装 HBuilderX 4.64&#xff08;需启用鸿蒙插件&#xff09;可选安装 DevEco Studio 5.0.3&#xff08;用于真机调试&#xff09;配置 …

使用centos服务器和Let‘s Encypted配置SpingBoot项目的https证书

一、Centos安装Certbot客户端 yum install certbot 二、生成证书 certbot certonly --standalone -d 你的域名 执行该命令后会生成如下文件 privkey.pem : the private key for your certificate. fullchain.pem: the certificate file used in most server software. c…

AWS Well-Architected Framework详解

一、六大支柱&#xff08;Well-Architected Framework&#xff09; AWS Well-Architected Framework 的实际操作可以通过其五大支柱&#xff08;或六大支柱&#xff0c;包括可持续性&#xff09;的具体实践来证明。以下是每个支柱对应的实际操作示例&#xff1a; 卓越运营&am…

【特征工程】机器学习的特征构造和筛选

调研论文中&#xff0c;看到datafun的一篇agent文章“智能不够&#xff0c;知识来凑”——知识驱动的金融决策智能体&#xff0c;里面提到了自动因子挖掘&#xff0c;感觉可以用来做机器学习的“特征工程”。 第一部分介绍如何“构造特征”&#xff0c;第二部分介绍如何“分析…

第21节 Node.js 多进程

Node.js本身是以单线程的模式运行的&#xff0c;但它使用的是事件驱动来处理并发&#xff0c;这样有助于我们在多核 cpu 的系统上创建多个子进程&#xff0c;从而提高性能。 每个子进程总是带有三个流对象&#xff1a;child.stdin, child.stdout和child.stderr。他们可能会共享…

【走进Golang】测试SDK环境搭建成功,配置path环境变量

[1]进入控制命令台&#xff1a;win R -->cmd [2]证明SDK环境成功 1.此电脑 2.高级系统设置 3.环境变量 4.点击环境变量&#xff0c;进入找到 path&#xff0c;点击编辑 5.进入编辑,找到对应目录&#xff0c;配置成功 添加完成后&#xff0c;点击确定&#xff0c;确定&#…

LlamaIndex 工作流 并发执行

除了循环和分支之外&#xff0c;工作流还可以并发地执行步骤。当你有多个可以相互独立运行的步骤&#xff0c;并且这些步骤中包含需要等待的耗时操作时&#xff0c;这种并发执行的方式就非常有用&#xff0c;因为它允许其他步骤并行运行。 触发多个事件 到目前为止&#xff0…

精粹汇总:大厂编程规范(持续更新)

欢迎来到啾啾的博客&#x1f431;。 记录学习点滴。分享工作思考和实用技巧&#xff0c;偶尔也分享一些杂谈&#x1f4ac;。 有很多很多不足的地方&#xff0c;欢迎评论交流&#xff0c;感谢您的阅读和评论&#x1f604;。 目录 1 引言2 并发控制 (Concurrency Control)3 事务控…

curl 检查重定向的命令总结

查看是否发生了重定向&#xff1a; curl -I http://yourdomain.com跟踪整个重定向链&#xff1a; curl -IL http://yourdomain.com禁止跳转&#xff0c;检查是否返回 301/302&#xff1a; curl -I --max-redirs 0 http://yourdomain.com如果你只想看跳没跳 HTTPS&#xff0c…

STM32 Bootloader:使用文件头加载并启动应用程序

文章目录 STM32 Bootloader&#xff1a;使用文件头加载并启动应用程序的完整解析一、系统整体流程二、镜像头结构 image\_header\_t三、Bootloader 主函数流程1. 初始化 UART2. 调用启动函数3. 拷贝 APP 并跳转启动 四、跳转执行 APP 的实现五、总结与扩展思路 明白了&#xff…

无外接物理显示器的Ubuntu系统的远程桌面连接(升级版)

文章目录 操作步骤实践截图配置 Xorg 的虚拟显示界面(升级版) 操作步骤 “远程连接”,在设置里直接打开就可以.进行配置就行. 1.配置 GRUB 以支持无显示器启动 sudo nano /etc/default/grub (里面有一行改为: GRUB_CMDLINE_LINUX_DEFAULT"quiet splash videovesa:off vi…

ACCU-100安科瑞协调控制器:精准调控光伏逆变器

产品概述 ACCU-100微电网协调控制器是一款应用于微电网、分布式发电、储能等领域的智能协调控制器。它能接入光伏系统、风力发电、储能系统以及充电桩等设备&#xff0c;通过对微电网系统进行数据采集与分析&#xff0c;实时监控各类设备的运行状态和健康状况。在此基础上&…

长春光博会 | 麒麟信安:构建工业数字化安全基座,赋能智能制造转型升级

6月10日-13日&#xff0c;2025长春国际光电博览会Light国际会议&#xff08;简称长春光博会&#xff09;在长春东北亚国际博览中心盛大举行&#xff0c;吉林省委书记黄强出席并宣布开幕&#xff0c;省委副书记、省长胡玉亭致辞。本届大会聚焦光电信息领域的前沿技术和最新产品&…