婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python實現雙人貪吃蛇小游戲

python實現雙人貪吃蛇小游戲

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

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

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

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

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

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

游戲結束。

下面是小編寫的代碼:

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
 
'''
鏈表節點
'''
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]
        ]
 
    '''坐標取整'''
    def intPos(self, pos):
        return (int(pos[0]), int(pos[1]))
 
    '''坐標轉角度'''
    def pos2Angle(self, pos):
        return self.mapAngle[pos[0]][pos[1]]
 
    '''極坐標位移'''
    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, "任意鍵繼續", (w / 2, h / 2), 24, (55, 255, 55))
    printText(screen, str(remainFoods) + "個食物,搶完即止", (w / 2, h * 2 / 3), 32)
    
def quit():
    pygame.font.quit()
 
'''檢測游戲結束'''
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)
 
'''鍵盤按鍵轉換成面向角度'''
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,然后回車鍵進行安裝

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

您可能感興趣的文章:
  • Python貪吃蛇小游戲實例分享
  • python貪吃蛇游戲代碼
  • Python寫的貪吃蛇游戲例子
  • 使用Python寫一個貪吃蛇游戲實例代碼
  • Python 實現 貪吃蛇大作戰 代碼分享
  • Python貪吃蛇游戲編寫代碼
  • 利用python實現簡易版的貪吃蛇游戲(面向python小白)
  • 教你一步步利用python實現貪吃蛇游戲
  • python實現貪吃蛇游戲
  • Python實現貪吃蛇小游戲(單人模式)

標簽:七臺河 許昌 西安 辛集 贛州 雅安 濰坊 渭南

巨人網絡通訊聲明:本文標題《python實現雙人貪吃蛇小游戲》,本文關鍵詞  python,實現,雙人,貪吃,蛇,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現雙人貪吃蛇小游戲》相關的同類信息!
  • 本頁收集關于python實現雙人貪吃蛇小游戲的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩成人激情| 亚洲国产aⅴ天堂久久| 久久99国产精品久久99果冻传媒| 国产iv一区二区三区| 亚洲欧美激情在线| 亚洲成人www| 欧美成人性福生活免费看| 欧美日韩亚洲综合一区二区三区| 色婷婷av一区二区三区软件| 日韩欧美黄色影院| 中文字幕免费观看一区| 波多野结衣视频一区| 亚洲精品国产a久久久久久 | 亚洲国产精品成人久久综合一区| 欧美性xxxxxx少妇| 色噜噜久久综合| 免费在线视频一区| 亚洲一区在线看| 成人国产在线观看| 国产91丝袜在线播放0| 欧美日韩成人一区| 一区二区免费在线| 欧美男女性生活在线直播观看| 精品国产亚洲在线| 亚洲国产一二三| av成人动漫在线观看| 亚洲老妇xxxxxx| 3atv一区二区三区| 久久精品亚洲一区二区三区浴池| 国产精品一区免费视频| 91精品国产综合久久久久久久 | 国产风韵犹存在线视精品| 久久综合久久久久88| 国产一区免费电影| 精品日韩99亚洲| 成年人午夜久久久| 亚洲国产sm捆绑调教视频 | 日韩精品亚洲专区| 欧美在线制服丝袜| 午夜一区二区三区视频| 久久久久九九视频| 成人做爰69片免费看网站| 中文字幕一区二区三区四区| 成a人片亚洲日本久久| 一区二区三区四区在线播放| 日韩一区二区在线看| 成人精品国产一区二区4080| 欧美国产激情二区三区 | 亚洲综合免费观看高清完整版在线 | 日韩二区在线观看| 欧美片在线播放| 成人午夜免费视频| 日韩在线播放一区二区| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲四区在线观看| 欧美日韩精品欧美日韩精品一| 琪琪一区二区三区| 91麻豆精品国产91久久久久 | 日韩和欧美一区二区| 欧美日本国产一区| 久久99精品国产91久久来源| 久久99精品国产麻豆不卡| 制服丝袜中文字幕一区| 97精品国产露脸对白| 欧美videos中文字幕| 成a人片国产精品| 欧美xxxxxxxx| 91免费在线看| 久久精品一区蜜桃臀影院| 中文字幕在线免费不卡| 偷拍一区二区三区四区| 久久综合久久综合九色| jlzzjlzz国产精品久久| 成人黄色电影在线| 蜜桃av噜噜一区二区三区小说| 成人一区二区三区在线观看| 国产一区二区在线观看视频| 久久国产三级精品| 亚洲品质自拍视频网站| 欧美日韩精品一区二区三区四区| 欧美va亚洲va香蕉在线| 欧美性受xxxx黑人xyx性爽| 美女视频一区二区三区| 91农村精品一区二区在线| 日本不卡一区二区三区| 国产麻豆成人传媒免费观看| 欧美韩日一区二区三区| 日韩毛片一二三区| 亚洲伊人色欲综合网| 一区二区不卡在线视频 午夜欧美不卡在| 日本一区二区三区视频视频| 免费在线观看视频一区| 亚洲图片一区二区| 亚洲欧美影音先锋| 国产精品久线在线观看| 国产河南妇女毛片精品久久久 | 久久精品一区二区| 五月激情六月综合| 午夜久久久久久| 国产精品人人做人人爽人人添| 成人免费av网站| 亚洲综合免费观看高清完整版在线 | 狠狠色狠狠色综合系列| 一区二区三区资源| 一区二区日韩电影| 亚洲精品视频免费看| 国产亚洲女人久久久久毛片| 国产免费成人在线视频| 国产精品久久久久久亚洲伦 | 久久久久久久久久久99999| 国产视频一区在线观看| 中文字幕乱码日本亚洲一区二区| 亚洲欧洲国产专区| 亚洲国产一区二区三区| 国产在线视频不卡二| 欧美日本一区二区三区四区| 久久综合九色综合欧美亚洲| 亚洲综合一二三区| 97成人超碰视| 精品国产乱码久久久久久老虎| 亚洲欧美日韩在线播放| 成人综合在线观看| 精品久久人人做人人爽| 亚洲精品日产精品乱码不卡| 一区二区三区四区乱视频| 国产成人日日夜夜| 国产亚洲一区字幕| 五月综合激情婷婷六月色窝| 亚洲欧美自拍偷拍| 91免费版pro下载短视频| 久久婷婷国产综合精品青草 | 欧美一区二区三区影视| 专区另类欧美日韩| 精品一区二区三区久久| 波多野结衣精品在线| 久久美女艺术照精彩视频福利播放 | 国产福利91精品一区| 日韩精品一区二区三区视频 | 欧美变态tickling挠脚心| 中文字幕中文字幕一区二区 | 日韩欧美国产麻豆| 日本aⅴ免费视频一区二区三区 | 欧美一区二区三区四区在线观看| 欧美国产乱子伦| 老司机精品视频一区二区三区| 国产精品免费aⅴ片在线观看| 国模无码大尺度一区二区三区 | 午夜视频一区在线观看| 91色|porny| 亚洲一区免费在线观看| 亚洲猫色日本管| 色综合视频在线观看| 91精品国产一区二区三区蜜臀 | 国模套图日韩精品一区二区 | 久久久www免费人成精品| 国产成人在线看| 久久丁香综合五月国产三级网站| 欧美一区二区三区色| 久久成人免费日本黄色| 久久精品亚洲国产奇米99| 精品一二三四区| 久久免费精品国产久精品久久久久| 久久99热狠狠色一区二区| 中文一区一区三区高中清不卡| 高清beeg欧美| 青青草国产成人av片免费| 亚洲精品一区二区三区精华液| 色嗨嗨av一区二区三区| 午夜精品在线看| 国产精品第一页第二页第三页| av不卡一区二区三区| 亚洲国产精品麻豆| 欧美日韩视频在线观看一区二区三区| 一区二区三区蜜桃| 一区二区三区在线观看动漫| 国产成人在线看| 成人动漫一区二区在线| 日韩—二三区免费观看av| 中文字幕一区二区不卡| 精品国产亚洲在线| 美日韩一区二区| 亚洲综合一区二区三区| 自拍偷拍欧美精品| 国产精品国产三级国产专播品爱网 | 日韩欧美一区电影| 99re热视频精品| 色综合天天性综合| 99在线精品一区二区三区| a4yy欧美一区二区三区| 日韩av成人高清| 久久久久久免费网| 欧美日韩黄色影视| 日韩欧美二区三区| 欧美综合在线视频| 久久 天天综合| 国产自产v一区二区三区c| 成人美女视频在线看| 欧美专区亚洲专区| 日韩欧美第一区| 国产亚洲综合在线|