pygame学习--精灵组、碰撞检测、精灵更新

news2025/1/9 5:23:04

pygame学习--精灵组、碰撞检测、精灵更新

  • 一.效果
  • 二.代码

通过pygame库,模拟种群的分化
1.X从左往右移动,表示年龄的增加;Y坐标表示阶层
2.随着X坐标不断增大,圆逐渐增大,颜色也加深
3.精灵越多,碰撞后死亡的概率越大,诞生新精灵的概率越小
4.每个精灵都有随机的运动速度及Y坐标的移动方向
5.发生碰撞且诞生新精灵时,继承当前坐标的Y值

一.效果

  • 初始状态
    在这里插入图片描述
  • 迭代一段时间后
    在这里插入图片描述

二.代码

import pygame
import numpy as np
import random

min_sprite_radius=5
max_sprite_radius=15

max_width=max_sprite_radius*100
max_height=min_sprite_radius*100
max_sprites=5000

class Life(pygame.sprite.Sprite):
    def __init__(self,y=None):
        super().__init__()
        self.image = pygame.Surface((min_sprite_radius, min_sprite_radius),pygame.SRCALPHA)
        self.rect = self.image.get_rect()
        self.rect.centerx = np.random.randint(0,max_width)
        if y:
            self.rect.centery = y
        else:
            self.rect.centery = np.random.randint(0,max_height)
    def update(self):        
        dir   = np.random.randint(-1*min_sprite_radius,min_sprite_radius)  
        speed = np.random.randint(1,min_sprite_radius)

        self.rect.centerx += speed
        self.rect.centery += dir

        ratio=self.rect.centerx/max_width

        color_depth=ratio*255
        radius =ratio*(max_sprite_radius-min_sprite_radius)+min_sprite_radius

        self.image = pygame.transform.scale(self.image, (radius , radius ))
        
        pygame.draw.circle(self.image, (color_depth, 128, 128), (radius //2, radius //2), (radius //2)-1)

random.seed(2)
np.random.seed(2)

pygame.init()
screen = pygame.display.set_mode((max_width,max_height))
pygame.display.update()

clock = pygame.time.Clock()
fps=30

sprite_group = pygame.sprite.Group(*[Life() for _ in range(max_sprites//10)])

while True:
    clock.tick(fps)
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            print("退出...")
            pygame.quit()
            exit()

    screen.fill((31, 31, 31))
    
    sprite_group.update()

    # 判断是否超出边界
    for group_a_sprite in sprite_group.sprites():
        bkill=False
        if group_a_sprite.rect.centerx>=max_width:
            bkill=True
        if group_a_sprite.rect.centery>=max_height or group_a_sprite.rect.centery<0:
            bkill=True
        if bkill:
            group_a_sprite.kill()

    # 碰撞检测
    add_yoffsets=[]
    total_sprites=len(sprite_group)
    for group_a_sprite in sprite_group.sprites():
        collision = pygame.sprite.spritecollide(group_a_sprite, sprite_group, False)
        for j in collision:
            if id(group_a_sprite)==id(j):
                continue
            else:
                kill_prob=total_sprites/max_sprites
                remain_prob=1.0-kill_prob
                state=random.choices([0,1,2],[kill_prob,remain_prob/2,remain_prob/2],k=1)[0]
                if state==0:
                    group_a_sprite.kill()
                if state==1:
                    add_yoffsets.append(group_a_sprite.rect.centery)
                if state==2:
                    pass
    
    # 生成新精灵
    if total_sprites<max_sprites:
        for y in add_yoffsets:
            sprite_group.add(Life(y))

    sprite_group.draw(screen)

    myString=f"count:{total_sprites}"
    font = pygame.font.SysFont("Times New Roman", 48)
    text = font.render(myString, True, (255,255,255))
    screen.blit(text, (10,10))
    pygame.display.update()

pygame.quit()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1643182.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于YOLO8学习(五)安卓部署ncnn模型--视频检测

前文 关于YOLO8学习(一)环境搭建,官方检测模型部署到手机 关于YOLO8学习(二)数据集收集,处理 关于YOLO8学习(三)训练自定义的数据集 关于YOLO8学习(四)模型转换为ncnn 简介 本文将会讲解: (1)使用前文生成的ncnn模型,部署到安卓端,并且实现视频中,人脸的检测…

图像压缩问题

图像压缩问题的bilibil讲解 1.问题引入 首先&#xff0c;图像是由像素组合成的&#xff0c;每个像素都有灰度值&#xff0c;灰度值是体现像素的颜色的。灰度值从0~255&#xff0c;灰度值占用的位数就是像素占用的位数。我们要存储一个图像就要存储它的所有像素。现在的问题是我…

【Github】将github仓库作为图床使用

创建github仓库 首先创建一个github仓库专门用于存储图片&#xff0c;具体步骤如下&#xff1a; 1.点击新的仓库按钮 2.初始配置&#xff1a;随便填写一个仓库名&#xff1b;这里的仓库状态一定要是public公开的&#xff0c;不然后面访问不了图片 下载PicGo PicGo官网 在A…

【Linux系统编程】第十三弹---项目自动化构建工具-make/Makefile

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、背景 2、编写makefile 2、make原理 3、理解makefile 4、优化makefile 总结 1、背景 ★ 会不会写makefile&#xff0c;从…

杭州等级保护测评—提升企业安全等级

4月初&#xff0c;在和杭州未来科技城正式签署“重点企业落户协议”之后&#xff0c;新一代本地生活服务平台“AC生活”又获得了由中华人民共和国公安部颁发的“信息系统安全等级保护”备案证书。尽管工作人员一再强调“公司还处在研发期”、“产品还不成熟”&#xff0c;但随着…

2.spring security 简单入门

创建springboot 项目&#xff0c;引入spring security坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--spring security坐标--><dependency&g…

【每日力扣】141. 环形链表与142. 环形链表 II

&#x1f525; 个人主页: 黑洞晓威 &#x1f600;你不必等到非常厉害&#xff0c;才敢开始&#xff0c;你需要开始&#xff0c;才会变的非常厉害 141. 环形链表 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟…

恶补《操作系统》5_2——王道学习笔记

5.2_1 I-O核心子系统 1、用户层软件 假脱机系统 2、设备独立性软件&#xff08;设备无关性软件&#xff09; IO调度、设备保护、设备分配与回收、缓冲区管理 3、设备驱动程序&#xff08;比如打印机驱动&#xff09; 4、中断处理程序 5、硬件 5.2_2 假脱机技术&#xff…

爬虫工具:避免复制文字收费,VIP。。

step ctrl shift i 打开开发者工具 点击...打开设置勾选禁用JavaScript Principle 事件处理&#xff1a;JavaScript 用于处理用户交互&#xff0c;例如点击、滚动、输入等禁用 JavaScript 后&#xff0c;页面上的所有 JavaScript 代码都将不会执行

基于 Dockerfile 部署 LNMP 架构

目录 前言 1、任务要求 2、Nginx 镜像创建 2.1 建立工作目录并上传相关安装包 2.2 编写 Nginx Dockerfile 脚本 2.3 准备 nginx.conf 配置文件 2.4 生成镜像 2.5 创建 Nginx 镜像的容器 2.6 验证nginx 3、Mysql 镜像创建 3.1 建立工作目录并上传相关安装包 3.2 编写…

FastAPI - Pydantic相关应用

参考链接&#xff1a;Pydantic官方文档 文章目录 定义数据模型创建模型实例数据验证数据转换模型转换模型更新模型配置辅助类Field Pydantic 是一个 Python 库&#xff0c;主要用于数据验证和管理。数据验证是指检查数据是否符合预定的规则和格式&#xff0c;比如检查数据类型是…

c++项目文件夹重命名

文章目录 一、改变项目文件夹名&#xff1f;1. 手动改名2. 自动改名 二、全局替换原文件名的引用1.打开Visual Studio 2022软件 一、改变项目文件夹名&#xff1f; 1. 手动改名 文件名一个一个改挺麻烦的 2. 自动改名 import java.io.File; import java.util.Optional;publi…

leetcode_47.全排列 II

47. 全排列 II 题目描述&#xff1a;给定一个可包含重复数字的序列 nums &#xff0c;按任意顺序 返回所有不重复的全排列。 示例 1&#xff1a; 输入&#xff1a;nums [1,1,2] 输出&#xff1a; [[1,1,2],[1,2,1],[2,1,1]]示例 2&#xff1a; 输入&#xff1a;nums [1,2,3] …

Optional学习记录

Optional出现的意义 在Java中&#xff0c;我们经常遇到的一种异常情况&#xff1a;空指针异常&#xff0c;在原本的编程中&#xff0c;为了避免这种异常&#xff0c;我们通常会向对象进行判断&#xff0c;然而&#xff0c;过多的判断语句会让我们的代码显得臃肿不堪。 所以在J…

老Java学 Go 笔录(一) 到底为什么要学习 go ?

文章目录 一.到底什么是go ?1.1 历史渊源1.2 优秀特性1.2 应用场景1.3 和 java 有什么不同 二.聊一聊一个 java 的我为什么要学一学 go ?2.1 生活不止眼前苟且,还有诗和远方.但先要苟住2.2 了解一项新技能 三.打算怎么去学3.1 官网大概搂一遍3.2 b 站的学习视频跟着走一回3.3…

经纬度聚类:聚类算法比较

需求&#xff1a; 将经纬度数据&#xff0c;根据经纬度进行聚类 初始数据 data.csv K均值聚类 简介 K均值&#xff08;K-means&#xff09;聚类是一种常用的无监督学习算法&#xff0c;用于将数据集中的样本分成K个不同的簇&#xff08;cluster&#xff09;。其基本思想是…

产品AB测试设计

因为vue2项目升级到vue3经历分享1&#xff0c;vue2项目升级到vue3经历分享2&#xff0c;前端系统升级&#xff0c;界面操作也发生改变&#xff0c;为了将影响降到最低&#xff0c;是不能轻易让所有用户使用新系统的。原系统使用好好的&#xff0c;如果新界面用户不喜欢&#xf…

C语言中字符串输入的3种方式

Ⅰ gets() 函数 gets() 函数的功能是从输入缓冲区中读取一个字符串存储到字符指针变量 str 所指向的内存空间 # include <stdio.h> int main(void) {char a[256] {0};gets(a);printf("%s",a);return 0; }Ⅱ getchar() # include <stdio.h> int mai…

【实验】根据docker部署nginx并且实现https

环境准备 systemctl stop firewalld setenforce 0 安装docker #安装依赖包 yum -y install yum-utils device-mapper-persistent-data lvm2 #设置阿里云镜像 yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo #安装最新版…

DSP实时分析平台设计方案:924-6U CPCI振动数据DSP实时分析平台

6U CPCI振动数据DSP实时分析平台 一、产品概述 基于CPCI结构完成40路AD输入&#xff0c;30路DA输出的信号处理平台&#xff0c;处理平台采用双DSPFPGA的结构&#xff0c;DSP采用TI公司新一代DSP TMS320C6678&#xff0c;FPGA采用Xilinx V5 5VLX110T-1FF1136芯片&#xff…