「Mac畅玩鸿蒙与硬件49」UI互动应用篇26 - 数字填色游戏

本篇教程将带你实现一个数字填色小游戏,通过简单的交互逻辑,学习如何使用鸿蒙开发组件创建趣味性强的应用。


关键词
  • UI互动应用
  • 数字填色
  • 动态交互
  • 逻辑判断
  • 游戏开发

一、功能说明

数字填色小游戏包含以下功能:

  1. 数字选择:用户点击数字按钮后选中一个数字。
  2. 区域填色:选择数字后,点击区域进行填色,颜色根据数字变化。
  3. 颜色逻辑映射:通过逻辑映射,将数字和颜色关联。
  4. 清空重置:支持清空所有区域,恢复默认状态。

二、所需组件
  • @Entry@Component 装饰器
  • Canvas 组件用于绘制填色区域
  • RowColumn 布局组件
  • Button 组件用于选择数字和重置操作
  • @State 修饰符用于状态管理

三、项目结构
  • 项目名称DigitalColoringGame
  • 自定义组件名称ColoringGamePage
  • 代码文件ColorMapping.etsColoringGamePage.etsIndex.ets

四、代码实现
1. 定义颜色映射
typescript 复制代码
// 文件名:ColorMapping.ets

export type ColorMapping = Record<number, string>;

export const colorMapping: ColorMapping = {
  1: '#FF0000', // 红色
  2: '#00FF00', // 绿色
  3: '#0000FF', // 蓝色
  4: '#FFFF00', // 黄色
  5: '#FF00FF', // 品红
};

2. 数字填色游戏页面
typescript 复制代码
// 文件名:ColoringGamePage.ets

import { colorMapping } from './ColorMapping';

@Component
export struct ColoringGamePage {
  @State selectedNumber: number = 0; // 当前选择的数字
  @State coloredAreas: number[] = Array(9).fill(0); // 每个区域的颜色状态
  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(); // 创建 Canvas 渲染上下文

  // 选择数字
  selectNumber(num: number): void {
    this.selectedNumber = num; // 更新选中数字
  }

  // 填色区域
  fillArea(index: number): void {
    if (this.selectedNumber !== 0) {
      this.coloredAreas[index] = this.selectedNumber; // 更新颜色状态
      this.redrawCanvas(); // 重新绘制画布
    }
  }

  // 绘制初始画布
  drawInitialCanvas(): void {
    for (let i = 0; i < 9; i++) {
      const x = (i % 3) * 110; // 计算区域的 x 坐标
      const y = Math.floor(i / 3) * 110; // 计算区域的 y 坐标
      this.context.fillStyle = colorMapping[this.coloredAreas[i]] || '#FFFFFF'; // 设置填充颜色
      this.context.fillRect(x, y, 100, 100); // 绘制填充矩形
      this.context.strokeStyle = '#000000'; // 边框颜色
      this.context.strokeRect(x, y, 100, 100); // 绘制边框
    }
  }

  // 重新绘制画布
  redrawCanvas(): void {
    this.context.clearRect(0, 0, 330, 330); // 清空画布
    this.drawInitialCanvas(); // 重新绘制
  }

  // 重置游戏
  resetGame(): void {
    this.coloredAreas = Array(9).fill(0); // 清空状态
    this.selectedNumber = 0; // 重置选中数字
    this.redrawCanvas(); // 重置画布
  }

  build() {
    Column({ space: 20 }) {
      Text('数字填色游戏')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .alignSelf(ItemAlign.Center);

      // 显示填色区域
      Canvas(this.context)
        .width(330)
        .height(330)
        .onReady(() => {
          this.drawInitialCanvas(); // 初始化画布
        })
        .onTouch((event: TouchEvent) => {
          const touch = event.touches[0]; // 获取触控点
          const x = Math.floor(touch.x / 110); // 计算列索引
          const y = Math.floor(touch.y / 110); // 计算行索引
          const index = y * 3 + x; // 计算区域索引
          if (index >= 0 && index < 9) {
            this.fillArea(index); // 更新对应区域颜色
          }
        });

      // 数字选择按钮
      Row({ space: 10 }) {
        ForEach([1, 2, 3, 4, 5], (num: number) => {
          Button(`${num}`)
            .width(60)
            .height(60)
            .backgroundColor(colorMapping[num])
            .onClick(() => this.selectNumber(num)); // 选择数字
        });
      }

      // 重置按钮
      Button('重置')
        .onClick(() => this.resetGame()) // 重置游戏
        .margin({ top: 20 })
        .width(100)
        .height(50);
    }
    .padding(20)
    .width('100%')
    .height('100%');
  }
}

3. 主入口文件
typescript 复制代码
// 文件名:Index.ets

import { ColoringGamePage } from './ColoringGamePage';

@Entry
@Component
struct Index {
  build() {
    Column() {
      ColoringGamePage() // 调用数字填色游戏页面
    }
    .padding(20);
  }
}

效果示例:通过选择数字并点击区域,填充颜色,享受填色游戏的乐趣。

效果展示


五、代码解读
  1. 颜色映射逻辑

    • ColorMapping.ets 文件使用 Record<number, string> 定义数字到颜色的映射关系,便于扩展和管理。
  2. 区域填色逻辑

    • fillArea() 方法根据当前选择的数字,为指定区域填色,实时更新画布。
  3. 数字选择与重置

    • 通过 selectNumber() 方法更新用户选择的数字,resetGame() 方法一键清空填色区域并恢复默认状态。
  4. 状态管理

    • 使用 @State 修饰符管理 selectedNumbercoloredAreas,实现组件状态和界面的实时联动。

六、优化建议
  1. 添加"未填色提示",如动态高亮未填区域。
  2. 支持保存填色进度以便后续继续。
  3. 提供不同的配色主题,增强游戏的趣味性。

七、效果展示
  • 数字选择与区域填色:用户点击数字按钮并点击区域,实现数字填色。
  • 清空重置:一键清空所有区域,重新开始游戏。

八、相关知识点

小结

通过本篇教程,用户掌握了使用鸿蒙组件实现数字填色小游戏的核心方法,进一步提升了开发互动性应用的能力。


下一篇预告

在下一篇「UI互动应用篇27 - 水果掉落小游戏」中,我们将学习如何实现一个互动性更强的水果掉落小游戏,增强用户的娱乐体验。


上一篇: 「Mac畅玩鸿蒙与硬件48」UI互动应用篇25 - 简易购物车功能实现
下一篇: [「Mac畅玩鸿蒙与硬件50」UI互动应用篇27 - 水果掉落小游戏](#下一篇: 「Mac畅玩鸿蒙与硬件50」UI互动应用篇27 - 水果掉落小游戏)

作者:SoraLuna

链接:https://www.nutpi.net

來源:坚果派

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


相关推荐
Rossy Yan24 分钟前
【HarmonyOS应用开发——ArkTS语言】欢迎界面(启动加载页)的实现【合集】
前端·typescript·harmonyos·arkts·web app·鸿蒙应用开发·合集
橘子海全栈攻城狮30 分钟前
【源码+文档+调试讲解】“健康早知道”微信小程序
开发语言·servlet·微信小程序·小程序·notepad++
爱是小小的癌40 分钟前
Java-数据结构-顺序表(ArrayList)
java·开发语言·数据结构
我明天再来学Web渗透1 小时前
【2024年-11月-9日-开源社区openEuler实践记录】OpenAMDC:开启智能边缘计算与系统管控的新征程
开发语言·人工智能·架构·开源·边缘计算·copilot·开源软件
egoist20231 小时前
数据结构之单链表(超详解)
c语言·开发语言·数据结构·笔记·学习·链表·gitee
小_太_阳1 小时前
Scala_【3】运算符
开发语言·scala·intellij-idea
xinghuitunan1 小时前
考试座位号(PTA)C语言
c语言·开发语言
程序边界2 小时前
AIGC赋能Java编程:智能工具引领效率、创新与理解的新纪元
java·开发语言·aigc
jk_1012 小时前
MATLAB中binopdf函数用法
开发语言·算法·matlab
有颜有货2 小时前
华为的数字化转型框架和数字化转型成熟度评估方法
华为·数字化·数字化转型