- Adapatation de la taille de la texture à l'écran/fenêtre lors de la diffusion de video sur l'objet player.
- Rajout de la possibilité de changer la transparence en donnant un quatrième argument optionnel à la fonction drawsquare et drawsemisquare. - Ajout d'une fonction drawtriangles qui dessine des triangles aux quatres coins de éléments activables et suppression du cadre autour des éléments non activables. - Corrige un bug dans la fonction drawworld, on doit vérifier que la liste des mondes a activer en cas de victoire ne soit pas nulle. - Ajout d'une fonction unactive et modification de la fonction erase afin de désactiver totalement les éléments lors que l'on stope la simulation. - BUG: Les senseurs K,L,M et N doivent etre sensibles aux superelectron negatifs et pas positifs. - Demarrage de l'application par défaut en plein écran. - Remise a zero de la variable stat et donc de la répartition des particules sur le jeu lors de l'appel de reallystop (stop du jeu). - Changement du fonctionnemment de gameover et itsvictory afin de figer le jeu lorsque qu'on gagne ou l'on perd une partie. Après une action sur les commandes, on procéde à l'arrêt effectif avec la commande reallystop. - Ajout du démarrage de la video d'intro par le player au lancement du jeu.
This commit is contained in:
parent
a43a457589
commit
0568a288a0
67
WireChem.py
67
WireChem.py
|
@ -216,7 +216,7 @@ def refresh(dt):
|
||||||
global world,level
|
global world,level
|
||||||
if player.source and player.source.video_format:
|
if player.source and player.source.video_format:
|
||||||
glColor3ub(255,255,255)
|
glColor3ub(255,255,255)
|
||||||
player.get_texture().blit(0,0)
|
player.get_texture().blit(0,0,width=win.width,height=win.height)
|
||||||
return
|
return
|
||||||
if level!=-1:
|
if level!=-1:
|
||||||
drawgrid(zoom)
|
drawgrid(zoom)
|
||||||
|
@ -227,6 +227,9 @@ def refresh(dt):
|
||||||
''' Affichage '''
|
''' Affichage '''
|
||||||
|
|
||||||
def drawsquare(x,y,x2,y2,full,color):
|
def drawsquare(x,y,x2,y2,full,color):
|
||||||
|
if len(color)==4:
|
||||||
|
glColor4ub(color[0],color[1],color[2],color[3])
|
||||||
|
else:
|
||||||
glColor3ub(color[0],color[1],color[2])
|
glColor3ub(color[0],color[1],color[2])
|
||||||
if full>0:
|
if full>0:
|
||||||
glBegin(GL_QUADS)
|
glBegin(GL_QUADS)
|
||||||
|
@ -239,6 +242,9 @@ def drawsquare(x,y,x2,y2,full,color):
|
||||||
glEnd()
|
glEnd()
|
||||||
|
|
||||||
def drawsemisquare(x,y,x2,y2,color):
|
def drawsemisquare(x,y,x2,y2,color):
|
||||||
|
if len(color)==4:
|
||||||
|
glColor4ub(color[0],color[1],color[2],color[3])
|
||||||
|
else:
|
||||||
glColor3ub(color[0],color[1],color[2])
|
glColor3ub(color[0],color[1],color[2])
|
||||||
glBegin(GL_LINES)
|
glBegin(GL_LINES)
|
||||||
thezoom=y2-y
|
thezoom=y2-y
|
||||||
|
@ -260,16 +266,38 @@ def drawsemisquare(x,y,x2,y2,color):
|
||||||
glVertex2i(x2-thezoom/4,y)
|
glVertex2i(x2-thezoom/4,y)
|
||||||
glEnd()
|
glEnd()
|
||||||
|
|
||||||
|
def drawtriangles(x,y,x2,y2,color):
|
||||||
|
if len(color)==4:
|
||||||
|
glColor4ub(color[0],color[1],color[2],color[3])
|
||||||
|
else:
|
||||||
|
glColor3ub(color[0],color[1],color[2])
|
||||||
|
glBegin(GL_TRIANGLES)
|
||||||
|
thezoom=y2-y
|
||||||
|
glVertex2i(x,y)
|
||||||
|
glVertex2i(x,y+thezoom/4)
|
||||||
|
glVertex2i(x+thezoom/4,y)
|
||||||
|
glVertex2i(x2,y2)
|
||||||
|
glVertex2i(x2,y2-thezoom/4)
|
||||||
|
glVertex2i(x2-thezoom/4,y2)
|
||||||
|
glVertex2i(x,y2)
|
||||||
|
glVertex2i(x,y2-thezoom/4)
|
||||||
|
glVertex2i(x+thezoom/4,y2)
|
||||||
|
glVertex2i(x2,y)
|
||||||
|
glVertex2i(x2,y+thezoom/4)
|
||||||
|
glVertex2i(x2-thezoom/4,y)
|
||||||
|
glEnd()
|
||||||
|
|
||||||
|
|
||||||
def drawitdem(x,y,art,thezoom,activation):
|
def drawitdem(x,y,art,thezoom,activation):
|
||||||
if 'text' in art:
|
if 'text' in art:
|
||||||
if art['activable']==0:
|
if art['activable']==0:
|
||||||
drawsquare(x+1,y+1,x+thezoom-1,y+thezoom-1,0,[255,255,255])
|
|
||||||
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(art['color'][0],art['color'][1],art['color'][2],255))
|
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(art['color'][0],art['color'][1],art['color'][2],255))
|
||||||
else:
|
else:
|
||||||
drawsemisquare(x+1,y+1,x+thezoom-1,y+thezoom-1,[255,255,255])
|
|
||||||
if activation!=0:
|
if activation!=0:
|
||||||
|
drawtriangles(x+1,y+1,x+thezoom-1,y+thezoom-1,[art['color'][0],art['color'][1],art['color'][2],55+200*activation/10])
|
||||||
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(art['color'][0],art['color'][1],art['color'][2],55+200*activation/10))
|
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(art['color'][0],art['color'][1],art['color'][2],55+200*activation/10))
|
||||||
else:
|
else:
|
||||||
|
drawtriangles(x+1,y+1,x+thezoom-1,y+thezoom-1,[255,255,255])
|
||||||
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(255,255,255,255))
|
label=pyglet.text.Label(art['text'].decode('utf-8'),font_name='Liberation Mono',font_size=thezoom,x=x+thezoom/10,y=y+thezoom/10,color=(255,255,255,255))
|
||||||
label.draw()
|
label.draw()
|
||||||
|
|
||||||
|
@ -345,7 +373,7 @@ def drawworld():
|
||||||
if ele['world']==world:
|
if ele['world']==world:
|
||||||
glBegin(GL_LINES)
|
glBegin(GL_LINES)
|
||||||
for n in ele['validate']:
|
for n in ele['validate']:
|
||||||
if items[n]['world']==world:
|
if n!="" and items[n]['world']==world:
|
||||||
glVertex2i(ele['coordx']+50,ele['coordy']+50)
|
glVertex2i(ele['coordx']+50,ele['coordy']+50)
|
||||||
glVertex2i(items[n]['coordx']+50,items[n]['coordy']+50)
|
glVertex2i(items[n]['coordx']+50,items[n]['coordy']+50)
|
||||||
glVertex2i(ele['coordx']+51,ele['coordy']+50)
|
glVertex2i(ele['coordx']+51,ele['coordy']+50)
|
||||||
|
@ -413,7 +441,7 @@ def drawworld():
|
||||||
label.draw()
|
label.draw()
|
||||||
|
|
||||||
def drawgrid(zoom):
|
def drawgrid(zoom):
|
||||||
global temp,debug,over,allcout,play
|
global temp,debug,over,allcout,play,element
|
||||||
glClear(GL_COLOR_BUFFER_BIT)
|
glClear(GL_COLOR_BUFFER_BIT)
|
||||||
drawsquare(decx-1+zoom,decy-1+zoom,decx+zoom*(sizex-1)+1,decy+zoom*(sizey-1)+2,0,[255,255,255])
|
drawsquare(decx-1+zoom,decy-1+zoom,decx+zoom*(sizex-1)+1,decy+zoom*(sizey-1)+2,0,[255,255,255])
|
||||||
if play>0:
|
if play>0:
|
||||||
|
@ -443,7 +471,7 @@ def drawgrid(zoom):
|
||||||
drawsquare(7+i*size,55,8+i*size,55+size,0,[90,90,90])
|
drawsquare(7+i*size,55,8+i*size,55+size,0,[90,90,90])
|
||||||
cat=art['cat']
|
cat=art['cat']
|
||||||
drawsquare(615,win.height-45,655,win.height-5,1,[255,255,255])
|
drawsquare(615,win.height-45,655,win.height-5,1,[255,255,255])
|
||||||
label=pyglet.text.Label(element,font_size=20,x=636-len(element)*10,y=win.height-35,bold=False,italic=False,color=(0, 0, 0,255))
|
label=pyglet.text.Label(element,font_size=20,x=636-len(element)*10,y=win.height-35,font_name='Liberation Mono',bold=False,italic=False,color=(0, 0, 0,255))
|
||||||
label.draw()
|
label.draw()
|
||||||
if tech>3:
|
if tech>3:
|
||||||
for i in range(4):
|
for i in range(4):
|
||||||
|
@ -615,7 +643,7 @@ def zoomp(x,y,dummy1,dummy2):
|
||||||
''' Fonctions gestion du monde '''
|
''' Fonctions gestion du monde '''
|
||||||
|
|
||||||
def reallystop():
|
def reallystop():
|
||||||
global play,sizeworld,level
|
global play,sizeworld,level,stat
|
||||||
items['run']['icon']="picture/stop.png"
|
items['run']['icon']="picture/stop.png"
|
||||||
play=0
|
play=0
|
||||||
clock.unschedule(calculate)
|
clock.unschedule(calculate)
|
||||||
|
@ -625,6 +653,7 @@ def reallystop():
|
||||||
readcondgrid(ele['file'])
|
readcondgrid(ele['file'])
|
||||||
erase()
|
erase()
|
||||||
retriern()
|
retriern()
|
||||||
|
stat=[0,0,0,0,0,0,0,0]
|
||||||
|
|
||||||
def reallyrun():
|
def reallyrun():
|
||||||
global play,sizeworld
|
global play,sizeworld
|
||||||
|
@ -670,6 +699,7 @@ def swap():
|
||||||
|
|
||||||
def gameover_ok():
|
def gameover_ok():
|
||||||
global over,level,sizeworld
|
global over,level,sizeworld
|
||||||
|
reallystop()
|
||||||
for i in range(sizeworld):
|
for i in range(sizeworld):
|
||||||
ele=items[items[int("0x40000",16)+i]]
|
ele=items[items[int("0x40000",16)+i]]
|
||||||
if ele['world']==world and ele['grid']==level:
|
if ele['world']==world and ele['grid']==level:
|
||||||
|
@ -680,6 +710,7 @@ def gameover_ok():
|
||||||
|
|
||||||
def itsvictory_ok():
|
def itsvictory_ok():
|
||||||
global over,level,finished,sizeworld
|
global over,level,finished,sizeworld
|
||||||
|
reallystop()
|
||||||
for i in range(sizeworld):
|
for i in range(sizeworld):
|
||||||
ele=items[items[int("0x40000",16)+i]]
|
ele=items[items[int("0x40000",16)+i]]
|
||||||
if ele['world']==world and ele['grid']==level:
|
if ele['world']==world and ele['grid']==level:
|
||||||
|
@ -692,18 +723,18 @@ def itsvictory_ok():
|
||||||
|
|
||||||
def gameover(x):
|
def gameover(x):
|
||||||
global over
|
global over
|
||||||
reallystop()
|
|
||||||
over=x
|
over=x
|
||||||
sound.queue(pyglet.resource.media("sound/gameover.mp3"))
|
sound.queue(pyglet.resource.media("sound/gameover.mp3"))
|
||||||
sound.play()
|
sound.play()
|
||||||
|
clock.unschedule(calculate)
|
||||||
|
|
||||||
def itsvictory():
|
def itsvictory():
|
||||||
global over
|
global over
|
||||||
reallystop()
|
|
||||||
label=pyglet.text.Label("ViCTOIRE !",font_name='Liberation Mono',font_size=100,x=win.width/2-350,y=win.height/2-200,color=(255,255,255,255))
|
label=pyglet.text.Label("ViCTOIRE !",font_name='Liberation Mono',font_size=100,x=win.width/2-350,y=win.height/2-200,color=(255,255,255,255))
|
||||||
over=-1
|
over=-1
|
||||||
sound.queue(pyglet.resource.media("sound/victoire.mp3"))
|
sound.queue(pyglet.resource.media("sound/victoire.mp3"))
|
||||||
sound.play()
|
sound.play()
|
||||||
|
clock.unschedule(calculate)
|
||||||
|
|
||||||
def infos():
|
def infos():
|
||||||
global stat,sizex,sizey,cycle,thecout,victory,current
|
global stat,sizex,sizey,cycle,thecout,victory,current
|
||||||
|
@ -736,6 +767,7 @@ def infos():
|
||||||
def erase():
|
def erase():
|
||||||
for x in range(1,sizex-1):
|
for x in range(1,sizex-1):
|
||||||
for y in range(1,sizey-1):
|
for y in range(1,sizey-1):
|
||||||
|
unactive(x,y)
|
||||||
if world_new[x][y]==items['headp']['value'] or world_new[x][y]==items['tailp']['value']:
|
if world_new[x][y]==items['headp']['value'] or world_new[x][y]==items['tailp']['value']:
|
||||||
world_new[x][y]=items['fiber']['value']
|
world_new[x][y]=items['fiber']['value']
|
||||||
elif world_new[x][y]>=items['tail']['value']:
|
elif world_new[x][y]>=items['tail']['value']:
|
||||||
|
@ -756,6 +788,9 @@ def desactive(x,y):
|
||||||
if world_art[x][y]>int("0x1000000",16):
|
if world_art[x][y]>int("0x1000000",16):
|
||||||
world_art[x][y]=world_art[x][y]-int("0x1000000",16)
|
world_art[x][y]=world_art[x][y]-int("0x1000000",16)
|
||||||
|
|
||||||
|
def unactive(x,y):
|
||||||
|
world_art[x][y]=world_art[x][y] & int("0x00FFFFFF",16)
|
||||||
|
|
||||||
def active(x,y):
|
def active(x,y):
|
||||||
world_art[x][y]=world_art[x][y] | int("0x0A000000",16)
|
world_art[x][y]=world_art[x][y] | int("0x0A000000",16)
|
||||||
|
|
||||||
|
@ -886,18 +921,17 @@ def nextgrid():
|
||||||
world_new[x+ex][y+ey-1]=items['prot']['value']
|
world_new[x+ex][y+ey-1]=items['prot']['value']
|
||||||
elif art==items['reactor']['value'] and value==items['head2']['value'] and isactive(x+ex,y+ey):
|
elif art==items['reactor']['value'] and value==items['head2']['value'] and isactive(x+ex,y+ey):
|
||||||
world_new[x+ex][y+ey]=items['copper']['value']
|
world_new[x+ex][y+ey]=items['copper']['value']
|
||||||
value=items['copper']['value']
|
|
||||||
world_new[x+ex][y+ey-1]=items['neut']['value']
|
world_new[x+ex][y+ey-1]=items['neut']['value']
|
||||||
elif art==items['senserK']['value'] and value==items['headr']['value'] and isactive(x+ex,y+ey):
|
elif art==items['senserK']['value'] and value==items['headb']['value'] and isactive(x+ex,y+ey):
|
||||||
world_new[x+ex][y+ey]=items['copper']['value']
|
world_new[x+ex][y+ey]=items['copper']['value']
|
||||||
current[7]=current[7]+1
|
current[7]=current[7]+1
|
||||||
elif art==items['senserL']['value'] and value==items['headr']['value'] and isactive(x+ex,y+ey):
|
elif art==items['senserL']['value'] and value==items['headb']['value'] and isactive(x+ex,y+ey):
|
||||||
world_new[x+ex][y+ey]=items['copper']['value']
|
world_new[x+ex][y+ey]=items['copper']['value']
|
||||||
current[8]=current[8]+1
|
current[8]=current[8]+1
|
||||||
elif art==items['senserM']['value'] and value==items['headr']['value'] and isactive(x+ex,y+ey):
|
elif art==items['senserM']['value'] and value==items['headb']['value'] and isactive(x+ex,y+ey):
|
||||||
world_new[x+ex][y+ey]=items['copper']['value']
|
world_new[x+ex][y+ey]=items['copper']['value']
|
||||||
current[9]=current[9]+1
|
current[9]=current[9]+1
|
||||||
elif art==items['senserN']['value'] and value==items['headr']['value'] and isactive(x+ex,y+ey):
|
elif art==items['senserN']['value'] and value==items['headb']['value'] and isactive(x+ex,y+ey):
|
||||||
world_new[x+ex][y+ey]=items['copper']['value']
|
world_new[x+ex][y+ey]=items['copper']['value']
|
||||||
current[10]=current[10]+1
|
current[10]=current[10]+1
|
||||||
elif art==items['sensere']['value'] and value==items['head']['value']:
|
elif art==items['sensere']['value'] and value==items['head']['value']:
|
||||||
|
@ -985,7 +1019,8 @@ def nextgrid():
|
||||||
def main():
|
def main():
|
||||||
pyglet.app.run()
|
pyglet.app.run()
|
||||||
|
|
||||||
win = pyglet.window.Window(width=1024, height=768,resizable=True, visible=True)
|
'''win = pyglet.window.Window(width=1024, height=768,resizable=True, visible=True)'''
|
||||||
|
win = pyglet.window.Window(fullscreen=True)
|
||||||
|
|
||||||
initgrid(30,20)
|
initgrid(30,20)
|
||||||
win.set_caption("Wirechem: The new chemistry game")
|
win.set_caption("Wirechem: The new chemistry game")
|
||||||
|
@ -993,6 +1028,8 @@ clock.schedule(refresh)
|
||||||
player = pyglet.media.Player()
|
player = pyglet.media.Player()
|
||||||
ambiance = pyglet.media.Player()
|
ambiance = pyglet.media.Player()
|
||||||
sound = pyglet.media.Player()
|
sound = pyglet.media.Player()
|
||||||
|
player.queue(pyglet.resource.media("movie/intro.mp4"))
|
||||||
|
player.play()
|
||||||
ambiance.queue(pyglet.resource.media("music/ambiance1.mp3"))
|
ambiance.queue(pyglet.resource.media("music/ambiance1.mp3"))
|
||||||
ambiance.play()
|
ambiance.play()
|
||||||
readpref('user/pref.dat')
|
readpref('user/pref.dat')
|
||||||
|
|
Loading…
Reference in New Issue