uniApp 中实现一个骰子动效

代码如下

复制代码
<template>
	<!-- 骰子组件 -->
	<view class="dice-wrap" @tap="throwDice">
		<!-- 筛子运动时候的展示的图片 -->
		<image v-if="isDicing" :src="diceAnimationImages[aniIndex]" class="dice-icon"></image>
		<!-- 筛子静止时候的显示的对应点数的图片 -->
		<image v-else :src="diceImages[currentPoint]" class="dice-icon"></image>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				//是否正在掷筛子
				isDicing: false,
				//当前显示的动画图片索引
				aniIndex: 0,
				//掷筛子动画所用到的图片(4张骰子旋转过程中的图)
				diceAnimationImages: [
					'https://www.upupo.cn/img/骰子素材/动1.png',
					'https://www.upupo.cn/img/骰子素材/动2.png',
					'https://www.upupo.cn/img/骰子素材/动3.png',
					'https://www.upupo.cn/img/骰子素材/动4.png'
				],
				//骰子每一个点的对应的图片
				diceImages: {
					//1点的图片
					1: 'https://www.upupo.cn/img/骰子素材/1点.png',
					//2点的图片
					2: 'https://www.upupo.cn/img/骰子素材/2点.png',
					//3点的图片
					3: 'https://www.upupo.cn/img/骰子素材/3点.png',
					//4点的图片
					4: 'https://www.upupo.cn/img/骰子素材/4点.png',
					//5点的图片
					5: 'https://www.upupo.cn/img/骰子素材/5点.png',
					//6点的图片
					6: 'https://www.upupo.cn/img/骰子素材/6点.png'
				},
				//当前掷筛子掷到的点数(默认1点)
				currentPoint: 1,
				//定时器
				timer: null,
			}
		},
		beforeDestroy() {
			//组件销毁之前清除定时器
			clearInterval(this.timer);
		},
		methods: {
			async getDicePoint() {
				let point = 1;
				//从1~6随机一个数
				point = Math.floor(Math.random() * 6 + 1);
				return point;
			},
			//掷骰子
			async throwDice() {
				//如果当前骰子正在滚动则不能掷骰子
				if (this.isDicing) {
					return
				}
				//从接口获取点数
				this.currentPoint = await this.getDicePoint();
				//开启骰子动画
				await this.startAnimation();
				//动画完毕之后可以通知父组件当前掷到的点数
				this.$emit('throwEnd', this.currentPoint);
			},
			//开启动画效果
			async startAnimation() {
				return new Promise((resolve) => {
					//设置筛子开始运动
					this.isDicing = true;
					//记录动画次数
					let num = 0;
					//每隔100毫秒来回切换一张"动"图形成掷骰子的动画
					this.timer = setInterval(() => {
						let index = this.aniIndex;
						index++;
						if (index >= this.diceAnimationImages.length) {
							index = 0;
						}
						this.aniIndex = index;
						num++;
						//差不多执行1.2秒钟的时候可以停止了
						if (num > 12) {
							//关闭定时器
							clearInterval(this.timer);
							//设置骰子停止
							this.isDicing = false;
							//返回结果
							resolve(true);
						}
					}, 100);
				})
			},
		}
	}
</script>

<style lang="scss">
	.dice-wrap {
		width: 172rpx;
		height: 172rpx;

		.dice-icon {
			width: 172rpx;
			height: 172rpx;
		}
	}
</style>

素材地址:https://download.csdn.net/download/yueye_wu/88621174

ps:素材免费下载哦

相关推荐
xiangxiongfly9154 小时前
uni-app 组件总结
前端·javascript·uni-app
2501_915918415 小时前
iOS性能数据监控:从概念到工具实践,让应用运行更流畅
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_9159090621 小时前
全面解析前端开发中常用的浏览器调试工具及其使用场景
android·ios·小程序·https·uni-app·iphone·webview
wuxianda103021 小时前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a
小盼江1 天前
Uniapp小程序鲜花商城推荐系统 买家卖家双端(web+uniapp)
前端·小程序·uni-app
fakaifa1 天前
【最新版】CRMEB Pro版v4.0系统源码 全开源+uniapp/PC前端+搭建教程
uni-app·开源·商城小程序·crmeb·crmebpro
小徐_23332 天前
Wot UI v1 升级 v2?这份迁移指南帮你少踩坑!
前端·微信小程序·uni-app
游戏开发爱好者82 天前
使用Fiddler设置HTTPS抓包诊断Power Query网络问题
android·ios·小程序·https·uni-app·iphone·webview
棋宣2 天前
uni-app编译到微信小程序中,父传子props首次传递数据不接收的bug
微信小程序·uni-app·bug
阳光先做3 天前
uniapp打包鸿蒙安装包问题
uni-app