Java实现一个坦克大战的小游戏【附源码】

简介: Java实现一个坦克大战的小游戏【附源码】

1 前言

🚀获取源码,文末公众号回复【坦克】,即可。

⭐欢迎点赞留言

2 正文

13MB GIF可以欣赏:

https://ucc.alicdn.com/images/user-upload-01/img_convert/4721f22d97731adcdbc8baff4b520176.gif


2.2 项目结构

2.2 主要代码展示


var Bullet = function(context,owner,type,dir){
  this.ctx = context;
  this.x = 0;
  this.y = 0;
  this.owner = owner; //子弹的所属者
  this.type = type;//1、玩家  2、敌方
  this.dir = dir;
  this.speed = 3;
  this.size = 6;
  this.hit = false;
  this.isDestroyed = false;
  
  this.draw = function(){
    this.ctx.drawImage(RESOURCE_IMAGE,POS["bullet"][0]+this.dir*this.size,POS["bullet"][1],this.size,this.size,this.x,this.y,this.size,this.size);
    this.move();
  };
  
  this.move = function(){
    if(this.dir == UP){
      this.y -= this.speed;
    }else if(this.dir == DOWN){
      this.y += this.speed;
    }else if(this.dir == RIGHT){
      this.x += this.speed;
    }else if(this.dir == LEFT){
      this.x -= this.speed;
    }
    
    this.isHit();
  };
  
  /**
   * 碰撞检测
   */
  this.isHit = function(){
    if(this.isDestroyed){
      return;
    }
    //临界检测
    if(this.x < map.offsetX){
      this.x = map.offsetX;
      this.hit = true;
    }else if(this.x > map.offsetX + map.mapWidth - this.size){
      this.x = map.offsetX + map.mapWidth - this.size;
      this.hit = true;
    }
    if(this.y < map.offsetY){
      this.y = map.offsetY;
      this.hit = true;
    }else if(this.y > map.offsetY + map.mapHeight - this.size){
      this.y = map.offsetY + map.mapHeight - this.size;
      this.hit = true;
    }
    //子弹是否碰撞了其他子弹
    if(!this.hit){
      if(bulletArray != null && bulletArray.length > 0){
        for(var i=0;i<bulletArray.length;i++){
          if(bulletArray[i] != this && this.owner.isAI != bulletArray[i].owner.isAI && bulletArray[i].hit == false && CheckIntersect(bulletArray[i],this,0)){
            this.hit = true;
            bulletArray[i].hit = true;
            break;
          }
        }
      }
    }
    
    if(!this.hit){
      //地图检测
      if(bulletMapCollision(this,map)){
        this.hit = true;
      }
      //是否击中坦克
      if(this.type == BULLET_TYPE_PLAYER){
        if(enemyArray != null || enemyArray.length > 0){
          for(var i=0;i<enemyArray.length;i++){
            var enemyObj = enemyArray[i];
            if(!enemyObj.isDestroyed && CheckIntersect(this,enemyObj,0)){
              CheckIntersect(this,enemyObj,0);
              if(enemyObj.lives > 1){
                enemyObj.lives --;
              }else{
                enemyObj.distroy();
              }
              this.hit = true;
              break;
            }
          }
        }
      }else if(this.type == BULLET_TYPE_ENEMY){
        if(player1.lives > 0 && CheckIntersect(this,player1,0)){
          if(!player1.isProtected && !player1.isDestroyed){
            player1.distroy();
          }
          this.hit = true;
        }else if(player2.lives > 0 && CheckIntersect(this,player2,0)){
          if(!player2.isProtected && !player2.isDestroyed){
            player2.distroy();
          }
          this.hit = true;
        }
      }
    }
    
    
    if(this.hit){
      this.distroy();
    }
  };
  
  /**
   * 销毁
   */
  this.distroy = function(){
    this.isDestroyed = true;
    crackArray.push(new CrackAnimation(CRACK_TYPE_BULLET,this.ctx,this));
    if(!this.owner.isAI){
      BULLET_DESTROY_AUDIO.play();
    }
  };
  
  
};

2.3 按钮操作


var CrackAnimation = function(type,context,crackObj){
  this.times = 0;
  this.ctx = context;
  this.frame = 0;
  this.x = 0;
  this.y = 0;
  this.posName = "";
  this.size = 0;
  this.isOver = false;
  this.tempDir = 1;
  this.owner = crackObj;
  
  if(type == CRACK_TYPE_TANK){
    this.posName = "tankBomb";
    this.size = 66;
    this.frame = 4;
  }else{
    this.posName = "bulletBomb";
    this.size = 32;
    this.frame = 3;
  }
  this.x = crackObj.x + (parseInt(crackObj.size - this.size)/2);
  this.y = crackObj.y + (parseInt(crackObj.size - this.size)/2);
  
  this.draw = function(){
    var gaptime = 3;
    var temp = parseInt(this.times/gaptime);
    this.ctx.drawImage(RESOURCE_IMAGE,POS[this.posName][0]+temp*this.size,POS[this.posName][1],this.size,this.size,this.x,this.y,this.size,this.size);
    this.times += this.tempDir;
    if(this.times > this.frame * gaptime - parseInt(gaptime/2)){
      this.tempDir = -1;
    }
    if(this.times <= 0){
      this.isOver = true;
    }
  };
};

不会还有人没 点赞 + 关注 + 收藏 吧!

目录
打赏
0
0
0
0
137
分享
相关文章
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
65 7
Java产科专科电子病历系统源码
产科专科电子病历系统,全结构化设计,实现产科专科电子病历与院内HIS、LIS、PACS信息系统、区域妇幼信息平台的三级互联互通,系统由门诊系统、住院系统、数据统计模块三部分组成,它管理了孕妇从怀孕开始到生产结束42天一系列医院保健服务信息。
39 4
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
96 2
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
110 13
Java线程池提交任务流程底层源码与源码解析
【11月更文挑战第30天】嘿,各位技术爱好者们,今天咱们来聊聊Java线程池提交任务的底层源码与源码解析。作为一个资深的Java开发者,我相信你一定对线程池并不陌生。线程池作为并发编程中的一大利器,其重要性不言而喻。今天,我将以对话的方式,带你一步步深入线程池的奥秘,从概述到功能点,再到背景和业务点,最后到底层原理和示例,让你对线程池有一个全新的认识。
60 12
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
Java智慧工地信息管理平台源码 智慧工地信息化解决方案SaaS源码 支持二次开发
智慧工地系统是依托物联网、互联网、AI、可视化建立的大数据管理平台,是一种全新的管理模式,能够实现劳务管理、安全施工、绿色施工的智能化和互联网化。围绕施工现场管理的人、机、料、法、环五大维度,以及施工过程管理的进度、质量、安全三大体系为基础应用,实现全面高效的工程管理需求,满足工地多角色、多视角的有效监管,实现工程建设管理的降本增效,为监管平台提供数据支撑。
55 3
Java云HIS医院管理系统源码 病案管理、医保业务、门诊、住院、电子病历编辑器
通过门诊的申请,或者直接住院登记,通过”护士工作站“分配患者,完成后,进入医生患者列表,医生对应开具”长期医嘱“和”临时医嘱“,并在电子病历中,记录病情。病人出院时,停止长期医嘱,开具出院医嘱。进入出院审核,审核医嘱与住院通过后,病人结清缴费,完成出院。
127 4
家政上门系统用户端、阿姨端源码,java家政管理平台源码
家政上门系统基于互联网技术,整合大数据分析、AI算法和现代通信技术,提供便捷高效的家政服务。涵盖保洁、月嫂、烹饪等多元化服务,支持多终端访问,具备智能匹配、在线支付、订单管理等功能,确保服务透明、安全,适用于家庭生活的各种需求场景,推动家政市场规范化发展。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等