pygame入门学习(四)位图的使用

news2025/1/9 1:26:19

大家好!我是码银🥰

欢迎关注🥰:

CSDN:码银

公众号:码银学编程

载入图片

pygame.image.load( ),Pygame 可以通过pygame.image.load( )函数处理位图文件。

大致可以支持以下文件:JPG、PNG、GIF、BMP、PCX、TGA、TIF、LBM、PBM、PGM、PPM、XPM。

1、加载背景图片主要有两行代码:

asurf = pygame.image.load('test.jpg').convert()
screen.blit(asurf, (0, 0))#加载背景图片

下面来看一下这段代码在整体代码中的位置:

import pygame
from pygame.locals import*
import sys


pygame.init()

screen = pygame.display.set_mode((800,600))
pygame.display.set_caption("图片")
asurf = pygame.image.load('test.jpg').convert()
while True:
    for event in pygame.event.get():
        if event.type == QUIT:
            sys.exit()
    screen.blit(asurf, (0, 0))
    pygame.display.update()

2、背景图片上显示另一幅图片

import pygame
from pygame.locals import*
import sys


pygame.init()

screen = pygame.display.set_mode((751,521))
pygame.display.set_caption("图片")
asurf = pygame.image.load('test.png').convert()
moon = pygame.image.load('moon.png').convert()
while True:
    for event in pygame.event.get():
        if event.type == QUIT:
            sys.exit()
    screen.blit(asurf, (0, 0))
    screen.blit(moon, (100,200))
    pygame.display.update()

可以看到背景图是一张“星星”的图片,左下角贴了一张月球的图片。

screen.blit(asurf, (0, 0))
screen.blit(moon, (100,200))

这段代码按照这个顺序,那么月球就会在背景图的上方显示,代码的先后顺序代表着图片的覆盖关系。

下面部分,本想控制月球移动的,但是图片太大,于是随找了一个小的图片进行测试。

控制图片移动

先看代码

import pygame
import sys

# 初始化Pygame
pygame.init()

# 设置窗口大小和标题
window_width = 800
window_height = 600
window_title = "图片移动示例"
screen = pygame.display.set_mode((window_width, window_height))
pygame.display.set_caption(window_title)

# 加载图片
image_path = "brick.png"
image = pygame.image.load(image_path)
image_rect = image.get_rect()

# 设置初始位置
image_rect.x = 0
image_rect.y = 0

# 游戏循环
while True:
    # 处理事件
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            pygame.quit()
            sys.exit()

            # 移动图片
    keys = pygame.key.get_pressed()
    if keys[pygame.K_LEFT] and image_rect.x > 0:
        image_rect.x -= 1
    if keys[pygame.K_RIGHT] and image_rect.x < window_width - image_rect.width:
        image_rect.x += 1
    if keys[pygame.K_UP] and image_rect.y > 0:
        image_rect.y -= 1
    if keys[pygame.K_DOWN] and image_rect.y < window_height - image_rect.height:
        image_rect.y += 1

        # 绘制图片和窗口边界
    screen.fill((0, 0, 0))  # 填充背景色为黑色
    screen.blit(image, image_rect)  # 在指定位置绘制图片
    pygame.display.update()  # 更新显示内容

如何去控制图片移动,这部分代码是与上一篇文章(pygame学习(三)——支持多种类型的事件-CSDN博客)相结合起来 的,将图片与键盘事件相结合,以此来控制图片的移动。

pygame键盘控制图片移动

image.get_rect()方法

 是 Pygame 中的一个方法,用于获取图像的矩形区域。这个矩形区域表示图像在屏幕上的位置和大小。

当你加载一个图像到 Pygame 中时,你可以使用 get_rect() 方法来获取该图像的矩形对象。这个矩形对象具有 x 和 y 属性,分别表示矩形左上角的坐标,以及 width 和 height 属性,分别表示矩形的宽度和高度。

例如上面代码中设置图片的初始位置:

# 设置初始位置
image_rect.x = 0
image_rect.y = 0

图片移动

        # 移动图片
keys = pygame.key.get_pressed()
if keys[pygame.K_LEFT] and image_rect.x > 0:
    image_rect.x -= 1
if keys[pygame.K_RIGHT] and image_rect.x < window_width - image_rect.width:
    image_rect.x += 1
if keys[pygame.K_UP] and image_rect.y > 0:
    image_rect.y -= 1
if keys[pygame.K_DOWN] and image_rect.y < window_height - image_rect.height:
    image_rect.y += 1

这段代码是使用Pygame库来控制图片在屏幕上的移动。具体来说,它通过检测用户的键盘输入来移动一个图片对象。以下是这段代码的总结:

  • 获取按键状态: 使用pygame.key.get_pressed()函数来获取当前所有按键的状态。

  • 图片移动逻辑:

    • 如果用户按下左键,并且图片的x坐标大于0,则将图片的x坐标减少1,使图片向左移动。
    • 如果用户按下右键,并且图片的x坐标小于屏幕宽度减去图片宽度,则将图片的x坐标增加1,使图片向右移动。
    • 如果用户按下上键,并且图片的y坐标大于0,则将图片的y坐标减少1,使图片向上移动。
    • 如果用户按下下键,并且图片的y坐标小于屏幕高度减去图片高度,则将图片的y坐标增加1,使图片向下移动。

既然都看到这里啦,点点赞吧😁,欢迎关注:

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

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

相关文章

怎么给wordpress网站底部页脚添加备案号和链接?

以前“WordPress后台 >> 常规”最底部是有一个ICP备案号的&#xff0c;我们只需要填写备案号并保存更改即可让WordPress自带主题底部显示ICP备案号&#xff0c;但是现在新版本的WordPress已经没有了这个ICP备案号选项&#xff0c;而且也无法直接添加公安联网备案号&#…

前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法

文章目录 一、vue实现导出excel1、前端实现1、安装xlsx依赖2、引入3、方法4、使用4.1、将一个二维数组转成sheet4.2、将一个对象数组转成sheet4.3、合并单元格4.4、一次导出多个sheet 5、支持的文件格式 2、后端实现 二、导出文件损坏1、前端请求导出接口&#xff0c;增加返回类…

对称二叉树,力扣

题目地址&#xff1a; 101. 对称二叉树 - 力扣&#xff08;LeetCode&#xff09; 难度&#xff1a;简单 今天刷对称二叉树&#xff0c;大家有兴趣可以点上面链接&#xff0c;看看题目要求&#xff0c;试着做一下。 题目&#xff1a; 给你一个二叉树的根节点 root &#xff0c;…

区块链社交:Facebook在去中心化时代的探索

随着区块链技术的崛起&#xff0c;数字社交领域也正迎来一场革命。Facebook&#xff0c;作为全球最大的社交媒体平台之一&#xff0c;不甘落后&#xff0c;积极探索区块链的应用前景。本文将深入探讨Facebook在去中心化时代对区块链社交的探索&#xff0c;以及这一探索可能引发…

控制项目进展

优质博文 IT-BLOG-CN 假如一个项目准备工作做的非常周详&#xff0c;现在要做的就是监督项目的进展情况&#xff0c;理想状况下事情应当进展的很顺利&#xff0c;但实际上我们会发现项目永远不会完全按照经计划执行&#xff0c;我们必须进行项目控制。也就是我们需要不断进行调…

基于springboot+vue的在线文档管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 背景和意…

[ACM学习]自上而下树形dp

问题引入 设置dp状态&#xff0c;相比于更容易出错的贪心更...不易出错。 状态设计 如果选择父结点&#xff0c;就会使孩子结点不能被选择&#xff0c;我们会多开一维的dp&#xff0c;用来标记该点是否被标记过。 以1点举例&#xff0c;f[1][0]为不选它的状态&#xff0c;那么…

使用双异步后,如何保证数据一致性?

目录 一、前情提要二、通过Future获取异步返回值1、FutureTask 是基于 AbstractQueuedSynchronizer实现的2、FutureTask执行流程3、get()方法执行流程 三、FutureTask源码具体分析1、FutureTask源码2、将异步方法的返回值改为Future<Integer>&#xff0c;将返回值放到new…

Databend 开源周报第 129 期

Databend 是一款现代云数仓。专为弹性和高效设计&#xff0c;为您的大规模分析需求保驾护航。自由且开源。即刻体验云服务&#xff1a;https://app.databend.cn 。 Whats On In Databend 探索 Databend 本周新进展&#xff0c;遇到更贴近你心意的 Databend 。 支持标准流 标…

关于图像分割项目的可视化脚本

1. 前言 之前实现了目标检测和图像分类任务的可视化脚本&#xff0c;本章将最后一个分割任务的可视化脚本实现 效果展示如下&#xff1a; 代码会在当前目录保存展示好的图片&#xff0c;从左到右依次为&#xff0c;原图、mask图、mask覆盖在原图的掩膜图 关于目标检测的可视化…

x-cmd pkg | hurl - HTTP 请求处理工具

目录 简介首次用户功能特点竞品和相关作品进一步探索 简介 Hurl 是 HTTP 请求处理工具&#xff0c;支持使用简单的纯文本格式定义的 HTTP 请求。它的用途非常广泛&#xff0c;既可以用于获取数据&#xff0c;也可以用于测试HTTP会话。 它可以链式处理请求&#xff0c;捕获数值…

在Go中处理HTTPS请求:一场加密的舞蹈

嘿&#xff0c;Go语言的爱好者们&#xff0c;你们准备好跳一场加密的舞蹈了吗&#xff1f;今天&#xff0c;我们要一起探讨如何在Go中处理那些神秘的HTTPS请求。 首先&#xff0c;我们要明白HTTPS是什么。简单来说&#xff0c;HTTPS就是给HTTP穿上了一层"加密的外套"…

如何根据openai官网的FileID下载文件

我的chatgpt网站&#xff0c;哈哈&#xff1a; https://chat.xutongbao.top/ file-type的版本需要注意&#xff1a; "file-type": "^15.0.0", const FileType require(file-type)const assistantsDownloadFileOnAzure async (req, res) > {let { apiK…

抖音出的AI工具火了!自动生成抖音文案,一键脚本数字人成片!

一些结论 抖音即创是一个一站式的智能创意生产与管理平台。 视频创作: AI视频脚本、数字人、一键成片 图文创作: 商品卡、图文工具 直播创作: AI背景、AI文案 抖音即创目前处于公测&#xff0c;全部功能免费使用&#xff01; 抖音即创是什么&#xff1f; “抖音即创”是一…

复杂高层建筑环境多模态导航服务和引导管理机器人系统设计(预告)

课题基础 机器人工程ROS方向应用型本科毕业设计重点课题学生验收成果 将上面这篇所涉及的算法等应用到如下环境中。 Gazebo新环境AWS RoboMaker Hospital医院场景适用于ROS1和ROS2 高层可以简化为多层测试。最典型的就是两层及以上。 简介 随着城市化进程的加速和高层建筑…

08-微服务Seata分布式事务使用

一、分布式事务简介 1.1 概念 事务ACID&#xff1a; A&#xff08;Atomic&#xff09;&#xff1a;原子性&#xff0c;构成事务的所有操作&#xff0c;要么都执行完成&#xff0c;要么全部不执行&#xff0c;不可能出现部分成功部分失 败的情况。 C&#xff08;Consistency&…

软件设计师——法律法规(四)

&#x1f4d1;前言 本文主要是【法律法规】——软件设计师——法律法规的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304…

encodeURI 和 encodeURIComponent

encodeURI 和 encodeURIComponent 是用来处理加密 decodeURI 和 decodeURIComponent 是用来处理解密 encodeURI 和encodeURIComponent 区别&#xff1a; 唯一区别就是编码的字符范围 encodeURI方法不会对下列字符编码 ASCII字母 数字 ~!#$&():/,;?’ encodeURIComponent方…

电脑录屏软件大比拼,哪个最适合你?

现如今&#xff0c;电脑录屏软件成为了许多用户记录、分享和教学的重要工具。从游戏玩家到专业制作人员&#xff0c;都需要高效的录屏软件。本文将介绍三款优秀的电脑录屏软件&#xff0c;通过详细的步骤和简洁的介绍&#xff0c;帮助用户轻松掌握这些工具的使用方法。 电脑录屏…

基于springboot+vue的台球管理系统

摘要 台球管理系统是一款基于Spring Boot和Vue.js技术栈构建的现代化系统&#xff0c;旨在提供全面而高效的台球场馆管理服务。该系统通过整合前后端技术&#xff0c;实现了场馆预约、会员管理、比赛统计等核心功能&#xff0c;为台球场馆管理员和玩家提供了便捷、智能的管理和…