一、引言
骰子(Dice)是人类历史上最古老的随机工具之一,已有超过 5000 年的历史。从古埃及的骰子游戏到现代桌游,骰子始终是随机性和概率的最直观体现。
在数字世界中实现摇骰子功能,核心挑战不在于生成随机数(这太简单了),而在于如何通过动画模拟真实骰子的"滚动感",以及如何设计交互反馈让用户觉得这个骰子是在"真正地摇"。
二、需求分析
2.1 功能需求
功能 说明
随机点数 模拟两个 1-6 点的骰子
滚动动画 在最终结果确定前,数字快速跳变动画
点数合计 显示两个骰子的总和
历史记录 记录每次投掷的结果
2.2 用户体验目标
每次投掷结果不可预测
滚动动画持续约 0.8-1 秒,营造真实感
最终结果以传统骰子符号(⚀-⚅)展示
三、动画反馈机制
3.1 滚动动画实现
骰子的"滚动"效果是通过在短时间内多次改变骰子点数来实现的:
roll() {
this.isRolling = true;
let rounds = 0;
let maxRounds = 10;
let tId = setInterval(() => {
this.dice1 = Math.floor(Math.random() * 6) + 1;
this.dice2 = Math.floor(Math.random() * 6) + 1;
rounds++;
if (rounds >= maxRounds) {
clearInterval(tId);
this.isRolling = false;
// 记录结果
}
}, 80);
}
参数设计分析:
maxRounds = 10:共改变 10 次点数
间隔 80ms:总动画时长 = 10 × 80 = 800ms
最终结果始终是最后一次随机生成的数字,不存在"预决定结果再表演"的问题——每一次随机都是真实的
3.2 骰子的 Unicode 表示
传统骰子点数的 Unicode 字符无法在 ArkTS 中直接使用,我们使用文字数字代替:
getDiceEmoji(v: number): string {
return [‘⚀’, ‘⚁’, ‘⚂’, ‘⚃’, ‘⚄’, ‘⚅’][v - 1] || ‘?’;
}
这些骰子符号(U+2680 到 U+2685)在支持 Unicode 的系统上可以正常显示。
四、状态管理
@State dice1: number = 1;
@State dice2: number = 1;
@State isRolling: boolean = false;
@State history: string[] = [];
isRolling 用于控制按钮的可用状态和动画状态。在滚动动画期间,按钮显示"滚动中…"且不可点击:
Button(this.isRolling ? ‘🎲 转动中…’ : ‘🎲 掷骰子!’)
.enabled(!this.isRolling)
五、历史记录
与随机数生成器类似,使用 unshift 将最新结果插入到历史记录的开头:
this.history.unshift(🎲 ${this.dice1} + ${this.dice2} = ${sum});
if (this.history.length > 30) this.history.pop();
六、总结
摇骰子应用的核心不在于随机数的生成(这是最简单的部分),而在于如何通过动画营造交互的"真实感"。80ms 间隔的 10 次随机变化、按钮状态的动态切换、历史记录的即时更新,这些元素共同构成了一个完整的、令人满意的交互体验。
从技术实现角度看,骰子应用也验证了 ArkTS 中一个核心模式:定时器驱动的状态变化 → 自动 UI 刷新。这个模式在游戏、动画、实时数据更新等场景中被反复使用。