嵌入式系统应用-LVGL的应用-平衡球游戏 part1

news2024/12/26 19:11:38

平衡球游戏 part1

  • 1 平衡球游戏的界面设计
  • 2 界面设计
    • 2.1 背景设计
    • 2.2 球的设计
    • 2.3 移动球的坐标
    • 2.4 用鼠标移动这个球
    • 2.5 增加边框规则
    • 2.6 效果图
    • 2.7 游戏失败重启游戏
  • 3 为小球增加增加动画效果
    • 3.1 增加移动效果代码
    • 3.2 具体效果图片

平衡球游戏 part2 第二部分文章在这里

1 平衡球游戏的界面设计

我们将开发一种界面平衡球的游戏, 这个游戏视频链接。

这个游戏界面相对比较简单,这里会的做的比较复杂一点。

在这里插入图片描述

2 界面设计

2.1 背景设计

创建一个蓝色的背景, 绘制这个界面。

// 创建窗口
if (main_screen == NULL)
{
    // 创建窗口
    main_screen = lv_scr_act();
    // 背景色是蓝色
    lv_obj_set_style_bg_color(main_screen, lv_palette_main(LV_PALETTE_BLUE), LV_PART_MAIN);
    lv_scr_load(main_screen);
}

2.2 球的设计

绘制这个球, 选择黄色的球。

lv_obj_t * create_circle(lv_obj_t* parent) {
    // 创建一个基本对象,作为圆的容器
    lv_obj_t* circle = lv_obj_create(parent);

    // 设置对象的大小,确保宽高相等
    lv_obj_set_size(circle, 50, 50);

    // 创建一个样式
    static lv_style_t style;
    lv_style_init(&style);

    // 设置样式的背景颜色
    lv_style_set_bg_color(&style, lv_palette_main(LV_PALETTE_YELLOW));

    // 设置样式的边框圆角半径为最大值,以形成一个圆
    lv_style_set_radius(&style, LV_RADIUS_CIRCLE);

    // 将样式应用到对象
    lv_obj_add_style(circle, &style, 0);

    return circle;
}

2.3 移动球的坐标

// 移动球的函数
void move_circle(lv_obj_t* circle, int16_t x, int16_t y) {
    // 设置圆的新位置
    lv_obj_set_pos(circle, x, y);
}

2.4 用鼠标移动这个球

2.4.1 为主界面增加一个鼠标的动作相应

   lv_obj_add_event_cb(main_screen, mouse_event_handler, LV_EVENT_ALL, NULL);

2.4.2 创建鼠标相应绘制具体的动作

// 鼠标移动函数
void mouse_event_handler(lv_event_t* e)
{
    lv_event_code_t code = lv_event_get_code(e);
    lv_obj_t* obj = lv_event_get_target(e);

    switch (code) {
    case LV_EVENT_PRESSED:
        printf("Mouse button pressed!\n");
        // 获取指针的坐标
        lv_point_t p;
        lv_indev_get_point(lv_indev_get_act(), &p);
        printf("x is %d, y is %d\r\n", p.x, p.y);
        // 新的位置,减去半径以确保中心点在指针位置
        int16_t new_x = p.x - BALL_SIZE / 2;
        int16_t new_y = p.y - BALL_SIZE / 2;
        // 检查是否超出屏幕边界
        if (new_x < 0 || new_y < 0 || (new_x + BALL_SIZE) > lv_disp_get_hor_res(NULL) || (new_y + BALL_SIZE) > lv_disp_get_ver_res(NULL)) {
            show_failure_dialog();
        }
        else {
            move_circle(ball, new_x, new_y);
        }

        break;
    default:
        break;
    }
}

2.5 增加边框规则

检测边界的范围

  if (new_x < 0 || new_y < 0 || (new_x + BALL_SIZE) > lv_disp_get_hor_res(NULL) || (new_y + BALL_SIZE) > lv_disp_get_ver_res(NULL)) {
            show_failure_dialog();
        }

失败,弹出对话框

设置 Message Box 颜色的步骤

  1. 创建消息框:
    使用 lv_msgbox_create 函数创建消息框。

  2. 定义样式:
    使用 lv_style_t 定义并初始化样式。你可以为消息框的不同部分创建不同的样式,例如背景、文本和按钮。

  3. 应用样式:
    使用 lv_obj_add_style 函数将样式应用到消息框或其组件上。

void show_failure_dialog() {
  lv_obj_t* mbox = lv_msgbox_create(NULL, "Game Over", "You hit the boundary!", NULL, true);
    // 定义背景样式
    static lv_style_t style_bg;
    lv_style_init(&style_bg);
    lv_style_set_bg_color(&style_bg, lv_palette_main(LV_PALETTE_NONE)); // 深黑色背景
    lv_style_set_bg_opa(&style_bg, LV_OPA_COVER);
    lv_style_set_border_color(&style_bg, lv_palette_main(LV_PALETTE_GREEN)); // 绿色边框
    lv_style_set_border_width(&style_bg, 2);

    // 定义文本样式
    static lv_style_t style_text;
    lv_style_init(&style_text);
    lv_style_set_text_color(&style_text, lv_palette_main(LV_PALETTE_RED)); // 红色文本



    // 应用样式到消息框
    lv_obj_add_style(mbox, &style_bg, 0);  // 应用背景样式
    lv_obj_add_style(lv_msgbox_get_title(mbox), &style_text, 0);  // 应用标题文本样式
    lv_obj_add_style(lv_msgbox_get_text(mbox), &style_text, 0);   // 应用消息文本样式




    // 设置消息框位置到中心

    lv_obj_center(mbox);
}

2.6 效果图

移动小球,没有动画

2.7 游戏失败重启游戏

为这个对话框添加一个回调函数,关闭对话框的时候,让小球回到起始位置。

//  对话框回调函数
static void mbox_event_cb(lv_event_t* e)
{
        lv_event_code_t code = lv_event_get_code(e);   

    if (code == LV_EVENT_DELETE) {
        move_circle(ball, 100, 100);    // 回到初始值的位置
    }
    
}

在创建对话框函数里面,添加下面的语句:关联回调函数。

lv_obj_add_event_cb(mbox, mbox_event_cb, LV_EVENT_DELETE, NULL);

3 为小球增加增加动画效果

3.1 增加移动效果代码

lv_anim_t 是 LVGL 中用于定义和管理动画的结构体。它提供了一套功能强大的 API,用于在 LVGL 对象上实现各种动画效果。以下是 lv_anim_t 及相关函数的说明:

lv_anim_t 结构体
lv_anim_t 是一个用于描述动画的结构体,其中包含了动画的各种参数和设置。

常用函数

  1. 初始化和基本设置
lv_anim_init(lv_anim_t * a):

初始化动画对象 a,并将其字段设置为默认值。

lv_anim_set_var(lv_anim_t * a, void * var):

设置动画作用的对象或变量,通常是一个 LVGL 对象。

lv_anim_set_exec_cb(lv_anim_t * a, lv_anim_exec_xcb_t exec_cb):

设置动画的执行回调函数,用于定义如何改变对象的属性,例如位置、尺寸、透明度等。

lv_anim_set_values(lv_anim_t * a, int32_t start, int32_t end):

设置动画的起始值和结束值,定义属性从 start 到 end 的变化。

  1. 时间管理
lv_anim_set_time(lv_anim_t * a, uint32_t duration):

设置动画的持续时间(毫秒)。

lv_anim_set_delay(lv_anim_t * a, uint32_t delay):

设置动画开始前的延迟时间(毫秒)。

  1. 动画效果控制
lv_anim_set_path_cb(lv_anim_t * a, lv_anim_path_cb_t path_cb):

设置动画路径回调函数,用于定义动画的过渡效果(如线性、缓入缓出等)。

lv_anim_path_linear:

一种简单的线性过渡效果。

lv_anim_path_ease_in, lv_anim_path_ease_out:

类似于缓入和缓出的效果,用于更自然的动画过渡。

  1. 事件和重复
lv_anim_set_repeat_count(lv_anim_t * a, uint16_t repeat_count):

设置动画重复的次数,0 表示无限次。

lv_anim_set_repeat_delay(lv_anim_t * a, uint32_t repeat_delay):

设置动画重复前的延迟时间。

lv_anim_set_playback_time(lv_anim_t * a, uint32_t playback_time):

设置动画回放时间(从结束到开始)。

lv_anim_set_playback_delay(lv_anim_t * a, uint32_t playback_delay):

设置动画回放前的延迟时间。

lv_anim_set_ready_cb(lv_anim_t * a, lv_anim_ready_cb_t ready_cb):

设置动画完成时的回调函数。

  1. 启动动画
lv_anim_start(lv_anim_t * a):

启动已经配置好的动画。

void move_circle(lv_obj_t* circle, int16_t x, int16_t y)
{

    // 设置动画
    lv_anim_t a;
    lv_anim_init(&a);
    lv_anim_set_var(&a, circle);
    lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)lv_obj_set_x);
    lv_anim_set_values(&a, lv_obj_get_x(circle), x);
    lv_anim_set_time(&a, 500);  // 动画持续时间
    //lv_anim_set_ready_cb(&a, anim_ready_cb);  // 动画结束时的回调
    lv_anim_start(&a);

    lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)lv_obj_set_y);
    lv_anim_set_values(&a, lv_obj_get_y(circle), y);
    // 动画过渡
    lv_anim_set_path_cb(&a, lv_anim_path_ease_in);
    lv_anim_set_path_cb(&a, lv_anim_path_ease_out);
    lv_anim_start(&a);
    /*        lv_obj_set_pos(circle, new_x, new_y);*/


}

3.2 具体效果图片

移动小球带动画

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

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

相关文章

《Python基础》之Pandas库

目录 一、简介 二、Pandas的核心数据结构 1、Series 2、DataFrame 三、数据读取与写入 1、数据读取 2、数据写入 四、数据清洗与处理 1、处理缺失值 2、处理重复值 3、数据转换 五、数据分析与可视化 1、统计描述 2、分组聚合 3、数据可视化 六、高级技巧 1、时…

网络安全-夜神模拟器如何通过虚拟机的Burp Suite代理应用程序接口

第一步、查看虚拟机的IP地址 我们可以通过ifconfig命令来查看虚拟机的IP地址,如下图所示。 第二步、在Burp Suite上设置代理 打开虚拟机上的Burp Suite,进入到代理模块中,进入到代理设置中心 打开系统代理设置中心之后,将我们虚拟机的地址添加到上面,作为新的代理。 第…

PyTorch 2.5.1: Bugs修复版发布

一&#xff0c;前言 在深度学习框架的不断迭代中&#xff0c;PyTorch 社区始终致力于提供更稳定、更高效的工具。最近&#xff0c;PyTorch 2.5.1 版本正式发布&#xff0c;这个版本主要针对 2.5.0 中发现的问题进行了修复&#xff0c;以提升用户体验。 二&#xff0c;PyTorch 2…

SpringAi整合大模型(进阶版)

进阶版是在基础的对话版之上进行新增功能。 如果还没弄出基础版的&#xff0c;请参考 https://blog.csdn.net/weixin_54925172/article/details/144143523?sharetypeblogdetail&sharerId144143523&sharereferPC&sharesourceweixin_54925172&spm1011.2480.30…

Python实现网站资源批量下载【可转成exe程序运行】

Python实现网站资源批量下载【可转成exe程序运行】 背景介绍解决方案转为exe可执行程序简单点说详细了解下 声明 背景介绍 发现 宣讲家网 的PPT很好&#xff0c;作为学习资料使用很有价值&#xff0c;所以想下载网站的PPT课件到本地&#xff0c;但是由于网站限制&#xff0c;一…

CSS函数

目录 一、背景 二、函数的概念 1. var()函数 2、calc()函数 三、总结 一、背景 今天我们就来说一说&#xff0c;常用的两个css自定义属性&#xff0c;也称为css函数。本文中就成为css函数。先来看一下官方对其的定义。 自定义属性&#xff08;有时候也被称作CSS 变量或者级…

UG NX二次开发(C#)-选择对象居中(不是全部居中)

文章目录 1、前言2、什么是对象居中3、功能实现代码3.1 对象居中3.1 恢复原视图1、前言 在UG NX二次开发过程中,我们经常会用到居中以查看完整的模型,但是对于如果想展示某些对象,而不是全部模型时,那么我们就想将选择的对象(如体对象)居中查看,当查看结束后还能恢复到…

动态规划-----路径问题

动态规划-----路径问题 下降最小路径和1&#xff1a;状态表示2&#xff1a;状态转移方程3 初始化4 填表顺序5 返回值6 代码实现 总结&#xff1a; 下降最小路径和 1&#xff1a;状态表示 假设&#xff1a;用dp[i][j]表示&#xff1a;到达[i,j]的最小路径 2&#xff1a;状态转…

[C++设计模式] 为什么需要设计模式?

文章目录 什么是设计模式&#xff1f;为什么需要设计模式&#xff1f;GOF 设计模式再次理解面向对象软件设计固有的复杂性软件设计复杂性的根本原因如何解决复杂性&#xff1f;分解抽象 结构化 VS 面向对象(封装)结构化设计代码示例&#xff1a;面向对象设计代码示例&#xff1…

级联树结构TreeSelect和上级反查

接口返回结构 前端展示格式 前端组件 <template><div ><el-scrollbar height"70vh"><el-tree :data"deptOptions" :props"{ label: label, children: children }" :expand-on-click-node"false":filter-node-me…

Figma入门-自动布局

Figma入门-自动布局 前言 在之前的工作中&#xff0c;大家的原型图都是使用 Axure 制作的&#xff0c;印象中 Figma 一直是个专业设计软件。 最近&#xff0c;很多产品朋友告诉我&#xff0c;很多原型图都开始用Figma制作了&#xff0c;并且很多组件都是内置的&#xff0c;对…

【Unity基础】使用InputSystem实现物体跳跃

要在Unity中使用 InputSystem 实现小球按空格键跳起的效果&#xff0c;可以按照以下步骤进行&#xff1a; 1. 安装 InputSystem 包 首先&#xff0c;确保你已经安装了 Input System 包。你可以通过以下步骤安装&#xff1a; 打开 Unity 编辑器&#xff0c;点击菜单 Window -…

【ArkTS】使用AVRecorder录制音频 --内附录音机开发详细代码

系列文章目录 【ArkTS】关于ForEach的第三个参数键值 【ArkTS】“一篇带你读懂ForEach和LazyForEach” 【小白拓展】 【ArkTS】“一篇带你掌握TaskPool与Worker两种多线程并发方案” 【ArkTS】 一篇带你掌握“语音转文字技术” --内附详细代码 【ArkTS】技能提高–“用户授权”…

一种多功能调试工具设计方案开源

一种多功能调试工具设计方案开源 设计初衷设计方案具体实现HUB芯片采用沁恒微CH339W。TF卡功能网口功能SPI功能IIC功能JTAG功能下行USB接口 安路FPGA烧录器功能Xilinx FPGA烧录器功能Jlink OB功能串口功能RS232串口RS485和RS422串口自适应接口 CAN功能烧录器功能 目前进度后续计…

浏览器的事件循环机制

浏览器和Node的事件循环机制 引言浏览器的事件循环机制 引言 由于JS是单线程的脚本语言&#xff0c;所以在同一时间只能做一件事情&#xff0c;当遇到多个任务时&#xff0c;我们不可能一直等待任务完成&#xff0c;这会造成巨大的资源浪费。为了协调时间&#xff0c;用户交互…

Zabbix添加防火墙温度监控值实战

我们在Zabbix监控系统会监控诸如Server、network device、application等实例&#xff0c;通常我们在监控某个具体产品时&#xff0c;我们会找到具体的监控模板&#xff0c;在设备添加到平台以后&#xff0c;将模板链接到该设备&#xff0c;但很多时候我们企业内部的设备是没有标…

【k8s】创建基于sa的token的kubeconfig

需求 创建一个基于sa的token的kubeconfig文件&#xff0c;并用这个文件来访问集群。 具体创建sa 和sa的token请参考文章: 【k8s】给ServiceAccount 创建关联的 Secrets-CSDN博客 创建sa apiVersion: rbac.authorization.k8s.io/v1 kind: Role metadata:namespace: jtkjdevnam…

Fastapi + vue3 自动化测试平台---移动端App自动化篇

概述 好久写文章了&#xff0c;专注于新框架&#xff0c;新UI界面的实践&#xff0c;废话不多说&#xff0c;开搞 技术架构 后端&#xff1a; Fastapi Airtest multiprocessing 前端&#xff1a; 基于 Vue3、Vite、TypeScript、Pinia、Pinia持久化插件、Unocss 和 Elemen…

Apache Doris 现行版本 Docker-Compose 运行教程

特别注意&#xff01;Doris On Docker 部署方式仅限于开发环境或者功能测试环境&#xff0c;不建议生产环境部署&#xff01; 如有生产环境或性能测试集群部署诉求&#xff0c;请使用裸机/虚机部署或K8S Operator部署方案&#xff01; 原文阅读&#xff1a;Apache Doris 现行版…

Docker的彻底删除与重新安装(ubuntu22.04)

Docker的彻底删除与重新安装&#xff08;ubuntu22.04&#xff09; 一、首先我们彻底删除Docker1、删除docker及安装时自动安装的所有包2、删除无用的相关的配置文件3、删除相关插件4、删除docker的相关配置和目录 二、重新安装1、添加 Docker 的官方 GPG 密钥&#xff1a;2、将…