国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Python Pygame實現俄羅斯方塊

瀏覽:4日期:2022-06-27 16:20:36

本文實例為大家分享了Python Pygame實現俄羅斯方塊的具體代碼,供大家參考,具體內容如下

源碼:

# coding : utf-8#: pip install pygameimport randomimport sysimport pygame#: 顏色定義COLOR_WHITE = (255, 255, 255)COLOR_BLACK = (0, 0, 0)class Block: '''小塊''' width = 24 height = 24 @staticmethod def draw(s, left, top, color, bg_color): pygame.draw.rect(s, bg_color, pygame.Rect(left, top, Block.width, Block.height)) pygame.draw.rect(s, color, pygame.Rect(left, top, Block.width - 1, Block.height - 1))class Building: '''積木''' def __init__(self): ''' 方塊的7種基本形狀 每次初始化隨機選擇一個形狀 @:return True / False ''' self.form = random.choice( [ [ [0, 0, 0, 0, 0], [0, 0, 1, 0, 0], [0, 1, 1, 1, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [1, 1, 1, 1, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 1, 1, 0, 0], [0, 0, 1, 1, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 0, 1, 1, 0], [0, 1, 1, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 1, 1, 0, 0], [0, 0, 1, 0, 0], [0, 0, 1, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 0, 1, 1, 0], [0, 0, 1, 0, 0], [0, 0, 1, 0, 0], [0, 0, 0, 0, 0] ], [ [0, 0, 0, 0, 0], [0, 1, 1, 0, 0], [0, 1, 1, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0] ] ]) def __getitem__(self, pos): return self.form[pos] def __setitem__(self, key, value): self.form[key] = valueclass Layout: '''棋盤''' def __init__(self): self.block_x_count = 16; self.block_y_count = 22; self.layout = [[0 if 1 < i < self.block_x_count - 2 and j < self.block_y_count - 2 else 1 for i in range(self.block_x_count)] for j in range(self.block_y_count)] @property def size(self): '''返回棋盤屏幕大小(width,height)''' return (self.block_x_count * Block.width, self.block_y_count * Block.height) def create_new_building(self): ''' 創建新的積木,初始化位置為第5,0格, 速度為4 :return: 返回是否無空間創建了 ''' self.building = Building() self.building_left, self.building_top = 5, 0 # self.drop_speed = 3 print(self.test_building_touch_wall()) return self.test_building_touch_wall() @property def speed(self): return self.drop_speed def test_building_touch_wall(self, x_offset=0, y_offset=0): ''' 積木是否已經觸底/墻壁 具體操作: 判斷積木最后一排的1,是否在當前棋牌對應的位置是也是1 @:param x_offset: x的偏移量 移動時可以傳入1/-1來判斷 @:param y_offset: y的偏移量 正常下落時可以傳入1來判斷 ''' for i in range(4, -1, -1): for j in range(5): if self.building[i][j]: if self.layout[i + self.building_top + y_offset][j + self.building_left + x_offset]: return True return False def move_left_right(self, x): ''' 左右移動 @:param x: 移動量 x_offset ''' #: 移動時不能撞墻 if not self.test_building_touch_wall(x_offset=x): self.building_left += x def down_build(self): ''' 盒子的自動下移 ''' self.building_top += 1 def direct_down(self): ''' 手動快速降落 ''' self.drop_speed = 50 def convert_building(self): ''' * 扭轉盒子的總方位 (右轉) 具體操作: 把第一豎排的倒序給第一橫排的 把第二豎排的倒序給第二橫排的 后面同理. ''' new_box = [[0 for i in range(5)] for j in range(5)] for i in range(5): for j in range(4, -1, -1): new_box[i][j] = self.building[4 - j][i] self.building = new_box def clear_full_lines(self): '''消除滿行的所有行''' new_layout = [[0 if 1 < i < self.block_x_count - 2 and j < self.block_y_count - 2 else 1 for i in range(self.block_x_count)] for j in range(self.block_y_count)] row_len = self.block_x_count - 4 new_row = self.block_y_count - 2 - 1 for cur_row in range(self.block_y_count - 2 - 1, 0, -1): if sum(self.layout[cur_row][2:self.block_x_count - 2]) < row_len: new_layout[new_row] = self.layout[cur_row] new_row -= 1 self.layout = new_layout def put_building_to_layout(self): '''將積木放到棋盤里''' for i in range(4, -1, -1): for j in range(5): if self.building[i][j]: self.layout[i + self.building_top][j + self.building_left] = 1 #: 這里會調用消除函數 self.clear_full_lines() def draw_building(self, s): ''' 顯示積木 @:param s : pygame = screen ''' cur_left, cur_top = self.building_left * Block.width, self.building_top * Block.height for i in range(5): for j in range(5): # 只畫積木實體,不管盒子本身 if self.building[j][i]: Block.draw(s, cur_left + i * Block.width, cur_top + j * Block.height, COLOR_BLACK, COLOR_WHITE) def draw(self, s): ''' 顯示棋盤 @:param s : pygame = screen ''' for i in range(self.block_x_count): for j in range(self.block_y_count): if self.layout[j][i] == 0: Block.draw(s, i * Block.width, j * Block.height, COLOR_WHITE, COLOR_BLACK) else: Block.draw(s, i * Block.width, j * Block.height, COLOR_BLACK, COLOR_WHITE)# -------------------------------------------------------------------# Main# -------------------------------------------------------------------def main(): #: 初始化 while True: layout = Layout() layout.create_new_building() pygame.init() pygame.display.set_caption(’俄羅斯方塊’) screen = pygame.display.set_mode((layout.size), 0, 32) is_over = False #: 單局游戲循環開始 [結束后直接重新開始] while not is_over: #: 處理游戲消息 for e in pygame.event.get(): if e.type == pygame.QUIT: sys.exit() #: 處理按鍵 if e.type == pygame.KEYDOWN: if e.key == pygame.K_UP: layout.convert_building() if e.key == pygame.K_DOWN: layout.direct_down() if e.key == pygame.K_LEFT: layout.move_left_right(-1) if e.key == pygame.K_RIGHT: layout.move_left_right(1) #: 是否碰觸底部地面了,是 -> 融合背景 否 -> 繼續下落 if layout.test_building_touch_wall(y_offset=1): layout.put_building_to_layout() is_over = layout.create_new_building() else: layout.down_build() #: 繪制 layout.draw(screen) layout.draw_building(screen) pygame.display.update() #: 速度 pygame.time.Clock().tick(layout.speed)if __name__ == ’__main__’: main()

效果:

Python Pygame實現俄羅斯方塊

更多俄羅斯方塊精彩文章請點擊專題:俄羅斯方塊游戲集合 進行學習。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 日本亚洲欧美高清专区vr专区 | 99精品网 | 亚洲精品久久九九精品 | 国语精品视频在线观看不卡 | 一级aaaaa毛片免费视频 | 国产黄色自拍视频 | 在线亚洲精品自拍 | 久久在线精品 | 欧美一区二区日韩一区二区 | 欧美成年人视频 | 亚洲精品一 | 国产区香蕉精品系列在线观看不卡 | 日韩高清欧美 | 日韩在线视频不卡一区二区三区 | 成人毛片在线视频 | 欧美三级在线视频 | 久久国产精品二区99 | 一级美国片免费看 | 亚洲国产欧美在线不卡中文 | 国产亚洲午夜精品a一区二区 | 亚洲男人天堂2017 | 亚洲精品成人 | 成人a级| 一区在线看 | 娇喘嗯嗯~轻点啊视频福利 | 欧美日韩综合精品一区二区三区 | 久久欧美久久欧美精品 | 色播亚洲| 看欧美毛片一级毛片 | 日本一级特黄aa毛片免费观看 | 伊人久久在线视频 | 色偷偷成人 | 99久久视频 | 乱子伦一级在线现看 | 国内主播福利视频在线观看 | 日本国产一区二区三区 | 亚洲国产精品第一区二区 | 福利社色 | 草草影院第一页yycccom | 97在线视频免费播放 | 欧美一级俄罗斯黄毛片 |