楼主也是初学quick,想写几个简单的小项目入门,想想最简单的还是“微信打飞机”了(之前学cocos2d-js的时候也是从这个项目开始入手的)。
这里只是写一个微信打飞机的Demo,所以,不需要有太多的功能。先简单的分析下:
大概分为四个部分来实现:
1.先新建项目实现一个飞机在屏幕中移动
自定义场景,
精灵的定义
屏幕点击事件
2.在游戏中添加敌人和子弹
数组,
计时器
3.添加碰撞检测
数组中元素的删除,
动画
分数的实现
4.游戏结算
界面的切换,
这里先实现第一部分:
写一个MainScene和一个GameScen,MainScene作为菜单界面,点击菜单界面进入GameScene(游戏主界面),这里需要用到精灵的创建,触屏事件的添加,界面的切换。
下面上代码:
MainScene:
- local MainScene = class("MainScene", function()
- return display.newScene("MainScene")
- end)
- function MainScene:ctor()
- --添加一个背景精灵
- self.bgSprite = display.newSprite("game_bg.jpg"):addTo(self)
- self.bgSprite:pos(display.cx,display.cy)
- --添加一个TouchLayer
- self.touchLayer = display.newColorLayer(cc.c4b(255,255,255,0)):addTo(self)
- self.touchLayer:setTouchEnabled(true)
- self.touchLayer:addNodeEventListener(cc.NODE_TOUCH_EVENT,function(event)
- if event.name == "ended" then
- --切换界面
- local nextScene = require("src.app.scenes.GameScene").new()
- display.replaceScene(nextScene, "fade", 0.5, cc.c3b(0, 0, 0))
- end
- return true
- end)
- end
- function MainScene:onEnter()
- end
- function MainScene:onExit()
- end
- return MainScene
-
- local GameScene = class("GameScene",function ()
- return display.newScene("GameScene")
- end)
- function GameScene:ctor()
- --添加Player精灵
- self.player = display.newSprite("hero_1.png"):addTo(self)
- self.player:pos(display.cx,display.cy)
- self.player:setLocalZOrder(10)
- self.touchPos = cc.p(0,0)
- --添加一个TouchLayer接收点击事件
- self.touchLayer = display.newColorLayer(cc.c4b(255,0,0,255)):addTo(self)
- self.touchLayer:setTouchEnabled(true)
- self.touchLayer:addNodeEventListener(cc.NODE_TOUCH_EVENT,function(event)
- print(event.name)
- if event.name == "began" then
- self.touchPos = cc.p(event.x,event.y)
- elseif event.name == "moved" then
- local x = event.x - self.touchPos.x ;
- local y = event.y - self.touchPos.y ;
- self.touchPos = cc.p(event.x,event.y) ;
- self:onTouch(x,y) ;
- else
- self.touchPos = cc.p(0,0)
- end
- return true
- end)
- end
- function GameScene:onTouch(x,y)
- --更新飞机的位置,没有对飞机是否会触屏做限制
- self.player:pos(self.player:getPositionX() + x,self.player:getPositionY() + y)
- end
- function GameScene:onEnter()
- end
- function GameScene:onExit()
- end
- return GameScene