雷电飞机大战游戏|基于Java开发实现雷电飞机大战游戏

简介: 雷电飞机大战游戏|基于Java开发实现雷电飞机大战游戏

前言:

电脑游戏,是指在计算机上能够运转的游戏软件。这种软件具有较强的娱乐性。电脑游戏的创新和发展与硬件、软件的发展紧密相关。它能够给玩家提供一个虚拟的环境,使游戏带给了人们很多的享受和欢乐。雷电游戏因为操作简单,节奏明快,一直是纵轴射击游戏的经典之作。经常能够在手机或者计算机中见到这款游戏,深得广大玩家的喜爱,可以说是妇孺皆知的一款益智类游戏。

  本游戏基于Eclipse开发工具,以java作为编程语言,整个项目开发旨在模拟雷电游戏的飞机射击游戏。游戏界面的下部是玩家的飞机,可以根据按键控制子弹的发射,上部为敌方飞机,在界面中随机出现。在游戏过程当中,用户飞机的移动是被电脑键盘的方向键所控制的,在整个游戏过程当中,如果用户飞机的子弹与敌方飞机发生相撞时,敌方飞机就会有爆炸的效果产生。游戏中使用到的飞机、子弹均采用对应的类实现。

一,项目简介

我们在小时候都拥有属于自己的一台游戏机,里面形形色色大概有十来款游戏。像 “扫雷”、“推箱子”、“俄罗斯方块”等等,我们的童年有这些游戏陪伴我们是幸福的,令许多小伙伴都为之痴迷,即使现在,这些都是随处可见的休闲游戏。我之选择“雷电”游戏作为我的毕业设计,因为它可以代表一代人青春的回忆。

Java语言,实际上就是面向对象的编程语言。对于计算机编程者来说,使用Java最大的好处有两方面,一是就编写程序而言,非常的简单也容易使用,二是它的功能很强大。与此同时,面向对象理论得以很好的实现。“雷电”游戏的毕业设计使我对本科期间所学知识进行了巩固。

   目前常见的电脑游戏的类型有动作游戏、传统益智游戏、体育游戏、策略游戏、休闲游戏和角色扮演类游戏等。不同的类型的游戏有着自身的特点,每一种类型的游戏都有一定的支持人群。开发出一款良好的游戏,了解各种类型的基本特点是很有必要的。而“雷电”游戏就属于上述类型中的STG(射击类)游戏,STG(Shooting Game)类型游戏主要凭借远程武器与敌方开展模拟对抗,拥有绚丽的射击画面。

这个项目使我第一次全流程地独立完成整条链路的开发,对于我自己而言,是0-1的突破。万事开头难,有了这次完整项目开发的经历,以后再做游戏或者其它项目时就对全局有所把控,能够做到游刃有余。假如自己没有亲自动手设计这些,哪怕一次,就不能够真正的领会一个完整项目体系中的每个元素。在以后做一些大的项目时,就更不能对整体进行宏观思考,也就不能对具体项目中每一个细分的小模块进行合适的时间估计,导致项目开发超过预期时间,更有甚,不能完成。

大部分的射击类游戏都存在一定的相似性,雷电游戏也不存在特殊。其实就是一个周而复始的情形,一直到游戏结束才能够停止。游戏开始阶段接受玩家的输入并对这个输入办理,如果没有结束就会不断产生飞机,通过检查我方飞机的血条判断游戏是不是最终结束。

该雷电主要就是我方飞机与敌方飞机的射击比拼,首先需要有界面来装载整个项目,通过键盘的上、下、左、右键遥控自己的飞机,z、x键进行子弹发射的选择,然后是敌方飞机的出现方式,敌机子弹的生成,通过各个关卡,最后得出比赛的结果。

雷电游戏主要包括以下功能:

  1. 雷电游戏状态调整功能 :在游戏启动时,游戏会自动进行初始化的验证,若初始化成功后,界面会自动进行跳转,跳转到游戏开始界面,有开始、暂停、恢复游戏等选项。

   (2)雷电游戏难度的升级:当进入游戏后,随着时间越来越长,游戏难度会越来越大,界面中敌机增多,对飞机造成伤害的子弹增多,游戏难度增加,最后会遇到一个血条较长的怪兽,攻击其至血条为0时,自动过关跳转到下一关卡。

   (3)玩家对飞机的控制功能:玩家可以对飞机进行操控,通过前后左右键来控制飞机的飞行路线。

   (4)游戏界面绘画功能。

关键技术

  1. 游戏美工。游戏中需要使用的游戏素材有自己控制的飞机、敌方飞机、游戏过程当中飞机所产生的子弹、飞机被命中的爆炸图片等。这些素材的选择尤为重要,游戏中清新亮丽的画面可以给玩家带来充足的美感和游戏体验。所以,在这个“雷电”游戏的素材选择中,应挑选一些立体感强的图片,给玩家更大的视觉冲击。
  2. 多线程技术的实现。多线程编程能够提供程序两个或两个以上并发执行任务的能力,极大改善程序的响应性能,有效提高资源的利用效率。采取Runnable接口的方法达到定义用户线程的功能,这样既不会对继承其他类有所变化,也不会改变实现其它接口。
  3. 用户飞机子弹与敌方飞机的相撞测试。包括自己控制的飞机与敌方飞机或子弹的相撞等。在这一过程中,将所有子弹对象的矩形区域与敌机对象的矩形区域逐个以此进行检测,如果出现重叠则说明子弹与敌机发生了碰撞。

(4)游戏地图滚动原理的实现。我们在坐火车时都产生过一种错觉:自己乘坐的火车没有发生移动,但如果旁边有其他火车发生移动,我们就会感到是自己的火车在移动。这种现象与飞机射击类游戏的地图原理类似,即通过背景图片的来回滚动,给游戏玩家一种是自己操纵的飞机向前飞行的感觉。

二,环境介绍

语言环境:Java:  jdk1.8

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse

开发技术:JavaSwing 及多线程

三,系统展示

四,核心代码展示

package com.ideabobo.game.leidian;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Image;
import com.ideabobo.game.leidian.Boss;
public class Battle extends Role {
  private static Battle battle = new Battle();
  private int tamaIntCount;
  private float speed;
  private float oldx;
  private float oldy;
  public static float vx;
  public static float vy;
  public static boolean keygo = false;
  private float tv[] = { -1F, -7F, 0.0F, -8F, 1.0F, -7F };
  public int power;
  public int powerMax;
  public Battle() {
    super(GamePanel.heroImage);
    speed = 3F;
    tamaIntCount = 0;
    x = ((float) app.getWidth() - WIDTH) / 2.0F;
    y = (float) app.getHeight() - HEIGHT * 2.0F;
    power = 600;
    powerMax = power;
  }
  public static Battle getInstance() {
    return battle;
  }
  public void move() {
    oldx = x;
    oldy = y;
    if (Key.left) {
      if (Key.xkey)
        x -= (double) speed / 4D;
      else
        x -= speed;
      if (x <= 0.0F)
        x = 0.0F;
    }
    if (Key.right) {
      if (Key.xkey)
        x += (double) speed / 4D;
      else
        x += speed;
      if (x + WIDTH >= (float) app.getWidth())
        x = (float) app.getWidth() - WIDTH;
    }
    if (Key.down) {
      if (Key.xkey)
        y += (double) speed / 4D;
      else
        y += speed;
      if (y + HEIGHT >= (float) app.getHeight())
        y = (float) app.getHeight() - HEIGHT;
    }
    if (Key.up) {
      if (Key.xkey)
        y -= (double) speed / 4D;
      else
        y -= speed;
      if (y <= 0.0F)
        y = 0.0F;
    }
    //**//--///loonframewrk提供
    vx = x - oldx;
    vy = y - oldy;
    if (tamaIntCount > 0)
      tamaIntCount--;
    if (Key.zkey && tamaIntCount <= 0) {
      for (int i = 0; i < tv.length; i += 2) {
        GamePanel.addList(new BattleBasic(x + WIDTH / 2.0F, y, tv[i],
            tv[i + 1]));
        tamaIntCount = 8;
      }
    }
    if (Key.xkey && !Key.zkey && tamaIntCount <= 0) {
      GamePanel.addList(new BattleBeam(x + WIDTH / 2.0F, y, 0.0F, -8F));
      tamaIntCount = 2;
    }
    if(Key.space){
      if(!keygo){
        GamePanel.skillCount--;
      }
      app.skillAnime();
      if(GamePanel.skillCount < 0){
        GamePanel.skillCount = 0;
      }
      if(GamePanel.skillCount>0){
        for (int i = 0; i < GamePanel.list.size(); i++) {
          Role chara1 = (Role) GamePanel.list.get(i);
          if(!(chara1 instanceof Battle) && chara1.x>0 && chara1.y>0 && !(chara1 instanceof BossA)  && !(chara1 instanceof BossB)  && !(chara1 instanceof BossC)){
            GamePanel.list.remove(i);
          }else if((chara1 instanceof BossA)  || (chara1 instanceof BossB)  || (chara1 instanceof BossC)){
            Boss cb = (Boss)chara1;
            cb.power-=50;
          }
        }
      }
      keygo = true;
    }
    if(!Key.space){
      keygo = false;
    }
  }
  public boolean checkHit(Role chara) {
    if ((chara instanceof EnemyA) || (chara instanceof EnemyB)|| (chara instanceof EnemyC) || (chara instanceof EnemyShot)) {
      if ((x + WIDTH) - 14F > chara.x && x + 14F < chara.x + chara.WIDTH
          && (y + HEIGHT) - 12F > chara.y
          && y + 12F < chara.y + chara.HEIGHT) {
        //如果碰到敌人,敌人死亡
        chara.dead();
        //如果碰到子弹血量减少
        if (chara instanceof EnemyBeam){
          power--;
        }
        power -= 50;
        if (power <= 0) {
          dead();
          //绘制爆炸图片
          GamePanel.burst = new Burst(x, y);
        }
        return true;
      }
    } else if ((chara instanceof Boss) && (x + WIDTH) - 14F > chara.x + 50F
        && x + 14F < (chara.x + chara.WIDTH) - 50F
        && (y + HEIGHT) - 12F > chara.y + 50F
        && y + 12F < (chara.y + chara.HEIGHT) - 80F) {
      power--;
      if (power <= 0) {
        dead();
        GamePanel.burst = new Burst(x, y);
      }
      return true;
    }
    return false;
  }
  public void setX(float x) {
    this.x = x;
  }
  public void setY(float y) {
    this.y = y;
  }
  public float getWidth() {
    return WIDTH;
  }
  public float getHeight() {
    return HEIGHT;
  }
  public float getX() {
    return x;
  }
  public float getY() {
    return y;
  }
  public Image getImage() {
    return img;
  }
  public int getPower() {
    return power;
  }
  public int getPowerMax() {
    return powerMax;
  }
  public void setPower(int power) {
    this.power = power;
  }
  public void drawPower(Graphics g) {
    g.setColor(Color.white);
    g.drawRect(380, 450, 50, 15);
    g.setColor(Color.red);
    g.fillRect(381, 451,
        (int) ((50D / (double) (float) powerMax) * (double) power) - 1,
        14);
  }
  public void drawSkillCount(Graphics g){
    g.setColor(Color.white);
    Font font = new Font("宋体", 1, 20);
    g.setFont(font);
    g.drawString("全屏爆破:" + GamePanel.skillCount, 0, 450);
  }
}
package com.ideabobo.game.leidian;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Image;
abstract class Boss extends Enemy {
  protected int powerMax;
  public Boss(Battle battle, Image enemyImage) {
    super(battle, enemyImage);
  }
  public abstract void move();
  public float getX() {
    return x;
  }
  public float getY() {
    return y;
  }
  public float getWidth() {
    return WIDTH;
  }
  public float getHeight() {
    return HEIGHT;
  }
  public int getPower() {
    return power;
  }
  public Image getImage() {
    return img;
  }
  public void drawPower(Graphics g) {
    g.setColor(Color.white);
    g.drawRect(200, 20, 150, 15);
    g.setColor(Color.green);
    g
        .fillRect(
            201,
            21,
            (int) ((150D / (double) (float) powerMax) * (double) power) - 1,
            14);
  }
  public int getPowerMax() {
    return powerMax;
  }
}

五,项目总结

本次项目开发是基于JAVA的雷电游戏。

此雷电游戏通俗来说就是我方飞机和敌方之间的对决,先要做的应该是通过一个界面来达到装载整个游戏,然后就是我方飞机的移动方式(也就是通过键盘来移动),接着就是生成我方飞机的子弹(依据子弹类型的不同有不同的实现形式),准备就绪后会有敌方飞机的出现,每一个飞机会对应发射不同种类的子弹,最后是我方飞机通过键盘进行移动、射击,显示出游戏结果,然后结束游戏。

该雷电应该满足以下一些要求:

(1)游戏状态控制功能

在进行游戏的设计时,我们应该考虑到,如何进行游戏状态的划分。简单来说,我们需要设置开始,并且要考虑到游戏中断,以及中断后回到游戏中。玩家点击开始之后,程序会调用启动页面的代码,然后进入游戏,在游戏的过程中,玩家如果由于其它工作需要离开时,可以将其中断,比如单击空格键,当需要恢复游戏现场时,再单击空格键,就可以继续游戏,当自己控制的飞机被击毁时,会有游戏结束的显现。

(2)游戏难度的调整

   随着游戏的进行、关卡的提高,敌机的速度会越来越快、敌方飞机的数目会越来越多、子弹数量也会越快且越多。此时,带给游戏玩家的视觉冲击变得更强,需要玩家更加冷静地去躲闪以及攻击敌机。

(3)游戏界面绘画功能

游戏主屏主要用来输出用户对我方的控制与敌方的动作显示。在游戏屏幕的左下角有全屏爆破次数的显示,这相当于游戏玩家的特殊技能,可以瞬间清除当前屏幕上的所有敌机以及子弹,在游戏屏幕的右下角会呈现玩家飞机血条,代表着当前我方飞机的状态。当血条格为空时,表示我方飞机已经被击毁,整个雷电游戏也将结束。

  1. 玩家游戏控制功能

对于我方飞机的移动和子弹的发射,游戏用户可以通过控制键盘来控制。飞机的左右移动通过键盘的上、下、左、右键来实现,而我方飞机子弹的释放方式有两种,z键会释放出点状子弹,而x键会释放出线状子弹,可供游戏玩家依据需要自行选择。

相关文章
|
2月前
|
安全 Java 领域建模
Java 17 探秘:不容错过的现代开发利器
Java 17 探秘:不容错过的现代开发利器
107 0
|
1月前
|
安全 Oracle Java
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡
154 0
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡
|
2月前
|
并行计算 Java API
Java List 集合结合 Java 17 新特性与现代开发实践的深度解析及实战指南 Java List 集合
本文深入解析Java 17中List集合的现代用法,结合函数式编程、Stream API、密封类、模式匹配等新特性,通过实操案例讲解数据处理、并行计算、响应式编程等场景下的高级应用,帮助开发者提升集合操作效率与代码质量。
126 2
|
2月前
|
安全 Java API
Java 17 及以上版本核心特性在现代开发实践中的深度应用与高效实践方法 Java 开发实践
本项目以“学生成绩管理系统”为例,深入实践Java 17+核心特性与现代开发技术。采用Spring Boot 3.1、WebFlux、R2DBC等构建响应式应用,结合Record类、模式匹配、Stream优化等新特性提升代码质量。涵盖容器化部署(Docker)、自动化测试、性能优化及安全加固,全面展示Java最新技术在实际项目中的应用,助力开发者掌握现代化Java开发方法。
115 1
|
2月前
|
IDE Java API
Java 17 新特性与微服务开发的实操指南
本内容涵盖Java 11至Java 17最新特性实战,包括var关键字、字符串增强、模块化系统、Stream API、异步编程、密封类等,并提供图书管理系统实战项目,帮助开发者掌握现代Java开发技巧与工具。
143 2
|
2月前
|
安全 Java 测试技术
Java 大学期末实操项目在线图书管理系统开发实例及关键技术解析实操项目
本项目基于Spring Boot 3.0与Java 17,实现在线图书管理系统,涵盖CRUD操作、RESTful API、安全认证及单元测试,助力学生掌握现代Java开发核心技能。
101 1
|
2月前
|
人工智能 前端开发 安全
Java开发不可不知的秘密:类加载器实现机制
类加载器是Java中负责动态加载类到JVM的组件,理解其工作原理对开发复杂应用至关重要。本文详解类加载过程、双亲委派模型及常见类加载器,并介绍自定义类加载器的实现与应用场景。
170 4
|
1月前
|
移动开发 Cloud Native 安全
Java:跨平台之魂,企业级开发的磐石
Java:跨平台之魂,企业级开发的磐石
|
1月前
|
设计模式 人工智能 前端开发
现代 Java 实现数字华容道与石头迷阵游戏的项目实战及项目开发指南
本项目基于Java 17+,采用JavaFX与MVC架构,实战开发数字华容道/石头迷阵游戏。内容涵盖技术选型、核心逻辑、现代GUI设计、动画实现及项目打包发布,结合sealed class、record等新特性,打造简洁可维护的游戏代码结构。
89 0
|
2月前
|
机器学习/深度学习 存储 Java
Java 大视界 -- Java 大数据机器学习模型在游戏用户行为分析与游戏平衡优化中的应用(190)
本文探讨了Java大数据与机器学习模型在游戏用户行为分析及游戏平衡优化中的应用。通过数据采集、预处理与聚类分析,开发者可深入洞察玩家行为特征,构建个性化运营策略。同时,利用回归模型优化游戏数值与付费机制,提升游戏公平性与用户体验。

热门文章

最新文章