一文詳解pygame.sprite的精靈碰撞
前言
pygame中的精靈碰撞是可見游戲中用的最基礎(chǔ)的東西,這里結(jié)合官方文檔和小甲魚的網(wǎng)站上的內(nèi)容做個小總結(jié),方便日后使用。
pygame.sprite.Sprite - 可見游戲?qū)ο蟮暮唵位悺?/h2>
Sprite(*groups) -> Sprite
- pygame.sprite.Sprite.add - 將精靈添加到組中
- pygame.sprite.Sprite.remove - 從組中刪除精靈
- pygame.sprite.Sprite.kill - 從所有組中刪除Sprite
- pygame.sprite.Sprite.alive - 精靈屬于任何組的檢測
- pygame.sprite.Sprite.groups - 包含此Sprite的組列表
- pygame.sprite.Sprite.update - 控制精靈行為的方法
Sprite(*groups) -> Sprite
pygame.sprite.Group - 用于保存和管理多個 Sprite 對象的容器類。
Group(*sprites) -> Group
- pygame.sprite.Group.sprites - 此組包含的 Sprite 列表
- pygame.sprite.Group.copy - 復(fù)制組
- pygame.sprite.Group.add - 將 Sprite 添加到此組
- pygame.sprite.Group.remove - 從組中刪除 Sprite
- pygame.sprite.Group.has - 測試一個 Group 是否包含 Sprite
- pygame.sprite.Group.update - 在包含的 Sprite 上調(diào)用 update 方法
- pygame.sprite.Group.draw - blit Sprite 的圖像
- pygame.sprite.Group.clear - 在 Sprites 上繪制背景
- pygame.sprite.Group.empty - 刪除所有 Sprite`
上面兩個基類是pygame中最常用,相當(dāng)輕量級,只為大多數(shù)游戲常見的代碼提供了一個起始點。
Sprite 類旨在用作游戲中不同類型對象的基類,為我們碰撞檢測做準(zhǔn)備。還有一個基本的 Group 類,它只存儲 sprite 對象, 這樣方便不同類型的精靈進(jìn)行碰撞檢測, 通常的操作 in / len / bool / iter 都對這個group使用。
in test if a Sprite is contained len the number of Sprites contained bool test if any Sprites are contained iter iterate through all the Sprites
pygame.sprite.spritecollide() - 在與另一個精靈相交的組中查找精靈
spritecollide(sprite, group, dokill, collided = None) -> Sprite_list
- 返回一個sprite列表,其中包含與另一個 Sprite 相交的 Group 中的所有 Sprite 。 通過比較每個 Sprite 的 Sprite.rect 屬性來確定交集。
- dokill 參數(shù)是一個布爾值。如果設(shè)置為 True,則將從組中刪除所有碰撞的 Sprite 。
- collided 碰撞參數(shù)是一個回調(diào)函數(shù),用于計算兩個精靈是否發(fā)生碰撞。 它應(yīng)該將兩個精靈作為值,并返回一個 bool 值,指示它們是否發(fā)生碰撞。 如果未傳遞碰撞,則所有精靈必須具有 rect 值,該值是 sprite 區(qū)域的矩形,將用于計算碰撞。
可用的回調(diào)函數(shù)
collide_rect, collide_rect_ratio, collide_circle, collide_circle_ratio, collide_mask
- pygame.sprite.collide_rect - 使用 rects 檢測兩個精靈之間的碰撞。
- Collision detection between two sprites, using rects. 使用函數(shù)pygame rect colliderect檢測碰撞并將結(jié)果返回給*collide, 精靈必須具有 ‘rect’ 屬性。
collide_rect(left, right) -> bool
- pygame.sprite.collide_rect_ratio - 使用按比例縮放的 rects 檢測兩個精靈之間的碰撞。
- Collision detection between two sprites, using rects scaled to a ratio. 使用 ratio 創(chuàng)建,然后將實例作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。
ratio 是浮點數(shù) - 1.0 是相同的大小,2.0 是兩倍大,0.5 是大小的一半。
- Collision detection between two sprites, using rects scaled to a ratio. 使用 ratio 創(chuàng)建,然后將實例作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。
collide_rect_ratio(ratio) -> collided_callable
- pygame.sprite.collide_circle - 使用圓圈檢測兩個精靈之間的碰撞。
- *Collision detection between two sprites, using circles.*測試兩個精靈之間的碰撞,通過測試以查看精靈中心的兩個圓是否重疊。
如果精靈具有 radius(半徑) 屬性,用于創(chuàng)建圓,否則會創(chuàng)建一個足夠大的圓,以完全包圍由 rect 屬性給出的精靈矩形。作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。精靈必須具有 rect 和可選的 radius 屬性。
collide_circle(left, right) -> bool
- pygame.sprite.collide_circle_ratio - 使用按比例縮放的圓圈檢測兩個精靈之間的碰撞。
- Collision detection between two sprites, using circles scaled to a ratio. 使用浮點數(shù) ratio 創(chuàng)建,然后將實例作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。ratio 是浮點數(shù) - 1.0 是相同的大小,2.0 是兩倍大,0.5 是大小的一半。
兩個精靈之間的碰撞創(chuàng)建的可調(diào)用測試,通過測試以查看以精靈為中心的兩個圓是否重疊,在通過存儲的比例縮放圓半徑之后。如果精靈具有 radius 半徑屬性,用于創(chuàng)建圓,否則會創(chuàng)建一個足夠大的圓,以完全包圍由 rect 屬性給出的精靈矩形。打算作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。
精靈必須具有 rect 和可選的 radius 屬性。
collide_circle_ratio(ratio) -> collided_callable
- pygame.sprite.collide_mask - 使用蒙版在兩個精靈之間進(jìn)行碰撞檢測。
- *Collision detection between two sprites, using masks. *返回 masks 碰撞的 mask 上的第一個點,如果沒有碰撞,則返回 None 。
通過測試它們的 bitmasks( pygame.mask.Mask.overlap()
) 是否重疊來測試兩個精靈之間的碰撞。 如果精靈具有 mask 屬性,該屬性用作 mask,否則將從精靈圖像創(chuàng)建 mask 。 作為碰撞回調(diào)函數(shù)傳遞給 *collide 函數(shù)。
精靈必須具有 rect 和可選的 mask 屬性。
如果要多次檢查碰撞,應(yīng)該考慮在加載時為精靈創(chuàng)建一個mask。這將提高性能,否則這可能是一個昂貴的功能,因為它會在每次檢查碰撞時創(chuàng)建 mask 。
# Example of mask creation for a sprite. sprite.mask = pygame.mask.from_surface(sprite.image)
collide_mask(sprite1, sprite2) -> (int, int)
collide_mask(sprite1, sprite2) -> None
pygame.sprite.groupcollide - 查找在兩個組之間發(fā)生碰撞的所有精靈。
- Find all sprites that collide between two groups.
- This will find collisions between all the Sprites in two groups. Collision is determined by comparing the
Sprite.rect
attribute of each Sprite or by using the collided function if it is not None.
Every Sprite inside group1 is added to the return dictionary. The value for each item is the list of Sprites in group2 that intersect. 像這個格式{group1_sprite: group2_sprite} - 如果*collide沒有指定回調(diào)函數(shù),則所有的sprite需要有rect屬性
groupcollide(group1, group2, dokill1, dokill2, collided = None) -> Sprite_dict
EG: class Block(pygame.sprite.Sprite): # Constructor. Pass in the color of the block, # and its x and y position def __init__(self, color, width, height): # Call the parent class (Sprite) constructor pygame.sprite.Sprite.__init__(self) # Create an image of the block, and fill it with a color. # This could also be an image loaded from the disk. self.image = pygame.Surface([width, height]) self.image.fill(color) # Fetch the rectangle object that has the dimensions of the image # Update the position of this object by setting the values of rect.x and rect.y # give radius and mask attribute self.rect = self.image.get_rect() self.radius = self.rect.width / 2 self.mask = pygame.image.from_surface(self.image) class File(pygame.sprite.Sprite): # Constructor. Pass in the color of the block, # and its x and y position def __init__(self, color, width, height): # Call the parent class (Sprite) constructor pygame.sprite.Sprite.__init__(self) # Create an image of the block, and fill it with a color. # This could also be an image loaded from the disk. self.image = pygame.Surface([width, height]) self.image.fill(color) # Fetch the rectangle object that has the dimensions of the image # Update the position of this object by setting the values of rect.x and rect.y self.rect = self.image.get_rect() self.radius = self.rect.width / 2 self.mask = pygame.image.from_surface(self.image) block_group = pygame.sprite.Group() for i in range(5): block = Block(color, width, height) block_group.add(block) # there is another sprite group called file_group, which have same setting as block_group. file_group = pygame.sprite.Group() for i in range(5): file = File(color, width, height) file_group.add(file) # the collide check will like: hit_list1 = pygame.sprite.spritecollide(block, file_group, False, pygame.sprite.collide_rect hit_list2 = pygame.sprite.spritecollide(block, file_group, False, pygame.sprite.collide_rect_ratio(.75)) hit_list3 = pygame.sprite.spritecollide(block, file_group, False, pygame.sprite.collide_circle hit_list4 = pygame.sprite.spritecollide(block, file_group, False, pygame.sprite.collide_circle_ratio(.25)) hit_list5 = pygame.sprite.spritecollide(block, file_group, False, pygame.sprite.collide_mask # select the collided function whatever you like hit_list6 = pygame.sprite.spritecollide(block_group, file_group, False, False, pygame.sprite.collide_XXX)
總結(jié)
到此這篇關(guān)于pygame.sprite精靈碰撞的文章就介紹到這了,更多相關(guān)pygame.sprite精靈碰撞內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python微服務(wù)開發(fā)之使用FastAPI構(gòu)建高效API
微服務(wù)架構(gòu)在現(xiàn)代軟件開發(fā)中日益普及,它將復(fù)雜的應(yīng)用程序拆分成多個可獨立部署的小型服務(wù)。本文將介紹如何使用 Python 的 FastAPI 庫快速構(gòu)建和部署微服務(wù),感興趣的可以了解一下2023-05-05python GUI庫圖形界面開發(fā)之PyQt5樹形結(jié)構(gòu)控件QTreeWidget詳細(xì)使用方法與實例
這篇文章主要介紹了python GUI庫圖形界面開發(fā)PyQt5樹形結(jié)構(gòu)控件QTreeWidget詳細(xì)使用方法與實例,需要的朋友可以參考下2020-03-03python簡單幾步獲取各種DOS命令顯示的內(nèi)容詳解流程
你會用python獲取各種DOS命令顯示的內(nèi)容核心嗎?說的可不是返回值,是用system()函數(shù)調(diào)用windows操作系統(tǒng)的DOS命令來做點事情,需要的朋友可以參考下2021-10-10Python實現(xiàn)學(xué)生信息管理系統(tǒng)的示例代碼
夏天是用來告別的季節(jié),因為畢業(yè)總在七月。那么七月之前的季節(jié)是用來干嘛的呢?當(dāng)然是用來做畢業(yè)設(shè)計的啦!本文為大家準(zhǔn)備了兩個版本的學(xué)生信息管理系統(tǒng),希望對大家有所幫助2023-02-02python交互模式基礎(chǔ)知識點學(xué)習(xí)
在本篇內(nèi)容里小編給大家整理的是關(guān)于python交互模式是什么的相關(guān)基礎(chǔ)知識點,需要的朋友們可以參考下。2020-06-06