Pygame程序的屏幕显示

不同对象的绘制与显示过程

在Pygame中,需要将所有需要在屏幕上显示的内容都绘制在一个display surface上。该Surface通常称为screen surface,它是pygame.display.set_mode()函数返回的Surface对象。

在绘制不同对象时,可以使用不同的绘制方法。下面介绍一些常用的绘制方法:

  • 绘制图像:

    • 使用pygame.image.load()函数加载图像文件,返回一个Surface对象。
    • 将需要绘制的图像blit到screen surface中,使用Surface.blit()方法进行绘制。
  • 绘制文本:

    • 使用pygame.font.Font()函数创建字体对象,该函数接受两个参数:字体文件的路径和字体大小。
    • 使用字体对象的render()方法将文本渲染成Surface对象。
    • 将渲染好的Surface对象blit到screen surface中。
  • 绘制几何图形:

    • 使用pygame.draw.rect()函数绘制矩形。
    • 使用pygame.draw.circle()函数绘制圆形。
    • 使用pygame.draw.line()函数绘制直线等。

Pygame中不同对象的显示过程

在Pygame中,不同对象的显示过程如下:

  1. 颜色填充:

    • 调用screen surface对象的fill()方法,可以将整个screen surface区域或部分screen surface区域填充为指定颜色。
  2. 简单图形:

    • 使用pygame.draw模块下的相关函数,例如pygame.draw.line()绘制直线、pygame.draw.rect()绘制矩形、pygame.draw.circle()绘制圆形等。
    • 将绘制函数的第一个参数指定为screen surface对象,以便将图形绘制在screen surface上。
  3. 图片图像:

    • 使用pygame.image.load()方法加载图片文件,返回一个image surface对象,表示图片的像素信息。
    • 调用screen surface对象的blit()方法,将image surface绘制到screen surface上。blit()方法的第一个参数是要绘制的image surface,第二个参数是一个坐标元组,表示绘制的位置。
  4. 文字:

    • 使用pygame.font.Font()函数创建字体对象,指定字体文件的路径和字体大小。
    • 使用字体对象的render()方法将文字渲染成一个text surface对象。
    • 调用screen surface对象的blit()方法,将text surface绘制到screen surface上。

在绘制完所有对象后,需要调用pygame.display.flip()或pygame.display.update()函数来更新屏幕显示。flip()函数会将screen surface的内容更新到屏幕上,并清除之前的内容。update()函数只会更新有变化的部分,可以提高程序的运行效率。

总之,在Pygame中,颜色填充只需调用fill()方法,简单图形使用相关绘制函数并指定screen surface为第一个参数,图片图像先加载为image surface再使用blit()方法绘制,文字先渲染为text surface再使用blit()方法绘制。最后需要调用flip()或update()函数更新屏幕显示。

在Pygame的画面中移动物体

在Pygame中,要移动物体,可以按照以下步骤进行操作:

  1. 在游戏循环中,使用pygame.Surface.fill()方法或其他绘制函数将物体绘制在屏幕上。
  2. 在每次循环中,更新物体的位置。可以通过改变物体的坐标来实现物体的移动。
  3. 在下一次循环开始之前,使用pygame.Surface.fill()方法或其他绘制函数将物体从原来的位置擦除。
  4. 使用pygame.Surface.blit()方法或其他绘制函数将物体绘制到新的位置上。

注意:

  • 注意对象的绘制顺序,后绘制的对象会把先绘制的对象覆盖住。
  • 注意及时清除屏幕,当在循环中不断绘制某个对象时,若是没有及时清除屏幕,则会导致“重影”现象,特别是在对象移动的情况下;因此在每次重绘时,最好清除屏幕内容,可以利用fill()方法把整个屏幕填充为相同颜色,也可重绘背景图片,具体方法取决于应用场景。
  • 注意记得调用pygame.display.flip()或者pygame.display.update()更新屏幕,否则屏幕上什么都不会显示。

具体示例:一个运动的小球 

import pygame

pygame.init()

# 设置窗口大小
size = [400, 300]
screen = pygame.display.set_mode(size)

# 设置窗口标题
pygame.display.set_caption("Moving Ball")

# 设置背景颜色
bg_color = (255, 255, 255)

# 设置小球初始位置和速度
ball_pos = [50, 50]
ball_speed = [2, 2]

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

    # 清除屏幕
    screen.fill(bg_color)

    # 移动小球
    ball_pos[0] += ball_speed[0]
    ball_pos[1] += ball_speed[1]

    # 如果小球碰到边界,就反弹回来
    if ball_pos[0] < 0 or ball_pos[0] > size[0]:
        ball_speed[0] = -ball_speed[0]
    if ball_pos[1] < 0 or ball_pos[1] > size[1]:
        ball_speed[1] = -ball_speed[1]

    # 绘制小球
    pygame.draw.circle(screen, (255, 0, 0), ball_pos, 10)

    # 刷新屏幕
    pygame.display.flip()

    # 控制帧率
    pygame.time.Clock().tick(60)

# 退出程序
pygame.quit()

在上面的代码中,首先初始化了Pygame库,创建一个窗口,并设置了窗口标题和背景颜色。

然后定义了小球的初始位置和速度,以及游戏循环中需要处理的事件。

在游戏循环中,首先清除屏幕,然后移动小球的位置,并处理小球碰到边界的情况,使其反弹回来。

接下来,通过pygame.draw.circle()函数绘制了一个红色的小球,

最后通过pygame.display.flip()刷新屏幕,让绘制的内容显示出来。

在每次循环结束后,调用pygame.time.Clock().tick(60)控制帧率,从而保证程序的运行速度不会过快或过慢。

通过上面的代码,实现了一个简单的运动小球,并且可以通过修改参数和添加功能,实现自己想要的效果。

 

相关推荐

  1. Android-AR眼镜屏幕显示

    2024-01-13 06:02:02       23 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-13 06:02:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-13 06:02:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-13 06:02:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-13 06:02:02       20 阅读

热门阅读

  1. 使用Docker部署PDF多功能工具Stirling-PDF

    2024-01-13 06:02:02       35 阅读
  2. c# ref和out参数修饰符

    2024-01-13 06:02:02       36 阅读
  3. 生成并压缩多个word文件,写入response

    2024-01-13 06:02:02       28 阅读
  4. jenkins设置Jenkinsfile的pipeline脚本 nohup运行

    2024-01-13 06:02:02       38 阅读
  5. 解决chromebook kabylake安装linux没有声音问题

    2024-01-13 06:02:02       40 阅读
  6. @KafkaListener指定kafka集群

    2024-01-13 06:02:02       30 阅读
  7. HTML5中form表单防止重复提交的两种方法

    2024-01-13 06:02:02       41 阅读
  8. VUE 前端框架学习总结

    2024-01-13 06:02:02       29 阅读
  9. Spring Boot 构建工具插件

    2024-01-13 06:02:02       40 阅读
  10. Web3.0是如何影响未来互联网发展的

    2024-01-13 06:02:02       38 阅读