2017-10-14 311 views
1

我想畫一個圖像的紅色邊框,但不知道如何。如何在pygame中圍繞精靈或圖像繪製邊框?

我試圖填充Hero sprite的圖像,並將colorkey設置爲紅色self.image.set_colorkey(red),但這會使圖像不可見。

在圖像上繪製一個紅色矩形,完全填充它:pygame.draw.rect(self.image, red, [0, 0, width, height])

我只是想要一個紅色的邊框,這將有助於未來的碰撞檢測。

main.py代碼:

import pygame 
from pygame import * 
import sprites 
from sprites import * 
pygame.init() 

width = 640 
height = 480 
color = (255, 255, 255) #white 
x = 0 
y = 0 
speed = 3 

screen = pygame.display.set_mode((width, height)) 
pygame.display.set_caption("Mushroom") 
icon = pygame.image.load('icon.bmp') 
pygame.display.set_icon(icon) 
sprites_list = pygame.sprite.Group() 

hero = Hero('mushroom.png', 48, 48) 
hero.rect.x = 200; 
hero.rect.y = 300; 

sprites_list.add(hero) 

running = True 
clock = pygame.time.Clock() 
while running: 
    sprites_list.update() 
    screen.fill((color)) 
    sprites_list.draw(screen) 
    hero.draw(screen) 
    pygame.display.flip() 
    pygame.display.update() 

    for event in pygame.event.get(): 
     if event.type == pygame.QUIT: 
      running = False 

    key = pygame.key.get_pressed() 
    if key[pygame.K_LEFT]: 
     hero.left(speed) 
    if key[pygame.K_RIGHT]: 
     hero.right(speed) 
    if key[pygame.K_UP]: 
     hero.up(speed) 
    if key[pygame.K_DOWN]: 
     hero.down(speed) 

    clock.tick(60) 

中的代碼sprites.py

import pygame 
from pygame import * 

red = (255, 0, 0) 

class Hero(pygame.sprite.Sprite): 
    def __init__(self, color, width, height): 

     super().__init__() 

     self.image = pygame.image.load('mushroom.png') 
     self.image = pygame.Surface((width, height)) 
     self.image.fill(red) 
     self.image.set_colorkey(red) 

     pygame.draw.rect(self.image, red, [0, 0, width, height]) 
     self.rect = self.image.get_rect() 

    def draw(self, screen): 
     screen.blit(self.image, self.rect) 

    def right(self, pixels): 
     self.rect.x += pixels 
    def left(self, pixels): 
     self.rect.x -= pixels 
    def up(self, pixels): 
     self.rect.y -= pixels 
    def down(self, pixels): 
     self.rect.y += pixels 
+1

這是不是很清楚你想要做什麼。你爲什麼要填寫圖像'self.image.fill(red)',然後設置'self.image.set_colorkey(red)'顏色鍵?這使得圖像不可見。你是否試圖讓「mushroom.png」圖像的背景透明?或者你想在圖像周圍繪製紅色邊框? – skrx

+1

是的,我想在圖像周圍繪製紅色邊框以便將來進行碰撞檢查。圖像不顯示,但會顯示紅色矩形。 –

+1

你能告訴我們你的mushroom.png文件嗎?另外,如果你總是想在你的精靈周圍有一個紅色的矩形,那麼就不需要用一個新的'pygame.Surface'來替換'self.image',並且丟失剛剛加載的所有圖像數據。 – CodeSurgeon

回答

1

你有兩個選擇:

  1. 畫一個紅色的,在蘑菇圖像/表面上未填充的矩形。
  2. draw方法中繪製矩形的每一幀。

如果你想有一個非填充矩形,你必須通過一個int作爲最後一個參數(行width)到pygame.draw.rect

import pygame 


pygame.init() 

white = (255, 255, 255) 
red = (255, 0, 0) 

# The original 
hero_img = pygame.Surface((48, 48), pygame.SRCALPHA) 
pygame.draw.circle(hero_img, (30, 90, 170), (24, 24), 20) 
# ---Solution 1--- 
# You could create a copy of the original image and 
# then draw the rect onto it. 
hero_img_with_border = hero_img.copy() 
# Draw the red border. Pass an int as the last argument (width) 
# to draw a non-filled rect. For 2 pixel linewidth the rect has 
# to be one pixel smaller. 
pygame.draw.rect(hero_img_with_border, red, (0, 0, 47, 47), 2) 


class Hero(pygame.sprite.Sprite): 

    def __init__(self, position): 
     super().__init__() 
     self.image = hero_img 
     self.rect = self.image.get_rect(center=position) 
     self.speed = 3 

    def draw(self, screen): 
     # ---Solution 2--- 
     # Just draw the non-filled rect here. 
     pygame.draw.rect(screen, red, self.rect, 2) 

    def right(self): 
     self.rect.x += self.speed 
    def left(self): 
     self.rect.x -= self.speed 
    def up(self): 
     self.rect.y -= self.speed 
    def down(self): 
     self.rect.y += self.speed 


screen = pygame.display.set_mode((640, 480)) 

sprites_list = pygame.sprite.Group() 
# You can pass the coords and change the rect in the __init__ method. 
hero = Hero((200, 300)) 
sprites_list.add(hero) 

running = True 
clock = pygame.time.Clock() 

while running: 
    for event in pygame.event.get(): 
     if event.type == pygame.QUIT: 
      running = False 

    key = pygame.key.get_pressed() 
    if key[pygame.K_LEFT]: 
     hero.left() 
    if key[pygame.K_RIGHT]: 
     hero.right() 
    if key[pygame.K_UP]: 
     hero.up() 
    if key[pygame.K_DOWN]: 
     hero.down() 

    sprites_list.update() 

    screen.fill(white) 
    sprites_list.draw(screen) 
    # If you use solution 1, you don't need the draw method, since 
    # sprites_list.draw blits the image already. 
    hero.draw(screen) 
    screen.blit(hero_img, (100, 100)) 

    pygame.display.flip() 
    clock.tick(60) 

我已經改變了幾件事:speed可能是精靈的屬性,你可以通過與座標元組到__init__方法,然後把它傳遞給get_rect爲centertopleft的說法。

self.image.get_rect(center=position)