校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Python實戰(zhàn)之實現(xiàn)康威生命游戲

Python實戰(zhàn)之實現(xiàn)康威生命游戲

熱門標簽:地圖制圖標注位置改變是移位嗎 地圖標注微信發(fā)送位置不顯示 房產(chǎn)電銷外呼系統(tǒng) 蓋州市地圖標注 浙江電銷卡外呼系統(tǒng)好用嗎 地圖標注的意義點 南京銷售外呼系統(tǒng)軟件 315電話機器人廣告 上海機器人外呼系統(tǒng)哪家好

前言

康威生命游戲設計并不難,我的思路就是借助pygame進行外觀的展示,最近一段時間的游戲項目都是使用pygame進行的,做起來比較順利。內部代碼的實現(xiàn)也比較簡單根據(jù)他的規(guī)則我們需要的是多次的計算和判斷,再刷新數(shù)組。

一、康威生命游戲規(guī)則

當周圍僅有1個或沒有存活細胞時, 原來的存活細胞進入死亡狀態(tài)。(模擬生命數(shù)量稀少)當周圍有2個或3個存活細胞時, 網(wǎng)格保持原樣。當周圍有4個及以上存活細胞時,原來的存活細胞亦進入死亡狀態(tài)。(模擬生命數(shù)量過多)當周圍有3個存活細胞時,空白網(wǎng)格變成存活細胞。(模擬繁殖)

二、設計流程

1. 引入庫

代碼如下(示例):

import sys
import random
import numpy as np
import pygame

2. 設計思路

在這篇博客里面我們實現(xiàn)了下面第一個圖的內容。

感興趣的朋友也可以加下面的思路:

3. 設計窗口

首先我們借用了之前的pygame窗口的代碼,實現(xiàn)窗口的調用。與之前有所不同的變化是,我們在展開窗口之前首先確定大小。
我們實現(xiàn)了游戲大小的自定義,窗口大小的自定義,可以與后面游戲設計增加統(tǒng)一性,增加美觀性。

中間的部分代碼是一些顏色的調出,和窗口的填充。

import sys
import random
import numpy as np
import pygame
pygame.init()#初始化init()及設置
n=int(input("請輸入階數(shù):"))
size=width,height=50*n+2,50*n+2
screen=pygame.display.set_mode(size)#窗口大小
pygame.display.set_caption("康威生命游戲")#窗口名字
icon=pygame.image.load("Icon.jpg")
pygame.display.set_icon(icon)
BLACK=pygame.Color("black")
GAINSBORO=pygame.Color("gainsboro")
MOCCASIN=pygame.Color("moccasin")
WHITE=pygame.Color("white")
screen.fill(MOCCASIN)
fps=5
fclock=pygame.time.Clock()#創(chuàng)建一個Clock對象用于操作時間

while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:  # 點擊了退出
            sys.exit()  # 退出

    pygame.display.update()  # 對顯示窗口進行更新,默認窗口全部重繪
    fclock.tick(fps)  # 窗口刷新速度,每秒3次

三、初始生命矩陣

我們通過循環(huán)產(chǎn)生隨機數(shù)來產(chǎn)生隨機的初始生命。

random.randint(a,b):產(chǎn)生一個位于a-b之間的隨機整數(shù),包括a,b。

## 生成初始生命
a=[]
for i in range(0,n):
    a.append([])
    for j in range(0,n):
        a[i].append(random.randint(0,1))

四、周圍生命的檢測

我們將生命周圍八個位置的索引差值存放在一個列表中,通過循環(huán)檢測有效位置上生命的個數(shù),存放入列表中。
包含兩個判斷。

1.首先要判斷位置的有效性

2.另一個是判斷是否有生命

direction = [[-1, -1], [0, -1], [1, -1], [1, 0], [1, 1], [0, 1], [-1, 1], [-1, 0]]
    c = []
    # 計算周圍生命個數(shù)
    for i in range(0, n):
        c.append([])
        for j in range(0, n):
            count = 0   # 每一個方格
            for o in direction:
                ide = np.array([i, j]) + np.array(o)
                # 保證判斷的位置在范圍內,針對邊界方格
                if 0 = ide[0]  n and 0 = ide[1]  n:
                    if a[ide[0]][ide[1]] == 1:
                        count += 1
            c[i].append(count)

五、生命的變化

將每個位置上的生命根據(jù)計數(shù)列表進行更新,更新生命矩陣。

## 按照生命的發(fā)展規(guī)律進行新一輪的生面變化
    for i in range(0, n):
        for j in range(0, n):
            if c[i][j] = 1 or c[i][j] >= 4:#當生命稀少或者過多時生命死亡
                a[i][j] = 0
            elif c[i][j] == 3:#當生命的周圍有三個生命時,生成新生命
                a[i][j] = 1

六、生命的展示

畫出生命的方格很簡單,我們調用pygame的繪制圖形代碼:

pygame.draw.rect(screen, BLACK, (i*50, j*50, 50, 50)):這樣展示出來的是一個填充的矩形,展示在:screen上,初始位置為:(i * 50, j * 50),大小為:(50, 50),顏色為:black,默認邊框為0,即全部填充的矩形,當后面添加一個數(shù)字時,代表無填充,框線為數(shù)字大小的矩形,如:pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)代表不填充,框線為2

通過畫圖重疊,我們實現(xiàn)每個生命之間的間隔的樣式,增強渲染效果。

for i in range(0, n):
        for j in range(0, n):
            if a[i][j]==1:
                #先畫一個滿填充的方格,有生命方格
                pygame.draw.rect(screen, BLACK, (i*50, j*50, 50, 50))
                #再畫一個不填充,框線為2的方格,套在上面的方格上面
                pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)

            else:#無生命方格
                pygame.draw.rect(screen, WHITE, (i*50, j*50, 50, 50))
                pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)

七、完整代碼

"""
# -*- coding: utf-8 -*-
# @Time    : 2021/4/23 0023 17:14
# @Author  : 源來很巧
# @FileName: 康威生命游戲2.py
# @Software: PyCharm
# @Blog    :https://blog.csdn.net/qq_44793283
"""
import sys
import random
import numpy as np
import pygame
pygame.init()#初始化init()及設置
n=int(input("請輸入階數(shù):"))
size=width,height=50*n+2,50*n+2
screen=pygame.display.set_mode(size)#窗口大小
pygame.display.set_caption("康威生命游戲")#窗口名字
icon=pygame.image.load("Icon.jpg")
pygame.display.set_icon(icon)
BLACK=pygame.Color("black")
GAINSBORO=pygame.Color("gainsboro")
MOCCASIN=pygame.Color("moccasin")
WHITE=pygame.Color("white")
screen.fill(MOCCASIN)
fps=1
fclock=pygame.time.Clock()#創(chuàng)建一個Clock對象用于操作時間


## 生成初始生命
a=[]
for i in range(0,n):
    a.append([])
    for j in range(0,n):
        a[i].append(random.randint(0,1))

## 八個方位的索引變化
direction = [[-1, -1], [0, -1], [1, -1], [1, 0], [1, 1], [0, 1], [-1, 1], [-1, 0]]
while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:  # 點擊了退出
            sys.exit()  # 退出
    c = []
    # 計算周圍生命個數(shù)
    for i in range(0, n):
        c.append([])
        for j in range(0, n):
            count = 0   # 每一個方格
            for o in direction:
                ide = np.array([i, j]) + np.array(o)
                # 保證判斷的位置在范圍內,針對邊界方格
                if 0 = ide[0]  n and 0 = ide[1]  n:
                    if a[ide[0]][ide[1]] == 1:
                        count += 1
            c[i].append(count)
    ## 按照生命的發(fā)展規(guī)律進行新一輪的生面變化
    for i in range(0, n):
        for j in range(0, n):
            if c[i][j] = 1 or c[i][j] >= 4:#當生命稀少或者過多時生命死亡
                a[i][j] = 0
            elif c[i][j] == 3:#當生命的周圍有三個生命時,生成新生命
                a[i][j] = 1
    for i in range(0, n):
        for j in range(0, n):
            if a[i][j]==1:
                #先畫一個滿填充的方格,有生命方格
                pygame.draw.rect(screen, BLACK, (i*50, j*50, 50, 50))
                #再畫一個不填充,框線為2的方格,套在上面的方格上面
                pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)

            else:#無生命方格
                pygame.draw.rect(screen, WHITE, (i*50, j*50, 50, 50))
                pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)
    print(np.array(a))
    pygame.display.update()  # 對顯示窗口進行更新,默認窗口全部重繪
    fclock.tick(fps)  # 窗口刷新速度,每秒3次

總結

這個游戲的實際設計并不是很困難,我們需要將具體的思路理順,哪一步首先進行,需要我們準備哪些存儲的矩陣等等。唯一的彎路是周圍生命個數(shù)的檢測,我的方法是窮舉法,將每個位置索引只差手動計算存儲起來。在小的計算量下,這層循環(huán)計算并不會浪費很多時間,如果您對此有好的建議歡迎交流。也歡迎對后面的游戲結束進行交流,后續(xù)我可以補上結束游戲的方法。

到此這篇關于Python實戰(zhàn)之實現(xiàn)康威生命游戲的文章就介紹到這了,更多相關Python實現(xiàn)康威生命游戲內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python pygame 憤怒的小鳥游戲示例代碼
  • 只需要100行Python代碼就可以實現(xiàn)的貪吃蛇小游戲
  • python編寫五子棋游戲
  • 學會用Python實現(xiàn)滑雪小游戲,再也不用去北海道啦
  • 教你用Python實現(xiàn)一個輪盤抽獎小游戲
  • python實戰(zhàn)之利用pygame實現(xiàn)貪吃蛇游戲(二)
  • python實現(xiàn)21點小游戲
  • 教你用Python寫一個植物大戰(zhàn)僵尸小游戲
  • 憶童年!用Python實現(xiàn)憤怒的小鳥游戲

標簽:金華 克拉瑪依 臨汾 日照 赤峰 陽泉 雙鴨山 貴州

巨人網(wǎng)絡通訊聲明:本文標題《Python實戰(zhàn)之實現(xiàn)康威生命游戲》,本文關鍵詞  Python,實戰(zhàn),之,實現(xiàn),康威,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python實戰(zhàn)之實現(xiàn)康威生命游戲》相關的同類信息!
  • 本頁收集關于Python實戰(zhàn)之實現(xiàn)康威生命游戲的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美激情一区二区| 国产人成亚洲第一网站在线播放| 天天综合色天天综合色h| 欧美精品777| 大白屁股一区二区视频| 亚洲一线二线三线视频| 欧美白人最猛性xxxxx69交| 国产成人综合精品三级| 亚洲一级二级在线| 精品国产乱码久久久久久蜜臀| 精品无人码麻豆乱码1区2区| 欧美日韩国产免费一区二区 | 国产欧美精品一区二区三区四区| 成人av影视在线观看| 日韩电影免费在线观看网站| 欧美极品xxx| 欧美日韩精品一区二区天天拍小说| 亚洲已满18点击进入久久| 7777精品伊人久久久大香线蕉完整版 | 99久久伊人精品| 日韩**一区毛片| 亚洲同性gay激情无套| 欧美一区二区视频观看视频| 菠萝蜜视频在线观看一区| 亚洲永久精品大片| 国产精品久久看| 26uuu色噜噜精品一区二区| 欧美性极品少妇| av在线免费不卡| 国产一区二区女| 婷婷丁香激情综合| 亚洲主播在线播放| 中文字幕一区二区三区四区不卡 | 国产日产欧产精品推荐色| 日本黄色一区二区| 东方欧美亚洲色图在线| 热久久国产精品| 午夜私人影院久久久久| 中文字幕一区二区在线播放 | 国产亚洲一区二区在线观看| 欧美久久久久久久久久| 色屁屁一区二区| 99精品1区2区| 成人午夜私人影院| 国模大尺度一区二区三区| 日韩主播视频在线| 亚洲国产日产av| 亚洲aaa精品| 一区二区三区日本| 亚洲免费观看高清完整| 欧美高清在线精品一区| 欧美大白屁股肥臀xxxxxx| 欧美日本精品一区二区三区| 91麻豆文化传媒在线观看| 成人免费看片app下载| 国产成人在线观看| 国产精品白丝jk白祙喷水网站| 美脚の诱脚舐め脚责91| 久久精品国产在热久久| 偷偷要91色婷婷| 日韩黄色免费电影| 亚洲电影一区二区| 亚洲成人av资源| 亚洲国产日韩一级| 亚洲激情成人在线| 亚洲国产乱码最新视频 | 亚洲精品综合在线| 亚洲精品成人精品456| 亚洲乱码一区二区三区在线观看| 亚洲欧美一区二区在线观看| 亚洲欧美偷拍三级| 亚洲一区中文在线| 男人的j进女人的j一区| 久久福利资源站| 国内精品国产成人| 成人手机电影网| 一本久道久久综合中文字幕 | 国产成人精品免费视频网站| 成人午夜短视频| 色综合视频一区二区三区高清| 色综合久久66| 欧美一区二区三区免费在线看| 日韩视频在线观看一区二区| 日韩午夜av电影| 国产视频在线观看一区二区三区 | 国产一区二区在线观看视频| 国内精品免费**视频| 成人av午夜影院| 欧美精品色一区二区三区| 欧美一级生活片| 国产精品美女久久久久久久网站| 亚洲精品一二三| 久久精品国产一区二区三| 国产91精品露脸国语对白| 色老汉一区二区三区| 9191久久久久久久久久久| 精品视频在线免费看| 欧美videofree性高清杂交| 欧美激情一区二区| 亚洲h在线观看| 国产精品小仙女| 色八戒一区二区三区| 日韩精品中文字幕一区| **欧美大码日韩| 免费国产亚洲视频| 一本久久a久久精品亚洲| 日韩欧美在线1卡| 亚洲欧洲综合另类在线| 精品一区二区三区蜜桃| 色狠狠色噜噜噜综合网| 欧美日本韩国一区| 国产精品国产精品国产专区不蜜 | 欧美96一区二区免费视频| 久久精品国产精品亚洲综合| 国产精品你懂的在线| 久久久国产精品午夜一区ai换脸| 亚洲精品视频在线| 极品少妇xxxx精品少妇偷拍 | 91亚洲大成网污www| 日韩女优av电影| 亚洲一二三级电影| voyeur盗摄精品| 久久综合精品国产一区二区三区 | 日韩视频免费观看高清完整版在线观看 | 欧美经典三级视频一区二区三区| 日韩制服丝袜av| 91论坛在线播放| 国产日韩精品一区二区浪潮av| 午夜精品福利在线| 色哟哟精品一区| 国产精品女主播在线观看| 麻豆精品在线视频| 欧美日韩夫妻久久| 亚洲黄色免费电影| 91在线精品一区二区三区| 久久精品人人爽人人爽| 青青草国产成人99久久| 欧美三区免费完整视频在线观看| 国产精品国产三级国产普通话蜜臀| 国产毛片精品视频| 精品日韩一区二区| 日韩av电影免费观看高清完整版| 欧美亚洲一区三区| 依依成人精品视频| 一本高清dvd不卡在线观看| 国产精品欧美一级免费| 丁香亚洲综合激情啪啪综合| 精品sm在线观看| 美女视频一区二区| 欧美大片在线观看一区| 美腿丝袜亚洲三区| 欧美成人三级电影在线| 免费久久99精品国产| 日韩三级视频在线看| 男人的天堂亚洲一区| 日韩女同互慰一区二区| 老司机免费视频一区二区| 欧美tickling挠脚心丨vk| 久久99深爱久久99精品| 欧美久久一区二区| 亚洲精品在线网站| 在线观看亚洲精品视频| 国产在线国偷精品产拍免费yy| 一区二区在线看| 91国内精品野花午夜精品 | 欧美日韩精品一区二区天天拍小说 | 日韩美女在线视频| 亚洲v日本v欧美v久久精品| 欧美日免费三级在线| 亚洲一区二区三区美女| 91成人国产精品| 免费观看一级欧美片| 日韩免费性生活视频播放| 国产综合成人久久大片91| 国产视频一区二区三区在线观看| 99久久婷婷国产精品综合| 亚洲一区二区精品视频| 777精品伊人久久久久大香线蕉| 麻豆精品蜜桃视频网站| 中文字幕国产一区二区| 色婷婷精品久久二区二区蜜臀av| 亚洲综合在线五月| 日韩色视频在线观看| 91日韩一区二区三区| 亚洲成人激情av| 欧美精品一区二区三区久久久| 不卡电影免费在线播放一区| 亚洲成人综合网站| 欧美精品一区二区三区久久久| 成人av免费网站| 五月天一区二区三区| 国产亚洲婷婷免费| aa级大片欧美| 久久99精品一区二区三区| 国产精品三级av在线播放| 欧美日韩色综合| 91网页版在线| 麻豆国产精品视频| 亚洲免费在线视频一区 二区| 777奇米四色成人影色区|