mirror of
https://forge.apps.education.fr/phroy/codetower.git
synced 2024-01-27 11:35:17 +01:00
231 lines
7.3 KiB
Python
231 lines
7.3 KiB
Python
import bge # Bibliothèque Blender Game Engine (UPBGE)
|
||
import bpy # Blender
|
||
from ct_lib import * # Bibliothèque CodeTower
|
||
import os
|
||
|
||
###############################################################################
|
||
# ct_map1.py
|
||
# @title: Map #1 definition
|
||
# @project: CodeTower
|
||
# @lang: fr,en
|
||
# @authors: Philippe Roy <phroy@phroy.org>
|
||
# @copyright: Copyright (C) 2022 Philippe Roy
|
||
# @license: GNU GPL
|
||
#
|
||
# This game is a tower defense coding game. The towers are driven by Python code.
|
||
# The file is the the map and waves definition.
|
||
#
|
||
###############################################################################
|
||
|
||
scene = bge.logic.getCurrentScene()
|
||
|
||
###############################################################################
|
||
# En: Threads management << DONT CHANGE THIS SECTION >>
|
||
# Fr: Gestion des tâches (threads) << NE PAS MODIFIER CETTE SECTION >>
|
||
###############################################################################
|
||
|
||
# waves_f={
|
||
# 1 : wave1(),
|
||
# 2 :wave2(),
|
||
# 3 :wave3(),
|
||
# 4 :wave4()}
|
||
|
||
def start(wave):
|
||
scene.objects['Terrain']['thread_wave']=True
|
||
if wave==1:
|
||
thread_waves_start(wave1)
|
||
if wave==2:
|
||
thread_waves_start(wave2)
|
||
if wave==3:
|
||
thread_waves_start(wave3)
|
||
if wave==4:
|
||
thread_waves_start(wave4)
|
||
|
||
def stop():
|
||
thread_waves_stop()
|
||
|
||
def end():
|
||
ct_sleep (2)
|
||
print ("Thread waves is arrived.")
|
||
scene.objects['Terrain']['thread_wave']=False
|
||
|
||
###############################################################################
|
||
# En: Minions definition
|
||
# Fr: Définition des minions
|
||
#
|
||
# Minion caracteristics :
|
||
# - category, minion class (string) :
|
||
# - Knight
|
||
# - Barbarian
|
||
# - Warrior
|
||
# - Mage
|
||
# - Rogue
|
||
# - Orc
|
||
# - Squelette
|
||
# - level : 1, 2 or 3 (integer)
|
||
# - hp (float)
|
||
# - speed (float)
|
||
# - armor (float)
|
||
# - bounty (integer)
|
||
# - lifes_damage (integer)
|
||
#
|
||
# Minion 3D object :
|
||
# - body : male,female,old, ... (string)
|
||
# - variante : A,B,C,D, ... (string)
|
||
# - level : common, uncommon, rare, ... (string)
|
||
#
|
||
###############################################################################
|
||
|
||
def minion_definition():
|
||
|
||
# Minion caracteristics : category (class), level, hp, speed, armor, bounty, lifes_damage
|
||
minion_carac={
|
||
'Knight-lv1' : ["Knight", 1 , 2.0, 1.0, 0.0, 5,1],
|
||
'Knight-lv2' : ["Knight", 2, 4.0, 1.0, 1.0, 20,1],
|
||
'Knight-lv3' : ["Knight", 3, 8.0, 1.0, 2.0, 80,1],
|
||
'Orc-lv1' : ["Orc", 1 , 2.0, 1.0, 0.0, 5,1],
|
||
'Orc-lv2' : ["Orc", 2, 4.0, 1.0, 1.0, 20,1],
|
||
'Orc-lv3' : ["Orc", 3, 8.0, 1.0, 2.0, 80,1]}
|
||
scene.objects['Terrain']['minion_carac'] = minion_carac
|
||
|
||
# Minion 3D object : body (male,female,old, ...), variante (A,B,C,D, ...), level
|
||
minion_3d={
|
||
'Knight-lv1' : [['Knight_m', 'Knight_f', 'OldKnight_m'],['A','B','C','D'],['common']],
|
||
'Knight-lv2' : [['Knight_m', 'Knight_f', 'OldKnight_m'],['A','B','C','D'],['uncommon']],
|
||
'Knight-lv3' : [['Knight_m', 'Knight_f', 'OldKnight_m'],['A','B','C','D'],['rare']],
|
||
'Orc-lv1' : [['Orc'],['A','B','C','D','E','F'],['common']],
|
||
'Orc-lv2' : [['Orc'],['A','B','C','D','E','F'],['uncommon']],
|
||
'Orc-lv3' : [['Orc'],['A','B','C','D','E','F'],['rare']]}
|
||
scene.objects['Terrain']['minion_3d'] = minion_3d
|
||
|
||
###############################################################################
|
||
# En: Waves commands
|
||
# Fr: Commandes des vagues
|
||
#
|
||
# Spawn a minion : ct_minion (x, y, cat, level)
|
||
# - x spwan position (integer)
|
||
# - y spwan position (integer)
|
||
# - category, minion class (string) :
|
||
# - Knight
|
||
# - Barbarian
|
||
# - Warrior
|
||
# - Mage
|
||
# - Rogue
|
||
# - Orc
|
||
# - Squelette
|
||
# - level (1, 2 or 3)
|
||
|
||
#
|
||
# Time management (temporization) : ct_sleep(delay)
|
||
# - delay : delay in seconds (integer)
|
||
#
|
||
# UI management : ct_map_text(text)
|
||
# - text for the wave label
|
||
#
|
||
###############################################################################
|
||
|
||
# Wave 1
|
||
def wave1():
|
||
ct_map_text_wave(1)
|
||
for i in range (15):
|
||
ct_minion(14,3,"Orc",1)
|
||
# ct_minion_details(14,3,"Orc",1, "Orc_A_common")
|
||
ct_sleep (2)
|
||
end()
|
||
|
||
# Wave 2
|
||
def wave2():
|
||
ct_map_text_wave(2)
|
||
for i in range (20):
|
||
ct_minion(14,3,"Orc",1)
|
||
# ct_minion_details(14,3,"Orc",1, "Orc_A_common")
|
||
ct_sleep (1)
|
||
end()
|
||
|
||
# Wave 3
|
||
def wave3():
|
||
ct_map_text_wave(3)
|
||
for i in range (30):
|
||
ct_minion(14,3,"Orc",1)
|
||
# ct_minion_details(14,3,"Orc",1, "Orc_A_common")
|
||
# ct_minion(14,3,"Knight",1)
|
||
ct_sleep (1)
|
||
end()
|
||
|
||
# Wave 4
|
||
def wave4():
|
||
ct_map_text_wave(4)
|
||
for i in range (20):
|
||
ct_minion(14,3,"Orc",1)
|
||
ct_minion(14,2.5,"Orc",1)
|
||
# ct_minion_details(14,3,"Orc",1, "Orc_A_common")
|
||
# ct_minion(14,3,"Knight",1)
|
||
ct_sleep (0.5)
|
||
end()
|
||
|
||
|
||
|
||
###############################################################################
|
||
# Tower definition
|
||
###############################################################################
|
||
|
||
def tower_definition():
|
||
|
||
# Tower caracteristics : category (class), damage, speed, range
|
||
tower_carac={
|
||
'Archer tower' : ["Archer tower", 1.0 , 0.02, 2.5],
|
||
'Mage tower' : ["Mage tower", 0.0 , 0.005, 2.5],
|
||
'Barrack' : ["Barrack", 1.0 , 0.0001, 2.5]}
|
||
scene.objects['Terrain']['tower_carac'] = tower_carac
|
||
|
||
# Minion 3D object : body (male,female,old, ...), variante (A,B,C,D, ...), level
|
||
tower_minion_3d={
|
||
'Archer-lv1' : [['Archer_m', 'Archer_f', "OldArcher_m"],['A','B','C','D'],['common']],
|
||
'Archer-lv2' : [['Archer_m', 'Archer_f', "OldArcher_m"],['A','B','C','D'],['uncommon']],
|
||
'Archer-lv3' : [['Archer_m', 'Archer_f', "OldArcher_m"],['A','B','C','D'],['rare']],
|
||
'Mage-lv1' : [['Mage'],['A','B','C','D'],['common']],
|
||
'Mage-lv2' : [['Mage'],['A','B','C','D'],['uncommon']],
|
||
'Mage-lv3' : [['Mage'],['A','B','C','D'],['rare']]}
|
||
scene.objects['Terrain']['tower_minion_3d'] = tower_minion_3d
|
||
|
||
###############################################################################
|
||
# Map
|
||
###############################################################################
|
||
|
||
# Initialization
|
||
def map_init():
|
||
|
||
# Base
|
||
scene.objects['Terrain']['size'] = [-15,15,-10,10] # Map size
|
||
scene.objects['Terrain']['navmesh'] = "Navmesh.004" # Navmesh
|
||
minion_definition()
|
||
tower_definition()
|
||
scene.objects['Terrain']['nb_waves'] = 4 # Number of waves
|
||
|
||
# Landscape
|
||
file_path = 'asset/map/map1-landscape.blend'
|
||
inner_path = 'Object'
|
||
object_name = 'Landscape'
|
||
bpy.ops.wm.append(
|
||
filepath=os.path.join(file_path, inner_path, object_name),
|
||
directory=os.path.join(file_path, inner_path),
|
||
filename=object_name)
|
||
|
||
# Ajout des sorties
|
||
scene.objects['Terrain']['endtile'] = "tile_straight.036"
|
||
ct_map_end(1,-10)
|
||
ct_map_endflag(0.5,-10)
|
||
ct_map_endflag(1.5,-10)
|
||
|
||
# Reset counters
|
||
def map_reset():
|
||
scene.objects['Points']['lifes']=10
|
||
scene.objects['Points']['lifes_max']=10
|
||
scene.objects['Points']['coins']=0
|
||
scene.objects['Points']['level']=0
|
||
scene.objects['Points']['level_max']=1
|
||
scene.objects['Points']['minions']=0
|
||
scene.objects['Points']['minions_run']=0
|
||
scene.objects['Points']['wave']=1
|
||
|