亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > python實現(xiàn)雙人貪吃蛇小游戲

python實現(xiàn)雙人貪吃蛇小游戲

熱門標(biāo)簽:旅游廁所地圖標(biāo)注怎么弄 南昌地圖標(biāo)注 電梯新時達系統(tǒng)外呼顯示e 宿州電話機器人哪家好 成都呼叫中心外呼系統(tǒng)哪家強 地圖標(biāo)注與注銷 百應(yīng)電話機器人總部 無錫智能外呼系統(tǒng)好用嗎 西青語音電銷機器人哪家好

小編今天要給大家分享的是雙人貪吃蛇,大家可以和自己的兄弟,姐妹,爸爸,媽媽等一起玩喲!我先介紹一下游戲:

運行游戲,進入初始界面,按下空格鍵。

玩家(1):w,a,s,d

玩家(2):↑,←,↓,→

玩家要爭奪7個實物,直到吃完為止

游戲結(jié)束。

下面是小編寫的代碼:

import math
import random
import pygame
from pygame.locals import *
 
running = False
playing = False
screen = None
timer = None
snk1 = None
snk2 = None
foods = None
remainFoods = 7
radiusFood = 8
 
'''
鏈表節(jié)點
'''
class Node:
    def __init__(self, data, prev = None, next = None):
        self.data = data
        self.prev = prev
        self.next = next
 
    def insert_front(self, node):
        if self.prev:
            node.prev = self.prev
            self.prev.next = node
            self.prev = node
            node.next = self
        else:
            self.prev = node
            node.next = self
        return node
 
    def insert_back(self, node):
        if self.next:
            node.next = self.next
            self.next.prev = node
            self.next = node
            node.prev = self
        else:
            self.next = node
            node.prev = self
        return node
    
    def remove(self):
        if self.next:
            self.next.prev = self.prev
        if self.prev:
            self.prev.next = self.next
 
'''
蛇
'''
class Snack:
 
    def __init__(self, surface, color, start_pos, end_pos, face):
        self.color = color
        self.surface = surface
        self.head = Node(start_pos)
        self.tail = Node(end_pos)
        self.head.insert_back(self.tail)
        self.length = self.distanceBetween(start_pos, end_pos)
        self.face = face
        self.speed = 120
        self.eat = 0
        self.grow = 0
        self.mapAngle = [
            [0, math.pi * 3 / 2, math.pi / 2],
            [0, math.pi * 7 / 4, math.pi / 4],
            [math.pi, math.pi * 5 / 4, math.pi * 3 / 4]
        ]
 
    '''坐標(biāo)取整'''
    def intPos(self, pos):
        return (int(pos[0]), int(pos[1]))
 
    '''坐標(biāo)轉(zhuǎn)角度'''
    def pos2Angle(self, pos):
        return self.mapAngle[pos[0]][pos[1]]
 
    '''極坐標(biāo)位移'''
    def polarPos(self, pos, angle, dis):
        xx = pos[0] + dis * math.cos(angle)
        yy = pos[1] + dis * math.sin(angle)
        return (xx, yy)
 
    '''計算兩點間距離'''
    def distanceBetween(self, pos1, pos2):
        dx = pos2[0] - pos1[0]
        dy = pos2[1] - pos1[1]
        return math.sqrt(dx*dx + dy*dy)
    
    '''計算兩點間角度'''
    def angleBetween(self, pos1, pos2):
        dx = pos2[0] - pos1[0]
        dy = pos2[1] - pos1[1]
        return math.atan2(dy, dx)
 
    '''改變面向'''
    def changeFace(self, newFace):
        if newFace[0] == 0 and newFace[1] == 0:
            return
        if newFace == self.face:
            return
        xx = self.face[0] + newFace[0]
        yy = self.face[1] + newFace[1]
        if xx == 0 and yy == 0:
            return
        self.face = newFace
        self.head = self.head.insert_front(Node(self.head.data))
 
    '''吃到食物'''
    def eatFood(self, grow):
        self.grow = grow
        self.eat += 1
 
    '''繪制蛇身'''
    def draw(self):
        node = self.head
        pygame.draw.circle(self.surface, self.color, self.intPos(node.data), 6, 6)
        while node:
            n2 = node.next 
            if not n2:
                break
            pygame.draw.line(self.surface, self.color, self.intPos(node.data), self.intPos(n2.data), 6)
            node = node.next
    
    '''每幀移動'''
    def walk(self, delta):
        dis = self.speed * delta / 1000
        self.head.data = self.polarPos(self.head.data, self.pos2Angle(self.face), dis)
        if self.grow >= dis:
            self.grow -= dis
        else:
            dis -= self.grow
            self.grow = 0
            self.cutTail(dis)
    
    '''收縮尾巴'''
    def cutTail(self, length):
        node = self.tail
        while length > 0:
            n2 = node.prev
            dis = self.distanceBetween(n2.data, node.data)
            angle = self.angleBetween(node.data, n2.data)
            if dis > length:
                node.data = self.polarPos(node.data, angle, length)
                length = 0
            else:
                self.tail = node.prev
                node.remove()
                length -= dis
 
            node = node.prev
 
'''屏幕指定位置繪制文字'''
def printText(surface, str, pos, size = 24, color = (255, 255, 255)):
    global screen
    font = pygame.font.SysFont("microsoftyaheimicrosoftyaheiui", size)
    text = font.render(str, True, color)
    w = text.get_width()
    h = text.get_height()
    surface.blit(text, (pos[0] - w / 2, pos[1] - h / 2))
 
'''添加食物'''
def addFood():
    global screen, snk1, snk2, foods, remainFoods
    if remainFoods = 0:
        return
    w = screen.get_width()
    h = screen.get_height()
    while True:
        posX = random.randint(5, w - 5)
        posY = random.randint(5, h - 5)
        color = tuple(screen.get_at((posX, posY)))
        if color != snk1.color and color != snk2.color:
            break
    remainFoods -= 1
    if not foods:
        foods = Node((posX, posY))
    else:
        foods = foods.insert_front(Node((posX, posY)))
 
'''刪除食物'''
def removeFood(node):
    global foods
    if node == foods:
        foods = foods.next
    else:
        node.remove()
 
'''檢測吃到食物'''
def checkEatFood():
    global foods, radiusFood, snk1, snk2
    node = foods
    while node:
        if snk1.distanceBetween(snk1.head.data, node.data)  (radiusFood + 4):
            snk1.eatFood(50)
            removeFood(node)
            addFood()
            break
        elif snk2.distanceBetween(snk2.head.data, node.data)  (radiusFood + 4):
            snk2.eatFood(50)
            removeFood(node)
            addFood()
            break
        else:
            node = node.next
 
'''游戲初始界面'''
def logo():
    global screen, remainFoods
    w = screen.get_width()
    h = screen.get_height()
    printText(screen, "Snack V1.0", (w / 2, h / 3), 48)
    printText(screen, "任意鍵繼續(xù)", (w / 2, h / 2), 24, (55, 255, 55))
    printText(screen, str(remainFoods) + "個食物,搶完即止", (w / 2, h * 2 / 3), 32)
    
def quit():
    pygame.font.quit()
 
'''檢測游戲結(jié)束'''
def checkGameOver():
    global remainFoods, snk1, snk2, foods, playing, screen
    if remainFoods == 0 and foods == None:
        playing = False
        screen.fill((0,0,0))
        w = screen.get_width()
        h = screen.get_height()
        if snk1.eat > snk2.eat:
            printText(screen, "玩家1 勝利", (w / 2, h / 2), 48)
        elif snk1.eat  snk2.eat:
            printText(screen, "玩家2 勝利", (w / 2, h / 2), 48)
        else:
            printText(screen, "平局", (w / 2, h / 2), 48)
 
'''鍵盤按鍵轉(zhuǎn)換成面向角度'''
def cmd():
    global snk1, snk2
    keys = pygame.key.get_pressed()
    x1 = x2 = y1 = y2 = 0
    if keys[pygame.K_RIGHT]:
        x2+=1
    if keys[pygame.K_LEFT]:
        x2-=1
    if keys[pygame.K_UP]:
        y2+=1
    if keys[pygame.K_DOWN]:
        y2-=1
    if keys[pygame.K_d]:
        x1+=1
    if keys[pygame.K_a]:
        x1-=1
    if keys[pygame.K_w]:
        y1+=1
    if keys[pygame.K_s]:
        y1-=1
    snk1.changeFace((x1, y1))
    snk2.changeFace((x2, y2))
 
'''游戲每幀更新'''
def play(delta):
    global playing, snk1, snk2
    if not playing:
        return
    cmd()
    snk1.walk(delta)
    snk2.walk(delta)
    checkEatFood()
    checkGameOver()
 
'''繪制'''
def draw():
    global snk1, snk2, playing, screen, radiusFood, remainFoods
    if not playing:
        return
    screen.fill((0,0,0))
    snk1.draw()
    snk2.draw()
    node = foods
    while node:
        color = (255, 255, 255)
        if remainFoods == 0:
            color = (255, 0, 0)
        pygame.draw.circle(screen, color, node.data, radiusFood, radiusFood // 2 + 1)
        node = node.next
 
def start(width = 800, height = 600, fps = 60):
    global running, screen, timer, playing, snk1, snk2
    pygame.init()
    pygame.font.init()
    font = pygame.font.SysFont("microsoftyaheimicrosoftyaheiui", 20)
    pygame.display.set_caption("Snack V1.0")
    screen = pygame.display.set_mode((width, height))
    
    logo()
    snk1 = Snack(screen, (0, 150, 200), (100, 100), (0, 100), (1, 0))
    snk2 = Snack(screen, (255, 100, 0), (width * 5 // 6, height // 2), (width * 5 // 6 + 100, height // 2), (-1, 0))
    for i in range(3):
        addFood()
 
    timer = pygame.time.Clock()
    running = True
    while running:
        delta = timer.tick(fps)
        play(delta)
        draw()
        for event in pygame.event.get():
            if event.type == pygame.QUIT:
                running = False
            elif event.type == pygame.KEYDOWN:
                if event.key == pygame.K_SPACE and playing == False:
                    screen.fill((0,0,0))
                    playing = True
 
        pygame.display.flip()
 
    
if __name__ == "__main__":
    start()
    quit()

以上就是雙人貪吃蛇的代碼啦!

教大家pygame的安裝方式

在終端輸入

pip install pyame,然后回車鍵進行安裝

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Python貪吃蛇小游戲?qū)嵗窒?/li>
  • python貪吃蛇游戲代碼
  • Python寫的貪吃蛇游戲例子
  • 使用Python寫一個貪吃蛇游戲?qū)嵗a
  • Python 實現(xiàn) 貪吃蛇大作戰(zhàn) 代碼分享
  • Python貪吃蛇游戲編寫代碼
  • 利用python實現(xiàn)簡易版的貪吃蛇游戲(面向python小白)
  • 教你一步步利用python實現(xiàn)貪吃蛇游戲
  • python實現(xiàn)貪吃蛇游戲
  • Python實現(xiàn)貪吃蛇小游戲(單人模式)

標(biāo)簽:七臺河 許昌 西安 辛集 贛州 雅安 濰坊 渭南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python實現(xiàn)雙人貪吃蛇小游戲》,本文關(guān)鍵詞  python,實現(xiàn),雙人,貪吃,蛇,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python實現(xiàn)雙人貪吃蛇小游戲》相關(guān)的同類信息!
  • 本頁收集關(guān)于python實現(xiàn)雙人貪吃蛇小游戲的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    尤物视频网站在线观看| 日本特黄特色aa大片免费| 天天做日日爱| 韩国毛片 免费| 国产成人精品一区二区视频| 国产一区二区精品久| 精品毛片视频| 久久国产精品自线拍免费| 天堂网中文字幕| 欧美激情一区二区三区视频| 国产精品免费久久| 在线观看导航| 亚洲天堂免费| 精品视频在线观看一区二区三区| 天天做日日干| 成人免费观看网欧美片| 国产高清在线精品一区a| 日本特黄特色aa大片免费| 免费一级片在线观看| 国产视频一区二区在线观看| 欧美激情一区二区三区视频| 九九热精品免费观看| 四虎影视久久| 国产精品自拍亚洲| 日韩字幕在线| 免费一级片在线观看| 成人影视在线播放| 日韩在线观看视频网站| 精品国产一区二区三区久久久狼| 精品美女| 国产一区精品| 精品国产三级a∨在线观看| 美女免费精品高清毛片在线视| 成人高清护士在线播放| 国产一区二区精品| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产精品免费久久| 欧美激情在线精品video| a级黄色毛片免费播放视频 | 黄视频网站免费观看| 日韩欧美一二三区| 亚洲精品影院| 一级毛片视频在线观看| 欧美一级视频免费| 国产a视频| 精品视频在线看| 久久精品免视看国产明星| 一级女人毛片人一女人| 精品国产香蕉在线播出| 四虎论坛| 国产欧美精品| 国产精品自拍在线| 一a一级片| 国产国语对白一级毛片| 麻豆网站在线免费观看| 精品美女| 一级毛片视频免费| 欧美18性精品| 国产激情一区二区三区| 青青青草影院| 一a一级片| 精品久久久久久中文字幕2017| 一本高清在线| 欧美激情影院| 九九久久99| 久久久成人影院| 欧美一级视| 国产视频一区二区在线播放| 欧美日本韩国| a级黄色毛片免费播放视频 | 国产一区免费观看| 成人a级高清视频在线观看| 可以免费在线看黄的网站| 国产91精品一区| 精品国产香蕉伊思人在线又爽又黄| 国产不卡在线观看| 国产视频久久久| 日韩一级黄色片| 一级女性大黄生活片免费| 国产视频久久久久| 午夜家庭影院| 国产一区二区精品久久91| 亚洲精品影院| 欧美18性精品| 国产福利免费视频| 欧美18性精品| 青青青草影院| 四虎影视久久久| 国产不卡在线观看| 亚洲女人国产香蕉久久精品 | 欧美另类videosbestsex久久| 九九干| 成人高清免费| 色综合久久手机在线| 日韩中文字幕在线亚洲一区| 日韩在线观看视频黄| 成人免费网站久久久| 亚欧乱色一区二区三区| 欧美1区| 精品视频免费看| 国产国语在线播放视频| 精品国产三级a∨在线观看| 国产91精品一区二区| 毛片高清| 国产激情视频在线观看| 麻豆网站在线看| 国产a视频| 国产不卡高清在线观看视频| 一级毛片视频在线观看| 精品视频在线观看一区二区三区| 999久久久免费精品国产牛牛| 精品国产亚洲人成在线| 日韩av成人| 国产一区二区精品久久91| 二级特黄绝大片免费视频大片| 日韩一级精品视频在线观看| 久久国产影院| 成人免费观看的视频黄页| 国产视频一区在线| 99色视频在线| 国产成a人片在线观看视频| 国产不卡高清在线观看视频| 日本伦理网站| 韩国妈妈的朋友在线播放| 高清一级片| 九九九国产| 日韩一级精品视频在线观看| 日韩中文字幕在线观看视频| 久久精品大片| 中文字幕一区二区三区 精品| 麻豆网站在线免费观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 一本伊大人香蕉高清在线观看| 国产成人精品影视| 精品国产一区二区三区国产馆| 99色视频在线观看| 国产麻豆精品hdvideoss| 九九久久99综合一区二区| 久久久久久久网| 免费国产在线观看| 91麻豆精品国产综合久久久| 毛片高清| 精品国产亚洲一区二区三区| 国产美女在线观看| 一级毛片看真人在线视频| 精品毛片视频| 精品国产一区二区三区精东影业| 精品在线视频播放| 日本特黄特黄aaaaa大片| 欧美1卡一卡二卡三新区| 成人影院一区二区三区| 九九免费高清在线观看视频| 午夜家庭影院| 成人在激情在线视频| 国产激情视频在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产网站在线| 九九久久99综合一区二区| 四虎影视精品永久免费网站| 欧美激情一区二区三区中文字幕| 青青青草影院 | 高清一级片| 欧美一级视| 精品视频免费看| 免费国产在线视频| 日韩av片免费播放| 国产原创视频在线| 99热热久久| 日韩免费片| 青草国产在线| 亚洲精品影院久久久久久| 日韩中文字幕在线亚洲一区| 91麻豆精品国产综合久久久| 可以免费在线看黄的网站| 日本伦理网站| 可以免费看污视频的网站| 青草国产在线| 国产不卡福利| 亚飞与亚基在线观看| 香蕉视频三级| 国产麻豆精品hdvideoss| 日韩在线观看视频黄| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产麻豆精品hdvideoss| 日韩av东京社区男人的天堂| 美女免费精品视频在线观看| 欧美大片一区| 免费毛片播放| 久久久成人影院| 国产成人精品在线| 久久久成人影院| 成人免费高清视频| 国产a视频| 精品久久久久久影院免费| 91麻豆国产| 国产福利免费观看| 国产精品自拍在线| 韩国妈妈的朋友在线播放| 国产网站免费视频| 亚洲精品影院一区二区|