<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
大家以前應該都聽說過一個遊戲:叫做走四棋兒
這款遊戲出來到現在時間挺長了,小時候的家鄉農村條件有限,附近也沒有正式的玩具店能買到玩具,因此小朋友們聚在一起玩耍時,其玩具大多都是就地取材的。
直接在家裡的水泥地上用燒完的炭火灰畫出幾條線,擺上幾顆石頭子即可。當時的火爆程度可謂是達到了一個新的高度。包括我當時也比較喜歡這款遊戲。因為時間推移,小時候很多遊戲都已經在現在這個時代看不到啦!
今天小編就帶大家追憶童年——一起敲一敲《走四棋兒》小遊戲,你小時候還玩兒過那些遊戲呢?(抓石頭、跳繩、丟手絹兒 .......捂臉.jpg)
“走四兒”大部分活躍在山東濟南、聊城、菏澤等地,是一種棋類遊戲,特別適合兒童試玩。
在一個4×4的棋盤上,雙方各有4子,分別擺放在棋盤兩個最上面的兩端線的四個位置上。下圖
就是“走四兒”開局的樣子。
“走四兒”的遊戲規則是:
1.雙方輪流走,每一步只能在上下左右中的一個無子的方向上走一個格,不能斜走。如果一方無法移動,則由另一方走。
2.當甲方的一個子移動到一條線上之後,這條線上只有甲方的兩個子和乙方的一個子,且甲方的這兩子相連,乙方的子與甲方那兩子中的一個子相連,那麼乙方的這個子就被吃掉。
下圖是可以吃子的樣式例舉:
3.少於2個子的一方為輸者。雙方都無法勝對方就可以認為是和棋。
1)素材(圖片)
2)執行環境 小編使用的環境:Python3、Pycharm社群版、Pygame、 numpy模組部分自帶就不一一 展示啦。
模組安裝:pip install -i https://pypi.douban.com/simple/+模組名
import pygame as pg from pygame.locals import * import sys import time import numpy as np pg.init() size = width, height = 600, 400 screen = pg.display.set_mode(size) f_clock = pg.time.Clock() fps = 30 pg.display.set_caption("走四棋兒") background = pg.image.load("background.png").convert_alpha() glb_pos = [[(90, 40), (190, 40), (290, 40), (390, 40)], [(90, 140), (190, 140), (290, 140), (390, 140)], [(90, 240), (190, 240), (290, 240), (390, 240)], [(90, 340), (190, 340), (290, 340), (390, 340)]] class ChessPieces(): def __init__(self, img_name): self.name = img_name self.id = None if self.name == 'heart': self.id = 2 elif self.name == 'spade': self.id = 3 self.img = pg.image.load(img_name + ".png").convert_alpha() self.rect = self.img.get_rect() self.pos_x, self.pos_y = 0, 0 self.alive_state = True def get_rect(self): return (self.rect[0], self.rect[1]) def get_pos(self): return (self.pos_x, self.pos_y) def update(self): if self.alive_state == True: self.rect[0] = glb_pos[self.pos_y][self.pos_x][0] self.rect[1] = glb_pos[self.pos_y][self.pos_x][1] screen.blit(self.img, self.rect) class Pointer(): def __init__(self): self.img = pg.image.load("pointer.png").convert_alpha() self.rect = self.img.get_rect() self.show = False self.selecting_item = False def point_to(self, Heart_Blade_class): if Heart_Blade_class.alive_state: self.pointing_to_item = Heart_Blade_class self.item_pos = Heart_Blade_class.get_rect() self.rect[0], self.rect[1] = self.item_pos[0], self.item_pos[1] - 24 def update(self): screen.blit(self.img, self.rect) class GlobalSituation(): def __init__(self): self.glb_situation = np.array([[2, 2, 2, 2], [0, 0, 0, 0], [0, 0, 0, 0], [3, 3, 3, 3]], dtype=np.uint8) self.spade_turn = None def refresh_situation(self): self.glb_situation = np.zeros([4, 4], np.uint8) for i in range(4): if heart[i].alive_state: self.glb_situation[heart[i].pos_y, heart[i].pos_x] = heart[i].id for i in range(4): if spade[i].alive_state: self.glb_situation[spade[i].pos_y, spade[i].pos_x] = spade[i].id for i in range(4): print(self.glb_situation[i][:]) print('=' * 12) if self.spade_turn != None: self.spade_turn = not self.spade_turn def check_situation(self, moved_item): curr_pos_x, curr_pos_y = moved_item.get_pos() curr_pos_col = self.glb_situation[:, curr_pos_x] curr_pos_raw = self.glb_situation[curr_pos_y, :] enemy_die = False if moved_item.id == 2: if np.sum(curr_pos_col) == 7: if (curr_pos_col == np.array([0, 2, 2, 3])).all(): enemy_die = True self.glb_situation[3, curr_pos_x] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == curr_pos_x and spade_i.pos_y == 3: spade_i.alive_state = False elif (curr_pos_col == np.array([2, 2, 3, 0])).all(): enemy_die = True self.glb_situation[2, curr_pos_x] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == curr_pos_x and spade_i.pos_y == 2: spade_i.alive_state = False elif (curr_pos_col == np.array([0, 3, 2, 2])).all(): enemy_die = True self.glb_situation[1, curr_pos_x] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == curr_pos_x and spade_i.pos_y == 1: spade_i.alive_state = False elif (curr_pos_col == np.array([3, 2, 2, 0])).all(): enemy_die = True self.glb_situation[0, curr_pos_x] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == curr_pos_x and spade_i.pos_y == 0: spade_i.alive_state = False if np.sum(curr_pos_raw) == 7: if (curr_pos_raw == np.array([0, 2, 2, 3])).all(): enemy_die = True self.glb_situation[curr_pos_y, 3] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == 3 and spade_i.pos_y == curr_pos_y: spade_i.alive_state = False elif (curr_pos_raw == np.array([2, 2, 3, 0])).all(): enemy_die = True self.glb_situation[curr_pos_y, 2] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == 2 and spade_i.pos_y == curr_pos_y: spade_i.alive_state = False elif (curr_pos_raw == np.array([0, 3, 2, 2])).all(): enemy_die = True self.glb_situation[curr_pos_y, 1] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == 1 and spade_i.pos_y == curr_pos_y: spade_i.alive_state = False elif (curr_pos_raw == np.array([3, 2, 2, 0])).all(): enemy_die = True self.glb_situation[curr_pos_y, 0] = 0 for spade_i in spade: if spade_i.alive_state and spade_i.pos_x == 0 and spade_i.pos_y == curr_pos_y: spade_i.alive_state = False elif moved_item.id == 3: if np.sum(curr_pos_col) == 8: if (curr_pos_col == np.array([0, 3, 3, 2])).all(): enemy_die = True self.glb_situation[3, curr_pos_x] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == curr_pos_x and heart_i.pos_y == 3: heart_i.alive_state = False elif (curr_pos_col == np.array([3, 3, 2, 0])).all(): enemy_die = True self.glb_situation[2, curr_pos_x] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == curr_pos_x and heart_i.pos_y == 2: heart_i.alive_state = False elif (curr_pos_col == np.array([0, 2, 3, 3])).all(): enemy_die = True self.glb_situation[1, curr_pos_x] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == curr_pos_x and heart_i.pos_y == 1: heart_i.alive_state = False elif (curr_pos_col == np.array([2, 3, 3, 0])).all(): enemy_die = True self.glb_situation[0, curr_pos_x] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == curr_pos_x and heart_i.pos_y == 0: heart_i.alive_state = False if np.sum(curr_pos_raw) == 8: if (curr_pos_raw == np.array([0, 3, 3, 2])).all(): enemy_die = True self.glb_situation[curr_pos_y, 3] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == 3 and heart_i.pos_y == curr_pos_y: heart_i.alive_state = False elif (curr_pos_raw == np.array([3, 3, 2, 0])).all(): enemy_die = True self.glb_situation[curr_pos_y, 2] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == 2 and heart_i.pos_y == curr_pos_y: heart_i.alive_state = False elif (curr_pos_raw == np.array([0, 2, 3, 3])).all(): enemy_die = True self.glb_situation[curr_pos_y, 1] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == 1 and heart_i.pos_y == curr_pos_y: heart_i.alive_state = False elif (curr_pos_raw == np.array([2, 3, 3, 0])).all(): enemy_die = True self.glb_situation[curr_pos_y, 0] = 0 for heart_i in heart: if heart_i.alive_state and heart_i.pos_x == 0 and heart_i.pos_y == curr_pos_y: heart_i.alive_state = False if enemy_die == True: self.glb_situation = np.zeros([4, 4], np.uint8) for i in range(4): if heart[i].alive_state: self.glb_situation[heart[i].pos_y, heart[i].pos_x] = heart[i].id for i in range(4): if spade[i].alive_state: self.glb_situation[spade[i].pos_y, spade[i].pos_x] = spade[i].id for i in range(4): print(self.glb_situation[i][:]) print('=' * 12) def check_game_over(self): heart_alive_num, spade_alive_num = 0, 0 for heart_i in heart: if heart_i.alive_state: heart_alive_num += 1 for spade_i in spade: if spade_i.alive_state: spade_alive_num += 1 if heart_alive_num <= 1: print('Spades win!') GlobalSituation.__init__(self) Pointer.__init__(self) chess_pieces_init() if spade_alive_num <= 1: print('Hearts win!') GlobalSituation.__init__(self) Pointer.__init__(self) chess_pieces_init() heart, spade = [None] * 4, [None] * 4 for i in range(4): heart[i] = ChessPieces('heart') spade[i] = ChessPieces('spade') def chess_pieces_init(): for i in range(4): heart[i].pos_y, heart[i].pos_x = 0, i spade[i].pos_y, spade[i].pos_x = 3, i heart[i].alive_state = True spade[i].alive_state = True chess_pieces_init() pointer = Pointer() situation = GlobalSituation() def check_click_item(c_x, c_y): selected_item = None if situation.spade_turn==None: for heart_i in heart: if heart_i.alive_state and heart_i.rect.collidepoint(c_x, c_y): situation.spade_turn = False selected_item = heart_i for spade_i in spade: if spade_i.alive_state and spade_i.rect.collidepoint(c_x, c_y): situation.spade_turn = True selected_item = spade_i else: if situation.spade_turn: for spade_i in spade: if spade_i.alive_state and spade_i.rect.collidepoint(c_x, c_y): selected_item = spade_i else: for heart_i in heart: if heart_i.alive_state and heart_i.rect.collidepoint(c_x, c_y): selected_item = heart_i return selected_item def move_to_dst_pos(selected_item, c_x, c_y): update_situation = False enemy_exist = False if selected_item.name == 'heart': for spade_i in spade: if spade_i.rect.collidepoint(c_x, c_y) and spade_i.alive_state: enemy_exist = True elif selected_item.name == 'spade': for heart_i in heart: if heart_i.rect.collidepoint(c_x, c_y) and heart_i.alive_state: enemy_exist = True if enemy_exist == False: delta_y, delta_x = c_y - selected_item.rect[1], c_x - selected_item.rect[0] if 80 <= abs(delta_x) <= 120 and abs(delta_y) <= 20: if delta_x < 0: if selected_item.pos_x > 0: selected_item.pos_x -= 1 else: if selected_item.pos_x < 3: selected_item.pos_x += 1 update_situation = True if 80 <= abs(delta_y) <= 120 and abs(delta_x) <= 20: if delta_y < 0: if selected_item.pos_y > 0: selected_item.pos_y -= 1 else: if selected_item.pos_y < 3: selected_item.pos_y += 1 update_situation = True return update_situation while True: for event in pg.event.get(): if event.type == pg.QUIT: sys.exit() elif event.type == pg.MOUSEBUTTONDOWN: cursor_x, cursor_y = pg.mouse.get_pos() clicked_item = check_click_item(cursor_x, cursor_y) if clicked_item != None: pointer.selecting_item = True pointer.point_to(clicked_item) else: if pointer.selecting_item: update_situation_flag = move_to_dst_pos(pointer.pointing_to_item, cursor_x, cursor_y) if update_situation_flag: situation.refresh_situation() situation.check_situation(pointer.pointing_to_item) situation.check_game_over() pointer.selecting_item = False screen.blit(background, (0, 0)) for heart_i in heart: heart_i.update() for spade_i in spade: spade_i.update() if pointer.selecting_item: pointer.update() f_clock.tick(fps) pg.display.update()
是不是效果跟上面的範例圖很像啦~棋子效果太死板啦!感覺會更加好看點兒撒!小編只是把雙方的棋子換成了紅心
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45