加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

做一个像植物大战僵尸的Flash游戏1

发布时间:2020-12-15 06:48:11 所属栏目:百科 来源:网络整理
导读:?http://bbs.9ria.com/thread-80527-1-6.html 这个教程是我翻译的。。不是我原创的。。原来是发表在新闻资讯版块,后来被移到了游戏编程版块,所以关于原作者的一些信息等都没了。。。 查看该系列的其它文章: 做一个像植物大战僵尸的Flash游戏 做一个像植物

?http://bbs.9ria.com/thread-80527-1-6.html

这个教程是我翻译的。。不是我原创的。。原来是发表在新闻资讯版块,后来被移到了游戏编程版块,所以关于原作者的一些信息等都没了。。。

查看该系列的其它文章:
做一个像植物大战僵尸的Flash游戏
做一个像植物大战僵尸的Flash游戏2
做一个像植物大战僵尸的Flash游戏3
做一个像植物大战僵尸的Flash游戏4
做一个像植物大战僵尸的Flash游戏5



我不得不承认,我不是植物大战僵尸的骨灰玩家,所以,如果你发现这个系列的教程有什么地方错误的,请告诉我。

定义游戏的主要结构

植物大战僵给了我们很好的视觉和感觉上的享受。你得保护你的房子以免被吃脑的僵尸入侵,这相当的吸引人。总的来说,杀死僵尸是很有趣的。但是这视觉上的东西和游戏玩法无关,我们可以用屠夫大战管子工,鸽子大战骆驼,圆形大战方块来代替。

在这个系列的教程中,我们用圆形来代替植物,用方块来代替僵尸,伟大的圆形将会阻止邪恶的方块进入我们的基地。游戏区域可以被简化为一个区块游戏。

设想一下这种局面:



然后尽量把它想象成这样:



我们所拥有的是一个位于(2,2)的植物,它会尽力阻止走在第二行(从第0行开始,下同)的僵尸,并且另一个僵尸正在沿着第三行接近我们的基地,还有一个正从第四列落下的阳光。不可能有另外一个植物位于(2,2),并且不可能出现一个僵尸走在第二行与第三行之间。

创建游戏区域

正如你在上图看到的那样,这个游戏的区域是一个5行9列的矩阵。因此,第一件要做的事就是定义一个数组。我设想你的fla文件有一个文档类为Main。下面是Main.as的内容:

  1. package {
  2. ? ? ? ? import flash.display.Sprite;
  3. ? ? ? ? public class Main extends Sprite {
  4. ? ? ? ? ? ? ? ? private var gameField:Array;
  5. ? ? ? ? ? ? ? ? public function Main():void {
  6. ? ? ? ? ? ? ? ? ? ? ? ? setupField();
  7. ? ? ? ? ? ? ? ? }
  8. ? ? ? ? ? ? ? ? private function setupField():void {
  9. ? ? ? ? ? ? ? ? ? ? ? ? gameField=new Array();
  10. ? ? ? ? ? ? ? ? ? ? ? ? for (var i:uint=0; i<5; i++) {
  11. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i]=new Array();
  12. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? for (var j:uint=0; j<9; j++) {
  13. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i][j]=0;
  14. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
  15. ? ? ? ? ? ? ? ? ? ? ? ? }
  16. ? ? ? ? ? ? ? ? }
  17. ? ? ? ? }
  18. }
复制代码
这样,gameField数组就是一个5*9的矩阵了。

画出游戏区域

下面的代码对于测试来说足够了,至少我们会画出一个游戏区域来。
  1. package {
  2. ? ? ? ? import flash.display.Sprite;
  3. ? ? ? ? public class Main extends Sprite {
  4. ? ? ? ? ? ? ? ? private var gameField:Array;
  5. ? ? ? ? ? ? ? ? public function Main():void {
  6. ? ? ? ? ? ? ? ? ? ? ? ? setupField();
  7. ? ? ? ? ? ? ? ? ? ? ? ? drawField();
  8. ? ? ? ? ? ? ? ? }
  9. ? ? ? ? ? ? ? ? private function setupField():void {
  10. ? ? ? ? ? ? ? ? ? ? ? ? gameField=new Array();
  11. ? ? ? ? ? ? ? ? ? ? ? ? for (var i:uint=0; i<5; i++) {
  12. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i]=new Array();
  13. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? for (var j:uint=0; j<9; j++) {
  14. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i][j]=0;
  15. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
  16. ? ? ? ? ? ? ? ? ? ? ? ? }
  17. ? ? ? ? ? ? ? ? }
  18. ? ? ? ? ? ? ? ? private function drawField():void {
  19. ? ? ? ? ? ? ? ? ? ? ? ? var fieldSprite:Sprite=new Sprite();
  20. ? ? ? ? ? ? ? ? ? ? ? ? var randomGreen:Number;
  21. ? ? ? ? ? ? ? ? ? ? ? ? addChild(fieldSprite);
  22. ? ? ? ? ? ? ? ? ? ? ? ? fieldSprite.graphics.lineStyle(1,0xFFFFFF);
  23. ? ? ? ? ? ? ? ? ? ? ? ? for (var i:uint=0; i<5; i++) {
  24. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? for (var j:uint=0; j<9; j++) {
  25. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? randomGreen=(125+Math.floor(Math.random()*50))*256;
  26. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? fieldSprite.graphics.beginFill(randomGreen);
  27. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? fieldSprite.graphics.drawRect(25+65*j,80+75*i,65,75);
  28. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
  29. ? ? ? ? ? ? ? ? ? ? ? ? }
  30. ? ? ? ? ? ? ? ? }
  31. ? ? ? ? }
  32. }
复制代码
drawField函数所做的事情都能够在setupField函数里实现,但是我想让他们分离,我得让一个函数只处理一件事。唯一有趣的一行代码是第25行的是在#007D00和#00AE00之间生成随机颜色。

这就是我们的游戏区域了。如果你想要让区块体面点。请。。。自便。

捕获阳光

阳光是植物大战僵尸里的货币。他们从天上掉下来,落到某一区块上。捡起这些阳光,你才能购买植物。

我用到了timer事件使得每五秒落下一束阳光,如果你对timer还不熟悉的话,请搜索。

现在,阳光还不会从天上掉下来,而是直接出现在某一随机的区块中。此时此刻,我还不知道是否两束阳光可以同时落到同一区块中。在这个例子里,他们是可以的,但是如果原版的植物大战僵尸里不允许这样的话,请告诉我。

当一束阳光落到地上的时候,它能够被玩家捡起。一个鼠标事件侦听器处理这整个任务。下面是代码:
  1. package {
  2. ? ? ? ? import flash.display.Sprite;
  3. ? ? ? ? import flash.utils.Timer;
  4. ? ? ? ? import flash.events.TimerEvent;
  5. ? ? ? ? import flash.events.MouseEvent;
  6. ? ? ? ? public class Main extends Sprite {
  7. ? ? ? ? ? ? ? ? private var gameField:Array;
  8. ? ? ? ? ? ? ? ? private var flowersTimer:Timer=new Timer(5000);
  9. ? ? ? ? ? ? ? ? private var sun:sunMc;
  10. ? ? ? ? ? ? ? ? private var sunContainer:Sprite=new Sprite();
  11. ? ? ? ? ? ? ? ? public function Main():void {
  12. ? ? ? ? ? ? ? ? ? ? ? ? setupField();
  13. ? ? ? ? ? ? ? ? ? ? ? ? drawField();
  14. ? ? ? ? ? ? ? ? ? ? ? ? fallingSuns();
  15. ? ? ? ? ? ? ? ? }
  16. ? ? ? ? ? ? ? ? private function fallingSuns():void {
  17. ? ? ? ? ? ? ? ? ? ? ? ? addChild(sunContainer);
  18. ? ? ? ? ? ? ? ? ? ? ? ? flowersTimer.start();
  19. ? ? ? ? ? ? ? ? ? ? ? ? flowersTimer.addEventListener(TimerEvent.TIMER,newSun);
  20. ? ? ? ? ? ? ? ? }
  21. ? ? ? ? ? ? ? ? private function newSun(e:TimerEvent):void {
  22. ? ? ? ? ? ? ? ? ? ? ? ? var sunRow:uint=Math.floor(Math.random()*5);
  23. ? ? ? ? ? ? ? ? ? ? ? ? var sunCol:uint=Math.floor(Math.random()*9);
  24. ? ? ? ? ? ? ? ? ? ? ? ? sun = new sunMc();
  25. ? ? ? ? ? ? ? ? ? ? ? ? sunContainer.addChild(sun);
  26. ? ? ? ? ? ? ? ? ? ? ? ? sun.x=52+sunRow*65;
  27. ? ? ? ? ? ? ? ? ? ? ? ? sun.y=130+sunRow*75;
  28. ? ? ? ? ? ? ? ? ? ? ? ? sun.addEventListener(MouseEvent.CLICK,sunClicked);
  29. ? ? ? ? ? ? ? ? }
  30. ? ? ? ? ? ? ? ? private function sunClicked(e:MouseEvent):void {
  31. ? ? ? ? ? ? ? ? ? ? ? ? e.currentTarget.removeEventListener(MouseEvent.CLICK,sunClicked);
  32. ? ? ? ? ? ? ? ? ? ? ? ? var sunToRemove:sunMc=e.currentTarget as sunMc;
  33. ? ? ? ? ? ? ? ? ? ? ? ? sunContainer.removeChild(sunToRemove);
  34. ? ? ? ? ? ? ? ? }
  35. ? ? ? ? ? ? ? ? private function setupField():void {
  36. ? ? ? ? ? ? ? ? ? ? ? ? gameField=new Array();
  37. ? ? ? ? ? ? ? ? ? ? ? ? for (var i:uint=0; i<5; i++) {
  38. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i]=new Array();
  39. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? for (var j:uint=0; j<9; j++) {
  40. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? gameField[i][j]=0;
  41. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
  42. ? ? ? ? ? ? ? ? ? ? ? ? }
  43. ? ? ? ? ? ? ? ? }
  44. ? ? ? ? ? ? ? ? private function drawField():void {
  45. ? ? ? ? ? ? ? ? ? ? ? ? var fieldSprite:Sprite=new Sprite();
  46. ? ? ? ? ? ? ? ? ? ? ? ? var randomGreen:Number;
  47. ? ? ? ? ? ? ? ? ? ? ? ? addChild(fieldSprite);
  48. ? ? ? ? ? ? ? ? ? ? ? ? fieldSprite.graphics.lineStyle(1,75);
  49. ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
  50. ? ? ? ? ? ? ? ? ? ? ? ? }
  51. ? ? ? ? ? ? ? ? }
  52. ? ? ? ? }
  53. }
复制代码
下面简要概述一下用到的函数:
drawField:画出游戏区域
fallingSuns:开始制造阳光,使他们坠落
newSun:创建新的阳光
setupField:生成区块数组
sunClicked:当玩家点击阳光时调用
下面是效果:

用鼠标捡起阳光吧。
下载该例子的源代码。下一次,我们将会加入使阳光平滑落下的动画,并且我们将会买到我们的第一个植物。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读