Python实战之实现康威生命游戏


Posted in Python onApril 26, 2021

前言

康威生命游戏设计并不难,我的思路就是借助pygame进行外观的展示,最近一段时间的游戏项目都是使用pygame进行的,做起来比较顺利。内部代码的实现也比较简单根据他的规则我们需要的是多次的计算和判断,再刷新数组。

一、康威生命游戏规则

当周围仅有1个或没有存活细胞时, 原来的存活细胞进入死亡状态。(模拟生命数量稀少)当周围有2个或3个存活细胞时, 网格保持原样。当周围有4个及以上存活细胞时,原来的存活细胞亦进入死亡状态。(模拟生命数量过多)当周围有3个存活细胞时,空白网格变成存活细胞。(模拟繁殖)

 二、设计流程

1、引入库

代码如下(示例):

import sys
import random
import numpy as np
import pygame

2、设计思路

在这篇博客里面我们实现了下面第一个图的内容。

Python实战之实现康威生命游戏

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

Python实战之实现康威生命游戏

3、设计窗口

首先我们借用了之前的pygame窗口的代码,实现窗口的调用。与之前有所不同的变化是,我们在展开窗口之前首先确定大小。
我们实现了游戏大小的自定义,窗口大小的自定义,可以与后面游戏设计增加统一性,增加美观性。

中间的部分代码是一些颜色的调出,和窗口的填充。

Python实战之实现康威生命游戏

import sys
import random
import numpy as np
import pygame
pygame.init()#初始化init()及设置
n=int(input("请输入阶数:"))
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()#创建一个Clock对象用于操作时间

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

    pygame.display.update()  # 对显示窗口进行更新,默认窗口全部重绘
    fclock.tick(fps)  # 窗口刷新速度,每秒3次

三、初始生命矩阵

我们通过循环产生随机数来产生随机的初始生命。

random.randint(a,b):产生一个位于a-b之间的随机整数,包括a,b。

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

四、周围生命的检测

我们将生命周围八个位置的索引差值存放在一个列表中,通过循环检测有效位置上生命的个数,存放入列表中。
包含两个判断。

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

2.另一个是判断是否有生命

direction = [[-1, -1], [0, -1], [1, -1], [1, 0], [1, 1], [0, 1], [-1, 1], [-1, 0]]
    c = []
    # 计算周围生命个数
    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)

五、生命的变化

将每个位置上的生命根据计数列表进行更新,更新生命矩阵。

## 按照生命的发展规律进行新一轮的生面变化
    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,即全部填充的矩形,当后面添加一个数字时,代表无填充,框线为数字大小的矩形,如:pygame.draw.rect(screen, GAINSBORO, (i*50, j*50, 50, 50),2)代表不填充,框线为2

通过画图重叠,我们实现每个生命之间的间隔的样式,增强渲染效果。

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("请输入阶数:"))
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()#创建一个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 = []
    # 计算周围生命个数
    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)
    ## 按照生命的发展规律进行新一轮的生面变化
    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次

总结

这个游戏的实际设计并不是很困难,我们需要将具体的思路理顺,哪一步首先进行,需要我们准备哪些存储的矩阵等等。唯一的弯路是周围生命个数的检测,我的方法是穷举法,将每个位置索引只差手动计算存储起来。在小的计算量下,这层循环计算并不会浪费很多时间,如果您对此有好的建议欢迎交流。也欢迎对后面的游戏结束进行交流,后续我可以补上结束游戏的方法。

到此这篇关于Python实战之实现康威生命游戏的文章就介绍到这了,更多相关Python实现康威生命游戏内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python中类的定义、继承及使用对象实例详解
Apr 30 Python
Python使用matplotlib实现在坐标系中画一个矩形的方法
May 20 Python
python中字符串类型json操作的注意事项
May 02 Python
python爬虫获取京东手机图片的图文教程
Dec 29 Python
python 执行文件时额外参数获取的实例
Dec 18 Python
Python+OpenCV+pyQt5录制双目摄像头视频的实例
Jun 28 Python
django 通过URL访问上传的文件方法
Jul 28 Python
Python性能分析工具Profile使用实例
Nov 19 Python
在Pytorch中计算自己模型的FLOPs方式
Dec 30 Python
PyQt5实现登录页面
May 30 Python
pandas.DataFrame.drop_duplicates 用法介绍
Jul 06 Python
python实现双链表
May 25 Python
Python 制作自动化翻译工具
教你用Python写一个植物大战僵尸小游戏
python爬取新闻门户网站的示例
Apr 25 #Python
python自然语言处理之字典树知识总结
Python自然语言处理之切分算法详解
Apr 25 #Python
Python网络编程之ZeroMQ知识总结
Python 文本滚动播放器的实现代码
Apr 25 #Python
You might like
php 什么是PEAR?(第三篇)
2009/03/19 PHP
php 判断字符串中是否包含html标签
2014/02/17 PHP
PHP获取用户客户端真实IP的解决方案
2016/10/10 PHP
PHP二维数组实现去除重复项的方法【保留各个键值】
2017/12/21 PHP
jQuery Tips 为AJAX回调函数传递额外参数的方法
2010/12/28 Javascript
EasyUI的treegrid组件动态加载数据问题的解决办法
2011/12/11 Javascript
javascript学习笔记(十一) 正则表达式介绍
2012/06/20 Javascript
JavaScript实现twitter puddles算法实例
2014/12/06 Javascript
Javascript添加监听与删除监听用法详解
2014/12/19 Javascript
详解jQuery UI库中文本输入自动补全功能的用法
2016/04/23 Javascript
使用JavaScript判断手机浏览器是横屏还是竖屏问题
2016/08/02 Javascript
AngularJS 指令的交互详解及实例代码
2016/09/14 Javascript
vue.js实现请求数据的方法示例
2017/02/07 Javascript
微信小程序登录态控制深入分析
2017/04/12 Javascript
JavaScript实现简单的双色球(实例讲解)
2017/07/31 Javascript
layui.js实现的表单验证功能示例
2017/11/15 Javascript
element ui 对话框el-dialog关闭事件详解
2018/02/26 Javascript
vue使用混入定义全局变量、函数、筛选器的实例代码
2019/07/29 Javascript
Node.js控制台彩色输出的方法与原理实例详解
2019/12/01 Javascript
js构造函数constructor和原型prototype原理与用法实例分析
2020/03/02 Javascript
python爬取拉勾网职位数据的方法
2018/01/24 Python
Python实现将数据写入netCDF4中的方法示例
2018/08/30 Python
详解python的四种内置数据结构
2019/03/19 Python
处理Selenium3+python3定位鼠标悬停才显示的元素
2019/07/31 Python
python django生成迁移文件的实例
2019/08/31 Python
Anaconda之conda常用命令介绍(安装、更新、删除)
2019/10/06 Python
python 创建一维的0向量实例
2019/12/02 Python
Python字符串及文本模式方法详解
2020/09/10 Python
Lyle & Scott苏格兰金鹰官网:英国皇室御用品牌
2018/05/09 全球购物
北京天润融通.net面试题笔试题
2012/02/20 面试题
以思科路由器为例你写下单臂路由的配置命令
2013/08/03 面试题
人力资源经理的岗位职责
2014/03/02 职场文书
2014年作风建设剖析材料
2014/10/23 职场文书
迎新生欢迎词
2015/01/23 职场文书
网吧员工管理制度
2015/08/05 职场文书
SQLServer中exists和except用法介绍
2021/12/04 SQL Server