-
Notifications
You must be signed in to change notification settings - Fork 0
/
fighterEX.py
244 lines (199 loc) · 7.97 KB
/
fighterEX.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
import pygame
class FighterEX():
def __init__(self, Player, x, y, flip,Data, Spritesheet,animations):
self.Player = Player
#loading x and y cordinates on sprite sheets
self.SizeWidth = Data[0]
self.SizeHeight = Data[1]
self.ImageScale = Data[2]
self.Offset = Data[3]
self.flip = flip
#loads sprites frame by frame
self.animation_list = self.load_sprites(Spritesheet,animations)
#Determines what player is doing to load correct sprites
self.action = 0 #0 = idle, 1 = run, 2 = jump, 3 = fall, 4 = attack1, 5 = attack2, 6 = get hit, 7 = death, 8 =attack3
self.frame_index = 0
self.image = self.animation_list[self.action][self.frame_index]
self.update_time = pygame.time.get_ticks()
#healthbar
self.rect = pygame.Rect((x,y,85,200))
#controls how fast you go up and down(for character jump)
self.vel_y = 0
#runnig
self.running = False
#makes it so that you can jump a certain distance up
self.jump = False
#can attack once per key press
self.attacking = False
#defing attack variable
self.attack_type = 0
#cooldown for attack
self.attack_cooldown = 0
#getting hit
self.hit = False
#Defines health.
# Health must be set to length of health bar
#also defining death
self.Health = 400
self.Alive = True
#SCORE
self.Score = 0
#load sprites
def load_sprites (self, Spritesheet,animations):
animation_list = []
for y,animation in enumerate(animations):
temp_img_list = []
for x in range(animation):
temp_img = Spritesheet.subsurface (x * self.SizeWidth,y * self.SizeHeight , self.SizeWidth, self.SizeHeight)
temp_img_list.append(pygame.transform.scale(temp_img, (self.SizeWidth * self.ImageScale, self.SizeHeight * self.ImageScale)))
animation_list.append(temp_img_list)
print(animation_list)
return animation_list
#Adding Movement To Characters (rectangles), Dx/Dy records the change in those coordinates
def Move(self, screen_width,screen_height,surface, target):
SPEED = 15
Gravity = 2
dx = 0
dy = 0
self.running = False
self.attack_type = 0
#get Keypresses that allows keys to move the player
key = pygame.key.get_pressed()
#Cant preform other movements while attacking
if self.attacking == False and self.Alive == True:
if self.Player == 0:
pass
#Check Ronin Controls
if self.Player == 1:
#Directional movement
if key[pygame.K_a]:#Left
dx = -SPEED
self.running = True
if key[pygame.K_d]:#Right
dx = SPEED
self.running = True
#Jumping , and statement makes it so that the player can only jump again when on the ground/ no double jump
if key[pygame.K_w] and self.jump == False:
self.vel_y = -30
self.jump = True
#Attack
if key[pygame.K_r] or key[pygame.K_t] or key[pygame.K_e]:
self.attack(surface, target)
#Determines whether to use attack 1,2 or 3
if key[pygame.K_r]:
self.attack_type = 1
if key[pygame.K_t]:
self.attack_type = 2
if key [pygame.K_e]:
self.attack = 3
#Check Samurai Controls
if self.Player == 2:
#Directional movement
if key[pygame.K_j]:#Left
dx = -SPEED
self.running = True
if key[pygame.K_l]:#Right
dx = SPEED
self.running = True
#Jumping , and statement makes it so that the player can only jump again when on the ground/ no double jump
if key[pygame.K_i] and self.jump == False:
self.vel_y = -30
self.jump = True
#Attack
if key[pygame.K_o] or key[pygame.K_p] or key[pygame.K_0]:
self.attack(surface, target)
#Determines whether to use attack 1 or 2
if key[pygame.K_p]:
self.attack_type = 1
if key[pygame.K_o]:
self.attack_type = 2
if key[pygame.K_0]:
self.attack_type = 3
#adds Gravity
self.vel_y += Gravity
dy += self.vel_y
#print(self.vel_y)
#Ensure player doesnt go off screen
if self.rect.left + dx < 0:
dx = -self.rect.left
if self.rect.right + dx > screen_width:
dx = screen_width - self.rect.right
if self.rect.bottom + dy > screen_height - 40:
self.vel_y = 0
self.jump = False
dy = screen_height - 40 - self.rect.bottom
#Apply Attack Cooldown
if self.attack_cooldown > 0:
self.attack_cooldown -= 1
#Update Player Position
self.rect.x += dx
self.rect.y += dy
#Handles Animatiion Updates
#Check which action is being preformed
if self.Health <= 0:
self.Health = 0
self.Alive = False
self.update_action(7)# Death
elif self.hit == True:
self.update_action(6)# Getting Hit
elif self.attacking == True:
if self.attack_type == 1:
self.update_action(4) #4: Attack 1
elif self.attack_type == 2:
self.update_action(5) #5: Attack 2
elif self.attack_type == 3:#8 Attack 3
self.update_action(8)
elif self.jump == True:
self.update_action(2) #2: Jump
if self.vel_y <=30 and self.vel_y>= 0:
self.update_action(3)#3:Fall
elif self.running == True:
self.update_action(1)#1: Run
else:
self.update_action(0)#0: Idle
def update(self):
animation_cooldown = 130
self.image = self.animation_list [self.action][self.frame_index]
#check if enough time has passed since last update
if pygame.time.get_ticks() - self.update_time > animation_cooldown:
self.frame_index += 1
self.update_time = pygame.time.get_ticks()
#will check if animation has been completed/ will loop again
if self.frame_index >= len(self.animation_list[self.action]):
if self.Alive == False:
self.frame_index = len(self.animation_list[self.action]) - 1
else:
self.frame_index = 0
#Check if attack was excecuted
if self.action == 4 or self.action == 5:
self.attacking = False
self.attack_cooldown = 20
#check if damage was taken
if self.action == 6:
self.hit = False
# if you get hit while trying to attack, your attack is interrupted
self.attacking = False
self.attack_cooldown = 20
#Key Note: Surface is what makes the rectangles show up
#Define attack variable attack starts from the center of player rectangle, width is multiplied by 2 and overlaps half the rectangle
def attack(self,surface,target):
if self.attack_cooldown == 0:
self.attacking = True
attacking_range = pygame.Rect(self.rect.centerx - (4.3 * self.rect.width * self.flip), self.rect.y, 3.59*self.rect.width , self.rect.height)
pygame.draw.rect(surface,(0,255,0), attacking_range)
#basically registers player hitting player
if attacking_range.colliderect(target.rect):
target.Health -= 33.34
target.hit = True
def update_action(self, new_action):
#checks if actions index range from sprites if different from the previous one, such as idle having 4 frames while running has 8
if new_action!= self.action:
self.action = new_action
#update animation settings
self.frame_index = 0
self.update_time = pygame.time.get_ticks()
#Visually adds the rectangles(soon to be sprite images)
def Draw(self, surface):
img = pygame.transform.flip(self.image, self.flip, False)
#pygame.draw.rect(surface, (255,0,0), self.rect)
surface.blit(img,(self.rect.x - (self.Offset[0] * self.ImageScale), self.rect.y -(self.Offset[1] * self.ImageScale)))