手把手一步一步教你使用Java开发一个大型街机动作闯关类游戏02支持中文及显示FPS

简介: 手把手一步一步教你使用Java开发一个大型街机动作闯关类游戏02支持中文及显示FPS

项目源码

项目源码

支持中文

新建res文件夹,添加支持中文的字体文件simsun.ttf

修改GameApp.java

public class GameApp {
    private boolean _gameRunning = true;
    private Frame _frm;
    private Font _font;
    public GameApp(){
        try{
            _font = Font.createFont(Font.TRUETYPE_FONT, getClass().getClassLoader().getResourceAsStream("res/simsun.ttf"));
            _font = _font.deriveFont(18f);

并且:


image.png


1640586763(1).png


显示FPS


FPS 每秒帧数(Frames Per Second)

如果设置FPS为20,这意味着我们命令游戏的每个循环持续1 / 20(0.05)秒。如果循环代码(更新,绘图等)只需要0.03秒,那么我们将等待0.02秒。以上是计算机处理比较快的情况。如果电脑比较差,运行缓慢,一秒钟未必能执行20次循环--- 那么FPS设置成20就成为一个指导意见。

具体实现如下:

新建一个utils包,包里新建一个FpsHandler.java类:

package utils;
public class FpsHandler {
    private long _lastFpsTime = 0;
    private int _fps;//计数器
    private int _displayFps;
    private long _seconds = 1000000000;//1秒
    //接受一个updateTime参数,单位为纳秒,累加到_lastFpsTime上;_fps是一个计数器
    //如果_lastFpsTime >= _seconds条件满足说明刚刚过去了1秒,重置_lastFpsTime,_fps
    //返回_displayFps;该值不是0就是_fps(即1秒钟的帧数)
    public int getFps(long updateTime){
        _lastFpsTime += updateTime;
        _fps++;
        if (_lastFpsTime >= _seconds)
        {
            _displayFps = _fps;
           _lastFpsTime = 0;
           _fps = 0;
        }
        return _displayFps;
    }
}

1秒=1000毫秒(ms)

1秒=1,000,000 微秒(μs)

1秒=1,000,000,000 纳秒(ns)

为了精确计时,我们这里使用纳秒作为单位

主循环代码修改如下:

image.png


1640588008(1).png

每次循环开始,获取当前系统时间(纳秒),接下来计算updateTime,其值等于now(本次循环开始时间)减去lastTime(上次循环开始时间),也即,上次循环一共消耗了多少时间。

private void _displayInfoText(Graphics2D g, long updateTime){
        g.setColor(Color.white);
        g.drawString(Config.TITEL+ " "+ Config.VERSION, 20, 20);
        int fps = _fpsh.getFps(updateTime);
        g.drawString("FPS: "+fps, 20, 35);
    }


如何控制循环按我们设置的FPS运行

注释掉我们上节代码中的Thread.sleep(1);改成下面的代码:


image.png

1640588116(1).png


其中:

long optimalTime = 1000000000 / Config.FPS;

上面代码的原理即:

如果设置FPS为20,这意味着我们命令游戏的每个循环持续1 / 20(0.05)秒。

如果循环代码(更新,绘图等)只需要0.03秒,那么我们将等待0.02秒(Thread.sleep(optimalTimeHao - duringTimeHao))。

以上是计算机处理比较快的情况。如果电脑比较差,运行缓慢,一秒钟未必能执行20次循环--- 那么FPS设置成20就成为一个指导意见(Thread.sleep(0))。


本节最终效果


image.png


目录
相关文章
|
8天前
|
安全 Java 数据建模
Java记录类:简化数据载体的新选择
Java记录类:简化数据载体的新选择
161 101
|
8天前
|
安全 Java 开发者
Java记录类:简化数据载体的新方式
Java记录类:简化数据载体的新方式
172 100
|
12天前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
12天前
|
存储 Java 关系型数据库
Java 项目实战基于面向对象思想的汽车租赁系统开发实例 汽车租赁系统 Java 面向对象项目实战
本文介绍基于Java面向对象编程的汽车租赁系统技术方案与应用实例,涵盖系统功能需求分析、类设计、数据库设计及具体代码实现,帮助开发者掌握Java在实际项目中的应用。
36 0
|
1月前
|
缓存 安全 Java
Java反射机制:动态操作类与对象
Java反射机制是运行时动态操作类与对象的强大工具,支持获取类信息、动态创建实例、调用方法、访问字段等。它在框架开发、依赖注入、动态代理等方面有广泛应用,但也存在性能开销和安全风险。本文详解反射核心API、实战案例及性能优化策略,助你掌握Java动态编程精髓。
|
1月前
|
存储 安全 Java
Java集合框架(一):List接口及其实现类剖析
本文深入解析Java中List集合的实现原理,涵盖ArrayList的动态数组机制、LinkedList的链表结构、Vector与Stack的线程安全性及其不推荐使用的原因,对比了不同实现的性能与适用场景,帮助开发者根据实际需求选择合适的List实现。
|
12天前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
47 0
|
24天前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
58 16
|
1月前
|
缓存 并行计算 安全
关于Java多线程详解
本文深入讲解Java多线程编程,涵盖基础概念、线程创建与管理、同步机制、并发工具类、线程池、线程安全集合、实战案例及常见问题解决方案,助你掌握高性能并发编程技巧,应对多线程开发中的挑战。