第十一天 主菜单/设置界面 过场动画(Timeline) 成就系统(Steam/本地) 多语言支持

news2025/7/15 12:44:57

前言

对于刚接触Unity的新手开发者来说,构建完整的游戏系统往往充满挑战。本文将手把手教你实现游戏开发中最常见的四大核心系统:主菜单界面、过场动画、成就系统和多语言支持。每个模块都将结合完整代码示例,使用Unity 2022 LTS版本进行演示。


一、主菜单系统搭建

1.1 基础UI搭建

在Hierarchy面板右键创建Canvas,设置Canvas Scaler为Scale With Screen Size:

// MenuController.cs
public class MenuController : MonoBehaviour
{
    [SerializeField] private Button startButton;
    [SerializeField] private Button settingsButton;
    [SerializeField] private Button quitButton;

    private void Start()
    {
        startButton.onClick.AddListener(StartGame);
        settingsButton.onClick.AddListener(OpenSettings);
        quitButton.onClick.AddListener(QuitGame);
    }

    private void StartGame() => SceneManager.LoadScene("GameScene");
    private void OpenSettings() => SettingsWindow.Instance.Show();
    private void QuitGame() => Application.Quit();
}

关键要点:

  • 使用Canvas Scaler确保多分辨率适配
  • 按钮事件通过AddListener绑定
  • 采用单例模式管理设置窗口

1.2 设置界面实现

创建嵌套Canvas实现设置面板:

// SettingsWindow.cs
public class SettingsWindow : MonoBehaviour
{
    public static SettingsWindow Instance;
    
    [SerializeField] private Slider volumeSlider;
    [SerializeField] private TMP_Dropdown qualityDropdown;

    private void Awake() => Instance = this;

    private void Start()
    {
        volumeSlider.value = PlayerPrefs.GetFloat("MasterVolume", 1f);
        qualityDropdown.AddOptions(QualitySettings.names.ToList());
        qualityDropdown.value = QualitySettings.GetQualityLevel();
    }

    public void OnVolumeChanged(float value)
    {
        AudioListener.volume = value;
        PlayerPrefs.SetFloat("MasterVolume", value);
    }

    public void OnQualityChanged(int index)
    {
        QualitySettings.SetQualityLevel(index);
    }
}

功能亮点:

  • PlayerPrefs持久化存储设置
  • 动态加载画质选项
  • 实时音效控制

二、过场动画制作(Timeline)

2.1 Timeline基础使用

  1. 创建Timeline资源
  2. 添加Animation Track控制相机移动
  3. 添加Activation Track控制UI显示
// CutsceneManager.cs
public class CutsceneManager : MonoBehaviour
{
    [SerializeField] private PlayableDirector director;
    
    public void PlayOpeningCutscene()
    {
        director.Play();
        director.stopped += OnCutsceneFinished;
    }

    private void OnCutsceneFinished(PlayableDirector obj)
    {
        SceneManager.LoadScene("MainScene");
    }
}

2.2 高级动画技巧

混合使用多种Track类型:

  • Cinemachine Virtual Camera:专业运镜
  • Audio Track:背景音乐控制
  • UI Animation Track:实现渐变效果
// 在Timeline信号接收器中
public void OnDialogueSignal(string dialogueText)
{
    DialogueSystem.Instance.Show(dialogueText);
}

三、成就系统开发

3.1 本地成就系统

使用ScriptableObject存储成就数据:

// Achievement.cs
[CreateAssetMenu]
public class Achievement : ScriptableObject
{
    public string achievementID;
    public string title;
    public string description;
    public bool isUnlocked;
}

// AchievementManager.cs
public class AchievementManager : MonoBehaviour
{
    public List<Achievement> achievements = new List<Achievement>();

    public void UnlockAchievement(string achievementID)
    {
        var achievement = achievements.Find(a => a.achievementID == achievementID);
        if (!achievement.isUnlocked)
        {
            achievement.isUnlocked = true;
            SaveAchievements();
            ShowNotification(achievement);
        }
    }

    private void SaveAchievements()
    {
        string json = JsonUtility.ToJson(new AchievementData(achievements));
        PlayerPrefs.SetString("Achievements", json);
    }
}

3.2 Steam成就集成

需要安装Steamworks.NET插件:

// SteamAchievementManager.cs
public class SteamAchievementManager : MonoBehaviour
{
    private void Awake()
    {
        try
        {
            Steamworks.SteamClient.Init(480);
        }
        catch (System.Exception e)
        {
            Debug.LogError(e);
        }
    }

    public void UnlockSteamAchievement(string apiName)
    {
        if (Steamworks.SteamUserStats.SetAchievement(apiName))
        {
            Steamworks.SteamUserStats.StoreStats();
        }
    }
}

四、多语言支持方案

4.1 本地化系统搭建

使用Unity官方Localization包:

// LanguageSwitcher.cs
public class LanguageSwitcher : MonoBehaviour
{
    [SerializeField] private TMP_Dropdown languageDropdown;

    private void Start()
    {
        var locales = LocalizationSettings.AvailableLocales.Locales;
        languageDropdown.options = locales.Select(l => 
            new TMP_Dropdown.OptionData(l.LocaleName)).ToList();
    }

    public void OnLanguageChanged(int index)
    {
        LocalizationSettings.SelectedLocale = 
            LocalizationSettings.AvailableLocales.Locales[index];
    }
}

4.2 文本本地化实践

  1. 创建Localization Tables
  2. 为Text组件添加Localized Text组件
  3. 配置不同语言的翻译文件
// 动态文本更新示例
[SerializeField] private LocalizedString localizedWelcome;

private void UpdateWelcomeText()
{
    localizedWelcome.StringChanged += OnStringChanged;
}

private void OnStringChanged(string value)
{
    welcomeText.text = value;
}

五、系统整合与优化

5.1 项目架构设计

推荐采用分层架构:

Assets/
├─ Scripts/
│  ├─ Systems/      // 核心系统
│  ├─ UI/           // 界面相关
│  └─ Utilities/    // 工具类
├─ Prefabs/
├─ Localization/
└─ Resources/       // 动态加载资源

5.2 性能优化技巧

  1. 对象池管理菜单界面
  2. 使用Addressables进行资源加载
  3. Coroutine实现异步加载
// 场景异步加载示例
IEnumerator LoadGameSceneAsync()
{
    AsyncOperation operation = SceneManager.LoadSceneAsync("GameScene");
    loadingProgressBar.gameObject.SetActive(true);
    
    while (!operation.isDone)
    {
        float progress = Mathf.Clamp01(operation.progress / 0.9f);
        loadingProgressBar.value = progress;
        yield return null;
    }
}

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

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

相关文章

AI数字人:未来职业的重塑(9/10)

摘要&#xff1a;AI 数字人凭借计算机视觉、自然语言处理与深度学习技术&#xff0c;从虚拟形象进化为智能交互个体&#xff0c;广泛渗透金融、教育、电商等多领域&#xff0c;重构职业生态。其通过降本提效、场景拓展与体验升级机制&#xff0c;替代重复岗位工作&#xff0c;催…

深入解析Mlivus Cloud中的etcd配置:最佳实践与高级调优指南

作为大禹智库的向量数据库高级研究员,我在《向量数据库指南》一书中详细阐述了向量数据库的核心组件及其优化策略。今天,我将基于30余年的实战经验,深入剖析Mlivus Cloud中etcd这一关键依赖的配置细节与优化方法。对于希望深入掌握Mlivus Cloud的读者,我强烈建议参考《向量…

前端面试宝典---vue原理

vue的Observer简化版 class Observer {constructor(value) {if (!value || typeof value ! object) returnthis.walk(value) // 对对象的所有属性进行遍历并定义响应式}walk (obj) {Object.keys(obj).forEach(key > defineReactive(obj, key, obj[key]))} } // 定义核心方法…

PyTorch卷积层填充(Padding)与步幅(Stride)详解及代码示例

本文通过具体代码示例讲解PyTorch中卷积操作的填充&#xff08;Padding&#xff09;和步幅&#xff08;Stride&#xff09;对输出形状的影响&#xff0c;帮助读者掌握卷积层的参数配置技巧。 一、填充与步幅基础 填充&#xff08;Padding&#xff09;&#xff1a;在输入数据边缘…

用go从零构建写一个RPC(仿gRPC,tRPC)--- 版本1

希望借助手写这个go的中间件项目&#xff0c;能够理解go语言的特性以及用go写中间件的优势之处&#xff0c;同时也是为了更好的使用和优化公司用到的trpc&#xff0c;并且作者之前也使用过grpc并有一定的兴趣&#xff0c;所以打算从0构建一个rpc系统&#xff0c;对于生产环境已…

django之账号管理功能

账号管理功能 目录 1.账号管理页面 2.新增账号 3.修改账号 4.账号重置密码 5.删除账号功能 6.所有代码展示集合 7.运行结果 这一片文章, 我们需要新增账号管理功能, 今天我们写到的代码, 基本上都是用到以前所过的知识, 不过也有需要注意的细节。 一、账号管理界面 …

月之暗面开源 Kimi-Audio-7B-Instruct,同时支持语音识别和语音生成

我们向您介绍在音频理解、生成和对话方面表现出色的开源音频基础模型–Kimi-Audio。该资源库托管了 Kimi-Audio-7B-Instruct 的模型检查点。 Kimi-Audio 被设计为通用的音频基础模型&#xff0c;能够在单一的统一框架内处理各种音频处理任务。主要功能包括&#xff1a; 通用功…

IDEA配置将Servlet真正布署到Tomcat

刚开始只能IDEA运行完Servlet web application 并保持IDEA运行才能通过浏览器访问到我的Servlet&#xff0c;跟想象中的不一样&#xff0c;不应该是IDEA运行完项目以后只要打开Tomcat就能访问吗&#xff1f;事实时运行完项目只要关掉IDEA就不能再访问到应用了&#xff0c;而且T…

刚体运动 (位置向量 - 旋转矩阵) 笔记 1.1~1.3 (台大机器人学-林沛群)

目录 1. 理解刚体的“自由度”&#xff08;Degrees of Freedom, DOF&#xff09; 1.1 平面运动 (2D) 1.2 空间运动 (3D) 2. 统一描述&#xff1a;引入“体坐标系”&#xff08;Body Frame&#xff09; 3. 从“状态”到“运动”&#xff1a;引入微分 3.1 补充&#xff1a;…

openAICEO山姆奥特曼未来预测雄文之三个观察

《三个观察》 山姆奥特曼 这篇文章主要讲的是关于AGI&#xff08;人工通用智能&#xff09;的未来发展及其对社会的影响&#xff0c;用大白话总结如下&#xff1a; 核心观点&#xff1a; AGI是什么&#xff1f; AGI是一种能像人类一样解决各种复杂问题的智能系统&#xff0c;比…

比象AI创作系统,多模态大模型:问答分析+AI绘画+管理后台系统

比象AI创作系统是新一代集智能问答、内容创作与商业运营于一体的综合型AI平台。本系统深度融合GPT-4.0/GPT-4o多模态大模型技术&#xff0c;结合实时联网搜索与智能分析能力&#xff0c;打造了从内容生产到商业变现的完整闭环解决方案。 智能问答中枢 系统搭载行业领先的对话…

Docker-高级使用

前言 书接上文Docker-初级安装及使用_用docker安装doccano-CSDN博客&#xff0c;我们讲解了Docker的基本操作&#xff0c;下面我们讲解的是高级使用&#xff0c;请大家做好准备&#xff01; 大家如果是从初级安装使用过来的话&#xff0c;建议把之前镜像和搭载的容器数据卷里面…

计算机网络 | Chapter1 计算机网络和因特网

&#x1f493;个人主页&#xff1a;mooridy-CSDN博客 &#x1f493;文章专栏&#xff1a;《计算机网络&#xff1a;自定向下方法》 大纲式阅读笔记_mooridy的博客-CSDN博客 &#x1f339;关注我&#xff0c;和我一起学习更多计算机网络的知识 &#x1f51d;&#x1f51d; 目录 …

开源项目实战学习之YOLO11:ultralytics-cfg-datasets-Objects365、open-images-v7.yaml文件(六)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 medical - pills.yaml 通常用于配置与医学药丸检测任务相关的参数和信息 Objects365.yaml 用于配置与 Objects365 数据集相关信息的文件。Objects365 数据集包含 365 个不同的物体类别…

蚂蚁集团“Plan A”重磅登场,开启AI未来

近期&#xff0c;蚂蚁集团面向全球高潜AI人才&#xff0c;正式发布顶级专项招募计划——“Plan A”。作为其“蚂蚁星”校招体系的全新升级模块&#xff0c;Plan A聚焦人工智能领域科研精英&#xff0c;旨在与全球高校AI研究者协同突破AGI前沿&#xff0c;共绘技术未来图谱。 蚂…

高中数学联赛模拟试题精选第18套几何题

在 △ A B C \triangle ABC △ABC 中, A B < A C AB< AC AB<AC, 点 K K K, L L L, M M M 分别是边 B C BC BC, C A C A CA, A B AB AB 的中点. △ A B C \triangle ABC △ABC 的内切圆圆心为 I I I, 且与边 B C BC BC 相切于点 D D D. 直线 l l l 经过线段…

Java 富文本转word

前言&#xff1a; 本文的目的是将传入的富文本内容(html标签&#xff0c;图片)并且分页导出为word文档。 所使用的为docx4j 一、依赖导入 <!-- 富文本转word --><dependency><groupId>org.docx4j</groupId><artifactId>docx4j</artifactId&…

多模态大语言模型arxiv论文略读(四十三)

InteraRec: Screenshot Based Recommendations Using Multimodal Large Language Models ➡️ 论文标题&#xff1a;InteraRec: Screenshot Based Recommendations Using Multimodal Large Language Models ➡️ 论文作者&#xff1a;Saketh Reddy Karra, Theja Tulabandhula …

GPU加速-系统CUDA12.5-Windows10

误区注意 查看当前系统可支持的最高版本cuda&#xff1a;nvidia-smi 说明&#xff1a; 此处显示的12.7只是驱动对应的最高版本&#xff0c;不一定是 / 也不一定需要是 当前Python使用的版本。但我们所安装的CUDA版本需要 小于等于它&#xff08;即≤12.7&#xff09;因此即使…

kafka课后总结

Kafka是由LinkedIn开发的分布式发布 - 订阅消息系统&#xff0c;具备高吞吐量、低延迟、可扩展性、持久性、可靠性、容错性和高并发等特性。其主要角色包括Broker、Topic、Partition、Producer、Consumer、Consumer Group、replica、leader、follower和controller。消息系统中存…