在上篇中,如果运行了fireplace的tests/full_game.py,这个程序将一个游戏过程在终端上运行完成,可以看到整个过程,那么第一步要做的就是将这个过程显示到cocos2d创建的场景中去。

创建一个游戏菜单场景。在testcocos.py中添加菜单,以及对应的方法。这个将是我们程序的入口。将后面需要用到的view,都放到gameview.py中。

class MainMenu(Menu):
def __init__(self):
super(MainMenu, self).__init__("HearthStone")
self.font_title['font_size'] = 72
self.font_title['color'] = (204,164,164,255)
self.font_item['color'] = (255,255,255,255)
self.font_item['font_size'] = 32
self.font_item_selected['color'] = (255,255,255,255)
self.font_item_selected['font_size'] = 46 self.menu_anchor_y = CENTER
self.menu_anchor_x = CENTER
items = []
items.append(MenuItem('StartGame',self.newGame))
items.append(MenuItem('Quit',self.on_quit))
self.create_menu( items, shake(), shake_back())
def newGame(self):
import gameview
director.push(FlipAngular3DTransition(
gameview.get_newgame(), 1.5))
def on_quit(self):
pyglet.app.exit()

入口:

if __name__ == "__main__":
pyglet.resource.path.append('data')
pyglet.resource.reindex() director.init(width = 800, height=600)
#scene
scene = Scene()
scene.add(MultiplexLayer(MainMenu(),),z=1) director.run(scene)

在看看gameview.py, 有一个get_newgame()方法:

def get_newgame():
scene = Scene()
scene.add(BackgroundLayer(), z=0, name = "background")
field1 = Field()
field1.position = 50,190
scene.add(field1, z=1, name="field1")
field2 = Field()
field2.position = 50,310
scene.add(field2, z=1, name="field2") hand1 = Hand()
hand1.position = 50,85
scene.add(hand1, z=1, name="hand1")
hand2 = Hand()
hand2.position = 50,415
scene.add(hand2, z=1, name="hand2") #model
model = GameModel()
#controller
ctrl = GameCtrl(model)
model.set_control(ctrl)
model.set_field(field1, field2)
model.set_hand(hand1, hand2)
scene.add(ctrl, z=1, name = "controller") return scene

这个方法创建了这个游戏很多的相关的东西。比如手牌hand,场地field, 模型model, 控制器ctrl

控制器是写在了gamectrl.py中,

class GameCtrl(Layer):
is_event_handler = True
def __init__(self, model):
super(GameCtrl, self).__init__()
self.model = model
#prepare game
self.deck1 = random_draft(hero=MAGE)
self.deck2 = random_draft(hero=WARRIOR)
player1 = Player(name="Player1")
player1.prepare_deck(self.deck1, MAGE)
player2 = Player(name="Player2")
player2.prepare_deck(self.deck2, WARRIOR) self.game = Game(players=(player1, player2))
self.players = self.game.players
self.player1 = self.players[0]
self.field1 = self.player1.field
self.hand1 = self.player1.hand
self.player2 = self.players[1]
self.field2 = self.player2.field
self.hand2 = self.player2.hand
self.game.start()
#draw hero
hero1 = self.game.players[0].hero
cocosHero1 = CocosCard(hero1)
cocosHero1.position = 350,-50
self.add(cocosHero1, z =1) hero2 = self.game.players[1].hero
cocosHero2 = CocosCard(hero2)
cocosHero2.position = 350,450
self.add(cocosHero2, z =1) for player in self.game.players:
print("Can mulligan %r" % (player.choice.cards))
mull_count = random.randint(0, len(player.choice.cards))
cards_to_mulligan = random.sample(player.choice.cards, mull_count)
player.choice.choose(*cards_to_mulligan)
#draw cards in hand
for player in self.game.players:
print ("%r" % player)
for card in player.hand:
print("%r" % card) self.elapsed = 0
self.schedule(self.step)
self.elapsed2 = 0
self.schedule(self.drawHandsAndFields)
def step(self, dt):
#print("step %r" % dt)
self.elapsed += dt
#control step time
if self.elapsed > 1:
self.elapsed = 0
try:
self.nextStep()
except GameOver:
print ("GAME OVER")
self.unschedule(self.step)
def nextStep(self):
player = self.game.current_player
heropower = player.hero.power
if heropower.is_usable() and percent_chance(10):
if heropower.has_target():
heropower.use(target=random.choice(heropower.targets))
else:
heropower.use()
# iterate over our hand and play whatever is playable
for card in player.hand:
if card.is_playable() and percent_chance(50):
target = None
if card.choose_cards:
card = random.choice(card.choose_cards)
if card.has_target():
target = random.choice(card.targets)
print("Playing %r on %r" % (card, target))
card.play(target=target) # Randomly attack with whatever can attack
for character in player.characters:
if character.can_attack():
character.attack(random.choice(character.targets)) if player.choice:
choice = random.choice(player.choice.cards)
print("Choosing card %r" % (choice))
player.choice.choose(choice)
self.game.end_turn() def drawHandsAndFields(self, dt):
self.elapsed2 += dt
if self.elapsed2 > 1:
self.model.draw_field()
self.model.draw_hand()
self.elapsed2 = 0

负责控制整个游戏过程。本身继承了Layer, 然后利用schedule()方法来实现调用绘制的逻辑。

但是绘制的具体实现是在gamemodel.py中。其中包含了两个类, 一个是GameModel,这个实现了绘制卡牌。但是卡牌本身有事放在了CocosCard这个类中。

具体代码见https://github.com/htwenning/mystone

这就是运行的效果。

为了好看点,我给每张卡牌添加了一个背景。

[模拟炉石](一)让游戏过程显示到cocos2d中的更多相关文章

  1. C# WinForm 异步执行耗时操作并将过程显示在界面中

    private void button3_Click(object sender, EventArgs e)        {            RunAsync(() =>         ...

  2. Python之模拟职场人生游戏

    题目:模拟人生 要求:1.至少有两个角色 2.玩的过程中,有冲突 3.根据不同的交互,产生不同的行为. 4.一定要用到面向对象语法和思想 1.解题思路 创建一个类,赋予角色不同的方法,使用面向对象思想 ...

  3. 【转载】【游戏开发】在Lua中实现面向对象特性——模拟类、继承、多态

    [游戏开发]在Lua中实现面向对象特性——模拟类.继承.多态   阅读目录 一.简介 二.前提知识 三.Lua中实现类.继承.多态 四.总结 回到顶部 一.简介 Lua是一门非常强大.非常灵活的脚本语 ...

  4. Socket编程之聊天程序 - 模拟Fins/ModBus协议通信过程

    设备控制软件编程涉及到的基本通信方式主要有TCP/IP与串口,用到的数据通信协议有Fins与ModBus. 更高级别的通信如.net中的Remoting与WCF在进行C/S架构软件开发时会采用. 本篇 ...

  5. spring-mvc实现模拟数据到网页展示过程代码

    spring-mvc实现模拟数据到网页展示过程代码 先看看我们的3种模拟数据到网页展示的思路图: 1.当mybatis的环境配置完成.一个动态Web项目建立好.开始导入jar包. -spring的ao ...

  6. 常用Java API之Ramdom--用代码模拟猜数小游戏

    常用Java API之Ramdom Ramdom类用来生成随机数字.使用起来也是三个步骤: 1.导包 import java.util.Random; 2.创建 Random r = new Rand ...

  7. Spring学习笔记(七)模拟实际开发过程的调用过程XML版-Setter方式注入

    模拟实际开发过程的调用过程XML版-Setter方式注入 源码获取github [TOC] 1.项目结构 2.jar包跟上个一样 3.重写set方法 UserServiceImpl.java 1234 ...

  8. Unity 如何在窗口大小可以随意改变的情况下让游戏世界完整的显示在镜头中

    当我们开发游戏时,如果是开发手机游戏,屏幕窗口的比例是固定的,不会说在运行时改变的. 但是,PC端的游戏就不一定,我希望它能被用户随意拉扯,但完整的内容还是能显示出来,这里我直接放例子: 请注意黑色的 ...

  9. Java/C++实现装饰模式---模拟手机功能的升级过程

    用装饰模式模拟手机功能的升级过程:简单的手机(SimplePhone)在接收来电时,会发出声音提醒主人:而JarPhone除了声音还能振动:更高级的手机(ComplexPhone)除了声音.振动外,还 ...

随机推荐

  1. 一个图片上传的servlet,传到本地磁盘,要传到服务器请修改

    本来想写个controller,结果拦截器把图片拦住了,那就直接servlet public class UploadEamge extends HttpServlet{ /** * */ priva ...

  2. iOS知识点全梳理-备用

    感谢大神分享 文/Jack_lin(简书作者)原文链接:http://www.jianshu.com/p/5d2163640e26著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 序言 ...

  3. CentOS下安装JDK6u21和设置环境变量bin文件

    1.先通过SSH登录到Linux系统中,通过SSH文件管理工具把Linux的JDK安装包上传到/home/acm/JavaTools/JDK目录: 2.进入/home/acm/JavaTools/JD ...

  4. form 和 ngModel

    参考 https://docs.angularjs.org/api/ng/type/ngModel.NgModelController https://docs.angularjs.org/api/n ...

  5. DOCKER,需要进入生产实践

    先玩起... 以下初级问题的解决: docker -dINFO[0000] +job serveapi(unix:///var/run/docker.sock) INFO[0000] WARNING: ...

  6. haskell学习笔记_函数

    一开始学习函数式编程语言就被告知函数式编程语言是一种“定义式”的语言,而不是一种命令式的语言,在学习haskell的函数语法时,此感觉更加强烈,haskell的函数定义倾向于一种类似C++里面的swi ...

  7. 用友U8.70安装说明

    用友U8.70安装说明 U8.70安装说明一.安装前注意事项:1.       在安装U870之前,我们推荐您确保当前计算机操作系统是“干净”的,即计算机在安装过操作系统和更新过必要的系统补丁后没有安 ...

  8. js如何判断字符串是否进行过window.btoa()转码

    window.btoa()是基于Base64算法的.window.btoa()只能将ASCII字符进行转码 因此我们需要了解Base64的原理及主要特征:Base64的原理在这里就不多说了,网上很多讲 ...

  9. Annotation(四)——Struts2注解开发

    Hibernate和Spring框架的开发前边总结了,这次看一下流行的MVC流程框架Struts2的注解开发吧.Struts2主要解决了从JSP到Action上的流程管理,如何进行Uri和action ...

  10. zoj 3706 Break Standard Weight(dp)

    Break Standard Weight Time Limit: 2 Seconds                                     Memory Limit: 65536 ...