tangledmind/models.py

179 lines
6.3 KiB
Python
Raw Normal View History

# -*- coding: UTF-8 -*-
### Tangled Mind
### Author: Arthur 'Grizzly' Grisel-Davy
import pygame
2020-03-29 23:17:04 +02:00
from time import time
2020-04-03 04:53:25 +02:00
import numpy as np
2020-04-06 00:29:38 +02:00
from numpy import sqrt
2020-04-12 06:08:24 +02:00
from math import atan, degrees,radians, cos, sin
2020-04-04 06:11:34 +02:00
decision_matrix = np.array([[0,1,2],[3,4,5],[6,7,8]])
suffix_matrix = ['_up_left.png',
'_up.png',
'_up_right.png',
'_left.png',
'_up.png',
'_right.png',
'_down_left.png',
'_down.png',
'_down_right.png',]
img_path = 'asset/'
2020-04-11 06:17:49 +02:00
cap_speed = 10
2020-04-06 00:29:38 +02:00
deceleration = 1.1
2020-04-04 06:11:34 +02:00
2020-03-29 23:17:04 +02:00
class Perso():
2020-04-11 06:17:49 +02:00
def __init__(self,name,posx,posy,key_up,key_down,key_left,key_right,key_fire,texture,texture_canon,texture_proj):
self.name = name
self.posx = posx
self.posy = posy
2020-04-06 00:29:38 +02:00
self.speed = [0,0]
2020-04-03 04:53:25 +02:00
self.direction = [0,-1]
self.key_up = key_up
self.key_down = key_down
self.key_left = key_left
self.key_right = key_right
2020-03-29 23:17:04 +02:00
self.key_fire = key_fire
2020-04-11 06:17:49 +02:00
self.imgs = [pygame.image.load(img_path+texture+'_up_left.png').convert_alpha(),
pygame.image.load(img_path+texture+'_up.png').convert_alpha(),
pygame.image.load(img_path+texture+'_up_right.png').convert_alpha(),
pygame.image.load(img_path+texture+'_left.png').convert_alpha(),
pygame.image.load(img_path+texture+'_down.png').convert_alpha(),
pygame.image.load(img_path+texture+'_right.png').convert_alpha(),
pygame.image.load(img_path+texture+'_down_left.png').convert_alpha(),
pygame.image.load(img_path+texture+'_down.png').convert_alpha(),
pygame.image.load(img_path+texture+'_down_right.png').convert_alpha(),]
2020-04-03 04:53:25 +02:00
self.img = self.imgs[0]
2020-04-11 06:17:49 +02:00
self.canon = pygame.image.load(img_path+texture_canon).convert_alpha()
2020-04-12 06:08:24 +02:00
self.degres = 0
2020-04-04 06:11:34 +02:00
self.texture_proj = texture_proj
2020-04-03 04:53:25 +02:00
2020-03-29 04:38:20 +02:00
self.size = self.img.get_size()
2020-03-29 23:17:04 +02:00
self.projectiles = []
self.last_fire = time()
2020-04-11 06:17:49 +02:00
def check_keys(self,keystate,screen_width,screen_height):
2020-04-03 04:53:25 +02:00
2020-04-06 00:29:38 +02:00
# If an interresting key is pressed
2020-04-03 04:53:25 +02:00
if keystate[self.key_left] or keystate[self.key_right] or keystate[self.key_up] or keystate[self.key_down]:
2020-04-06 00:29:38 +02:00
2020-04-03 04:53:25 +02:00
if keystate[self.key_left]:
2020-04-06 00:29:38 +02:00
self.speed[0] = -1*cap_speed
2020-04-03 04:53:25 +02:00
if keystate[self.key_right]:
2020-04-06 00:29:38 +02:00
self.speed[0] = cap_speed
2020-04-03 04:53:25 +02:00
if keystate[self.key_up]:
2020-04-06 00:29:38 +02:00
self.speed[1] = -1*cap_speed
2020-04-03 04:53:25 +02:00
if keystate[self.key_down]:
2020-04-06 00:29:38 +02:00
self.speed[1] = cap_speed
2020-04-03 04:53:25 +02:00
if not keystate[self.key_left] and not keystate[self.key_right]:
self.direction[0] = 0
if not keystate[self.key_up] and not keystate[self.key_down]:
self.direction[1] = 0
2020-03-29 23:17:04 +02:00
2020-04-06 00:29:38 +02:00
# Cap the speed
if abs(self.speed[0])>cap_speed:
self.speed[0] = self.speed[0]/abs(self.speed[0])*cap_speed
if abs(self.speed[1])>cap_speed:
self.speed[1] = self.speed[1]/abs(self.speed[1])*cap_speed
# Begin the deceleration
self.speed[0] = int(self.speed[0]/deceleration)
self.speed[1] = int(self.speed[1]/deceleration)
# Update the position
self.posx = self.posx+self.speed[0]
self.posy = self.posy+self.speed[1]
# Select the direction based on the closest cardinals+bissectrices vectors
if self.speed != [0,0]:
direction=[]
min_dist = 1000
for a in [-1,0,1]:
for b in [-1,0,1]:
dist = sqrt((self.speed[0]-a)**2+(self.speed[1]-b)**2)
if dist < min_dist:
min_dist = dist
direction = [a,b]
self.direction = direction
2020-03-29 23:17:04 +02:00
if keystate[self.key_fire]:
2020-03-31 05:03:42 +02:00
self.fire('fireball','asset/projectile')
2020-03-29 23:17:04 +02:00
def draw(self,surface):
2020-04-03 04:53:25 +02:00
# Make all projectiles move or disepear and draw them
2020-03-31 05:03:42 +02:00
to_remove = []
for k,proj in enumerate(self.projectiles):
if not proj.is_out(surface):
proj.move()
proj.draw(surface)
else:
to_remove.append(k)
if to_remove != []:
for k in to_remove[::-1]:
del self.projectiles[k]
2020-04-03 04:53:25 +02:00
# select img
2020-04-04 06:11:34 +02:00
index = decision_matrix[self.direction[1]+1,self.direction[0]+1]
2020-04-03 04:53:25 +02:00
self.img = self.imgs[index]
2020-04-11 06:17:49 +02:00
#Calculate canon rotation:
x_mouse, y_mouse = pygame.mouse.get_pos()
if x_mouse==self.posx:
x_mouse+=0.1
2020-04-12 06:08:24 +02:00
self.degres = degrees(abs(atan((y_mouse-self.posy)/(x_mouse-self.posx))))
2020-04-11 06:17:49 +02:00
if y_mouse > self.posy:
2020-04-12 06:08:24 +02:00
self.degres = -self.degres
2020-04-11 06:17:49 +02:00
if x_mouse < self.posx:
2020-04-12 06:08:24 +02:00
self.degres = 180-self.degres
2020-04-11 06:17:49 +02:00
2020-04-12 06:08:24 +02:00
canon = pygame.transform.rotate(self.canon,self.degres)
2020-04-11 06:17:49 +02:00
# Get rects
perso_rect = self.img.get_rect()
canon_rect = canon.get_rect()
surface.blit(self.img,(self.posx-perso_rect.center[0],self.posy-perso_rect.center[1]))
surface.blit(canon,(self.posx-canon_rect.center[0],self.posy-canon_rect.center[1]))
2020-03-29 23:17:04 +02:00
2020-03-31 05:03:42 +02:00
def fire(self,name,texture):
2020-03-29 23:17:04 +02:00
if (time()-self.last_fire> 0.2):
2020-04-12 06:08:24 +02:00
new_proj = Projectile(name,self.texture_proj,10,(self.posx+int(self.img.get_height()/2),self.posy+int(self.img.get_width()/2)),self.degres)
2020-03-29 23:17:04 +02:00
self.projectiles.append(new_proj)
self.last_fire = time()
class Projectile():
2020-04-12 06:08:24 +02:00
def __init__(self,name,texture,speed,position,angle):
2020-03-29 23:17:04 +02:00
self.name = name
self.speed = speed
self.position = position
2020-04-12 06:08:24 +02:00
self.direction = direction = [cos(radians(angle)),-sin(radians(angle))]
self.img = pygame.transform.rotate(pygame.image.load(img_path+texture).convert_alpha(),angle)
2020-03-31 05:03:42 +02:00
2020-03-29 23:17:04 +02:00
def move(self):
2020-04-12 06:08:24 +02:00
self.position = (int(self.position[0]+self.speed*self.direction[0]),int(self.position[1]+self.speed*self.direction[1]))
def draw(self,surface):
2020-03-31 05:03:42 +02:00
surface.blit(self.img,self.position)
def is_out(self,surface):
if (self.position[0]<0-self.img.get_width() or
self.position[1]<0-self.img.get_height() or
self.position[0]>surface.get_width()+self.img.get_width() or
self.position[1]>surface.get_height()+self.img.get_height()):
return True
else:
return False