diff options
author | flavio <fdanesse@gmail.com> | 2012-04-04 00:41:10 (GMT) |
---|---|---|
committer | flavio <fdanesse@gmail.com> | 2012-04-04 00:41:10 (GMT) |
commit | c6fbb6b5b652f63bdd4e163aa2e1cda5b488748b (patch) | |
tree | c2e03ca8f7fb2fb0494456786fbecd90d65883f4 /FGR_T0201.py | |
parent | a1096db00fa9a775551622cce8df04062af1f5e0 (diff) |
Login
Diffstat (limited to 'FGR_T0201.py')
-rw-r--r-- | FGR_T0201.py | 120 |
1 files changed, 52 insertions, 68 deletions
diff --git a/FGR_T0201.py b/FGR_T0201.py index 63f49e1..8c7bd18 100644 --- a/FGR_T0201.py +++ b/FGR_T0201.py @@ -6,61 +6,63 @@ # https://sites.google.com/site/sugaractivities/ # http://codigosdeejemplo.blogspot.com/ -import pygame, gc, sys, random, gtk, pygtk +import pygame +import gc +import gobject +import sys +import random +import gtk from pygame.locals import * - import Globals as G gc.enable() - import BiblioJAM from BiblioJAM.JAMButton import JAMButton from BiblioJAM.JAMLabel import JAMLabel import BiblioJAM.JAMGlobals as JAMG -class FGR_T0201(): - def __init__(self, main): - # Variables para JAMatrix - self.ventana= None - self.name= "Caminando a la Escuela" - self.estado= False - - self.main= main - self.ventana= self.main.ventana - +class FGR_T0201(gtk.Widget): + __gsignals__ = {"run_grupo":(gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE, (gobject.TYPE_STRING,gobject.TYPE_INT))} + def __init__(self): + gtk.Widget.__init__(self) + self.ventana = None + self.nombre = "Caminando a la Escuela" + self.estado = False # Variables del Juego - self.fondo= None - self.reloj= None - self.puntos= 0 + self.fondo = None + self.reloj = None + self.puntos = 0 # Sprites - self.textos= None - self.botonesmenu= None - self.controles= None - self.seniales= None - self.carteles= None - self.senial_select= None + self.textos = None + self.botonesmenu = None + self.controles = None + self.seniales = None + self.carteles = None + self.senial_select = None # sonidos - self.sonido_error= None - self.sonido_exito= None - self.sound_select= None + self.sonido_error = None + self.sonido_exito = None + self.sound_select = None # Escalado self.ventana_real= None self.resolucionreal= None self.VA= None self.VH= None + self.load() + self.estado = "Intro" def run(self): - self.preset() - - from BiblioJAM.JAMatrix import JAMatrix - matrix= JAMatrix(self, self.ventana_real, self.resolucionreal) - matrix.set_imagen_matrix(None) - matrix.carga_game() - - self.estado= "Intro" - self.switch() + if self.estado == "Intro": + self.controles.stop() + self.fondo = self.fondo1 + return self.run_menu() + elif self.estado == "Game": + self.puntos = 0 + self.fondo = self.fondo2 + self.reset() + return self.run_juego() def run_menu(self): self.ventana.blit(self.fondo, (0,0)) @@ -112,18 +114,6 @@ class FGR_T0201(): #self.victory() #self.game_over(None) - def switch(self): - if self.estado== "Intro": - self.controles.stop() - self.fondo = self.fondo1 - self.set_event_intro() - return self.run_menu() - elif self.estado== "Game": - self.puntos= 0 - self.fondo = self.fondo2 - self.reset() - return self.run_juego() - def reset(self): self.puntos= 0 self.carteles.init() @@ -139,7 +129,7 @@ class FGR_T0201(): def deja_en(self, cartel): if self.senial_select: - if self.senial_select.name == cartel.name: + if self.senial_select.nombre == cartel.nombre: self.sonido_exito.play() self.senial_select.ubicada= True self.controles.recuadro_select.remove(self.controles) @@ -239,7 +229,10 @@ class FGR_T0201(): return self.salir(False) # ----------- SETEOS ------------- - def preset(self): + def load(self): + pygame.event.set_blocked([JOYAXISMOTION, JOYBALLMOTION, JOYHATMOTION, JOYBUTTONUP, JOYBUTTONDOWN, KEYUP, USEREVENT]) + pygame.event.set_allowed([MOUSEMOTION, MOUSEBUTTONUP, MOUSEBUTTONDOWN, KEYDOWN, VIDEORESIZE, VIDEOEXPOSE, QUIT, ACTIVEEVENT]) + pygame.mouse.set_visible(True) A, B= G.RESOLUCION self.ventana = pygame.Surface( (A, B), flags=HWSURFACE ) self.ventana_real= pygame.display.get_surface() @@ -248,8 +241,6 @@ class FGR_T0201(): self.resolucionreal= (C,D) self.VA= float(C)/float(A) self.VH= float(D)/float(B) - - def load(self): self.fondo1, self.fondo2= G.get_Fondos_FGR_T0201() self.textos= Textos_Intro() self.botonesmenu= ButtonsMenu(self) @@ -259,12 +250,6 @@ class FGR_T0201(): self.sonido_error, self.sonido_exito= G.get_Sonidos() self.sound_select= JAMG.get_sound_select() self.reloj = pygame.time.Clock() - self.estado= True - - def set_event_intro(self): - pygame.event.set_blocked([JOYAXISMOTION, JOYBALLMOTION, JOYHATMOTION, JOYBUTTONUP, JOYBUTTONDOWN, KEYUP, USEREVENT]) - pygame.event.set_allowed([MOUSEMOTION, MOUSEBUTTONUP, MOUSEBUTTONDOWN, KEYDOWN, VIDEORESIZE, VIDEOEXPOSE, QUIT, ACTIVEEVENT]) - pygame.mouse.set_visible(True) # ----------- EVENTOS en MENU --------------- def handle_event_Intro(self): @@ -367,7 +352,7 @@ class FGR_T0201(): dialog.clear(self.ventana, self.fondo) self.ventana_real.blit(pygame.transform.scale(self.ventana, self.resolucionreal), (0,0)) pygame.display.update() - return self.switch() + return self.run() else: dialog.clear(self.ventana, self.fondo) self.ventana_real.blit(pygame.transform.scale(self.ventana, self.resolucionreal), (0,0)) @@ -381,12 +366,15 @@ class FGR_T0201(): # ----------- EVENTOS en JUEGO --------------- def salir(self, valor= None): + ''' if valor: self.estado= True if not valor: self.estado= False pygame.mixer.music.unpause() self.seniales.empty() self.carteles.empty() - self.controles.empty() + self.controles.empty()''' + self.estado = False + self.emit("run_grupo", "grupo2", self.puntos) # -------- CONTROLES ---------- class Controles(pygame.sprite.OrderedUpdates): @@ -462,7 +450,7 @@ class Controles(pygame.sprite.OrderedUpdates): cartel_titulo.rect.y= -60 self.add(cartel_titulo) - self.titulo= JAMLabel(self.main.name) + self.titulo= JAMLabel(self.main.nombre) self.titulo.set_text(color=JAMG.get_blanco()) fuente, tamanio= JAMG.get_Font_fawn() self.titulo.set_font_from_file(fuente, tamanio= 40) @@ -503,7 +491,7 @@ class Controles(pygame.sprite.OrderedUpdates): def switching_game(self, button): self.main.estado= "Intro" - return self.main.switch() + return self.main.run() def init(self): sound= self.sonidos_reloj[0] @@ -639,7 +627,7 @@ class Sprite_Palabras(JAMButton): JAMButton.__init__(self, texto, None) self.main= main self.ubicada= False - self.name= self.get_text() + self.nombre= self.get_text() def update(self): if self == self.main.senial_select or self.ubicada: return @@ -715,10 +703,10 @@ class Sprites_Labels_Cartesles(JAMLabel): class Sprite_Carteles(JAMButton): ''' El cartel.''' - def __init__(self, main, name): + def __init__(self, main, nombre): JAMButton.__init__(self, ".................", None) self.main= main - self.name= name + self.nombre= nombre self.set_colores(colorbas= JAMG.get_negro(), colorbor= JAMG.get_blanco(), colorcara= JAMG.get_negro()) self.set_text(color= JAMG.get_blanco()) self.set_font_from_file(JAMG.get_Font_fawn()[0], tamanio= 25) @@ -836,7 +824,7 @@ class ButtonsMenu(pygame.sprite.OrderedUpdates): def switching(self, button): self.main.estado= "Game" pygame.event.clear() - return self.main.switch() + return self.main.run() # --------- Botones en Menu (Salir y Jugar) ------------------ # --------- Mensaje Final --------- @@ -942,8 +930,4 @@ class Mensaje(pygame.sprite.OrderedUpdates): self.label2.rect.x= self.x_final_label2 self.label1.rect.x= self.x_final_label1 self.estado= False -# --------- Mensaje Final --------- - -if __name__ == "__main__": - FGR_T0201() |