Главная » 2016 » Март » 19 » Перемещение нескольких объектов по клеточному полю
20:12
Перемещение нескольких объектов по клеточному полю

Перемещение нескольких объектов по клеточному полю.

В предыдущей части урока мы научились рисовать и перемещать по клеточкам один объект. Теперь усложняем задание - вводим несколько объектов и перемещаем их по полю. При перемещении мы должны учитывать, что объекты не должны занимать уже занятые клеточки( налазить друг на друга) и разрешение на перемещение определяется лкм.

Исходники для написания логических игр

И так, раз у нас уже несколько объектов, то я их как обычно сразу заношу в список, для проверки свободно или занято место куда я хочу переместить объект буду использовать двумерный список(изначально пустой).

Первым делом рождаем наши объекты , как экземпляры класса.

hero1 = Sprite(margin,margin,('abcd.png'))
hero2 = Sprite(margin+(width +margin),margin,('abcd1.png'))
hero3 = Sprite((width +margin)*2+margin,margin,('abcd2.png'))

Что мы меняем в классе? 1)Добавляем в функцию выделения объекта мышкой - запрет на перемещение конкрктного объекта, если этого не сделать возникнет ситуация когда можно последовательно активировать несколько объектов и при нажатии клавиши курсора переместятся сразу несколько объектов, а не один.2)Добавляем в класс функцию перемещения с запоминанием первоначального положения нашего объекта(для случая когда перемещение будет отклонено из за занятости клетки), в этой же функции заносим запись, что клетка свободна.Если проверка выявляет, что объект перемещен на занятую клетку, проводим откат назад. 3) Функция записи занятости клеток поля.

class Sprite:
    def __init__(self,xpos,ypos,filename):
        self.x = xpos
        self.y = ypos
        self.image=pygame.image.load(filename) # создаем рисунок-загрузка из файла
        self.action = False
        self.rect = self.image.get_rect() # представляем его прямоугольником
        
        self.w = self.image.get_width()   #ширина
        self.h = self.image.get_height()  #высота
        all_s.append(self)       
       
        self.row = None
        self.column = None
    def bum (self):
# проверка попадания мышки на объект
       
        if self.x<mp[0]<self.x+self.w and self.y<mp[1]<self.y+self.h:           
            self.action = True# объект активирован                         
        else:
            self.action = False# для избежания случая активации одновременно
                               #  двух объектов           
           
           
    
    def mouv(self):
# функция перемещения объекта
        a = self.x # первоначальные координаты объекта
        b = self.y        
       
        if e.key == pygame.K_LEFT:
            if self.x >margin and self.action == True:
                self.x -= margin+width                                               
                self.action = False# запрет на перемещение               
                grid[ b // (height + margin)][ a // (width + margin)] =0
              
        if e.key == pygame.K_RIGHT:
            if self.x <(width +margin)*(n-1)and self.action == True:
                self.x += margin+width               
                self.action = False
                grid[ b // (height + margin)][ a // (width + margin)] =0
        if e.key == pygame.K_UP:
            if self.y >margin and self.action == True:
                self.y -=height+margin                    
                self.action = False# запрет на перемещение
                grid[ b // (height + margin)][ a // (width + margin)] =0
        if e.key == pygame.K_DOWN:
            if self.y <(height+margin)*(n-1)and self.action == True:
                self.y += height+margin         
                self.action = False# запрет на перемещение
                grid[ b // (height + margin)][ a // (width + margin)] =0
        self.column = self.x // (width + margin)
        self.row = self.y // (height + margin)
        if grid[self.row][self.column] ==1:
            self.x = a
            self.y = b
           
              
    def mesto(self):              
        self.column = self.x // (width + margin)
        self.row = self.y // (height + margin)            
        grid[self.row][self.column] = 1
   
    def render (self ):
# отображение обьекта на игровом поле(экране)
        screen.blit(self.image,(self.x,self.y))
Для операций проверок занятости клеток поля, а следовательно и правильного перемещения кубиков организуем двумерный список, если клетка свободна - она будет иметь значение 0, если занята 1:

grid = []
for row in range(n):
    # заполняем пустую матрицу
    # 10 х 10  grid[row,column]
    grid.append([])
    for column in range(n):
        grid[row].append(0)

Полный код программы:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import pygame,sys,os
import random
# Define some colors  лкм - рисуем кубик в клетку, пкм - стираем кубик(закрашиваем белым)
BLACK    = (   0,   0,   0)
WHITE    = ( 255, 255, 255)
GREEN    = (   0, 255,   0)
RED      = ( 255,   0,   0)
pygame.init()
# окно
action = False

n=4# количество клеток квадратного поля игры
width  = 48#ширина клетки( и объекта)
height = 48#высота клетки ( и объекта)
playr = None
margin = 5# промежуток между клетками
x=None
y=None
window = pygame.display.set_mode(((width +margin)*n+margin,(height+margin)*n+margin))# создаём окно
pygame.display.set_caption('Masha and Misha') # титул строка
screen = pygame.Surface(((width +margin)*n+margin,(height+margin)*n+margin)) # создаем игровое поле(экран)
all_s = []

class Sprite:
    def __init__(self,xpos,ypos,filename):
        self.x = xpos
        self.y = ypos
        self.image=pygame.image.load(filename) # создаем рисунок-загрузка из файла
        self.action = False
        self.rect = self.image.get_rect() # представляем его прямоугольником
        
        self.w = self.image.get_width()   #ширина
        self.h = self.image.get_height()  #высота
        all_s.append(self)       
       
        self.row = None
        self.column = None
    def bum (self):# проверка попадания мышки на объект
       
        if self.x<mp[0]<self.x+self.w and self.y<mp[1]<self.y+self.h:           
            self.action = True# объект активирован                         
        else:
            self.action = False# для избежания случая активации одновременно
                               #  двух объектов           
           
           
    
    def mouv(self):# функция перемещения объекта
        a = self.x # первоначальные координаты объекта
        b = self.y        
       
        if e.key == pygame.K_LEFT:
            if self.x >margin and self.action == True:
                self.x -= margin+width                                               
                self.action = False# запрет на перемещение               
                grid[ b // (height + margin)][ a // (width + margin)] =0
              
        if e.key == pygame.K_RIGHT:
            if self.x <(width +margin)*(n-1)and self.action == True:
                self.x += margin+width               
                self.action = False
                grid[ b // (height + margin)][ a // (width + margin)] =0
        if e.key == pygame.K_UP:
            if self.y >margin and self.action == True:
                self.y -=height+margin                    
                self.action = False# запрет на перемещение
                grid[ b // (height + margin)][ a // (width + margin)] =0
        if e.key == pygame.K_DOWN:
            if self.y <(height+margin)*(n-1)and self.action == True:
                self.y += height+margin         
                self.action = False# запрет на перемещение
                grid[ b // (height + margin)][ a // (width + margin)] =0
        self.column = self.x // (width + margin)
        self.row = self.y // (height + margin)
        if grid[self.row][self.column] ==1:
            self.x = a
            self.y = b
           
              
    def mesto(self):              
        self.column = self.x // (width + margin)
        self.row = self.y // (height + margin)            
        grid[self.row][self.column] = 1
        print grid
    def render (self ):# отображение обьекта на игровом поле(экране)
        screen.blit(self.image,(self.x,self.y))

    
hero1 = Sprite(margin,margin,('abcd.png'))
hero2 = Sprite(margin+(width +margin),margin,('abcd1.png'))
hero3 = Sprite((width +margin)*2+margin,margin,('abcd2.png'))


done = True# некая переменная
grid = []
for row in range(n):
    # заполняем пустую матрицу
    # 10 х 10  grid[row,column]
    grid.append([])
    for column in range(n):
        grid[row].append(0)
while done:# условие существования игрового цикла
    
    #pygame.mixer.music.stop()
   
    screen.fill((0,0,90))
    for e in pygame.event.get():# для любого события
        
        if e.type == pygame.QUIT:# если было закрытие окна
            sys.exit()
        if e.type == pygame.MOUSEBUTTONDOWN : # если событие мышь                                      
            if pygame.mouse.get_pressed()[0]:#если  была нажата лкм
                mp = pygame.mouse.get_pos()
                for i in all_s :#
                    i.bum() # выбор объекта
                
        # Перемещение объекта с помощью курсора
        if e.type == pygame.KEYDOWN: # если была нажата клавиша
             for i in all_s:
                i.mouv()
    
    
    for row in range(n):# рисуем игровое поле
            for column in range(n):
                color = WHITE
                pygame.draw.rect(screen,
                             color,
                             [(margin+width)*column+margin,
                              (margin+height)*row+margin,
                              width,
                              height])    
   
    for i in all_s:# запись положения объекта в список grid
        i.mesto()
    
    for i in all_s:
        i.render()
   
    window.blit(screen,(0,0))# на окне прорисовываем поле игры
   
    pygame.display.flip()# отображаем полностью дисплей(окно)

 

 

Категория: игры на Python | Просмотров: 1781 | Добавил: kuzma | Рейтинг: 0.0/0
Всего комментариев: 0
avatar

Программирование игр на Python

Django - создание сайтов с нуля

Javascript - просто используем готовые решения