Pygmae都能很好的支持,具体支持的格式如下:
JPEG(Join Photograhpic Exper Group),极为常用,一般后缀名为.jpg或者.jpeg。数码相机、网上的图片基本都是这种格式。这是一种有损压缩方式,尽管对图片质量有些损坏,但对于减小文件尺寸非常棒。优点很多只是不支持透明。PNG(Portable Network Graphics)将会大行其道的一种格式,支持透明,无损压缩。对于网页设计,软件界面设计等等都是非常棒的选择!GIF 网上使用的很多,支持透明和动画,只是只能有256种颜色,软件和游戏中使用很少BMP Windows上的标准图像格式,无压缩,质量很高但尺寸很大,一般不使用PCXTGATIFLBM, PBMXPM对于Pygame而已,加载图片就是pygame.image.load,给它一个文件名然后就还给你一个surface对象。尽管读入的图像格式各不相同,surface对象隐藏了这些不同。你可以对一个Surface对象进行涂画、变形、复制等各种操作。事实上,屏幕也只是一个surface,pygame.display.set_mode就返回了一个屏幕surface对象。
一种方法就是刚刚说的pygame.image.load,这个surface有着和图像相同的尺寸和颜色;另外一种方法是指定尺寸创建一个空的surface,下面的语句创建一个256×256像素的surface:
bland_surface = pygame.Surface((256, 256))如果不指定尺寸,那么就创建一个和屏幕一样大小的。
你还有两个参数可选,第一个是flags:
HWSURFACE – 类似于前面讲的,更快!不过最好不设定,Pygmae可以自己优化。SRCALPHA – 有Alpha通道的surface,如果你需要透明,就要这个选项。这个选项的使用需要第二个参数为32~第二个参数是depth,和pygame.display.set_mode中的一样,你可以不设定,Pygame会自动设的和display一致。不过如果你使用了SRCALPHA,还是设为32吧:
bland_alpha_surface = pygame.Surface((256, 256), flags=SRCALPHA, depth=32)转换Surfaces
通常你不用在意surface里的具体内容,不过也许需要把这些surface转换一下以获得更高的性能,还记得一开始的程序中的两句话吗:
background = pygame.image.load(background_image_filename).convert()mouse_cursor = pygame.image.load(mouse_image_filename).convert_alpha()第一句是普通的转换,相同于display;第二句是带alpha通道的转换。如果你给convert或者conver_alpha一个surface对象作为参数,那么这个会被作为目标来转换。
矩形对象(Rectangle Objects)
一般来说在制定一个区域的时候,矩形是必须的,比如在屏幕的一部分画东西。在pygame中矩形对象极为常用,它的指定方法可以用一个四元素的元组,或者两个二元素的元组,前两个数为左上坐标,后两位为右下坐标。
Pygame中有一个Rect类,用来存储和处理矩形对象(包含在pygame.locals中,所以如果你写了from pygame.locals import *就可以直接用这个对象了),比如:
my_rect1 = (100, 100, 200, 150)my_rect2 = ((100, 100), (200, 150))#上两种为基础方法,表示的矩形也是一样的my_rect3 = Rect(100, 100, 200, 150)my_rect4 = Rect((100, 100), (200, 150))剪裁(Clipping)
通常游戏的时候你只需要绘制屏幕的一部分。比如魔兽上面是菜单,下面是操作面板,中间的小兵和英雄打的不可开交时候,上下的部分也是保持相对不动的。为了实现这一点,surface就有了一种叫裁剪区域(clipping area)的东西,也是一个矩形,定义了哪部分会被绘制,也就是说一旦定义了这个区域,那么只有这个区域内的像素会被修改,其他的位置保持不变,默认情况下,这个区域是所有地方。我们可以使用set_clip来设定,使用get_clip来获得这个区域。
下面几句话演示了如何使用这个技术来绘制不同的区域:
screen.set_clip(0, 400, 200, 600)draw_map()#在左下角画地图screen.set_clip(0, 0, 800, 60)draw_panel()#在上方画菜单面板子表面(Subsurfaces)
Subsurface就是在一个Surface中再提取一个Surface,记住当你往Subsurface上画东西的时候,同时也向父表面上操作。这可以用来绘制图形文字,尽管pygame.font可以用来写很不错的字,但只是单色,游戏可能需要更丰富的表现,这时候你可以把每个字母(中文的话有些吃力了)各自做成一个图片,不过更好的方法是在一张图片上画满所有的字母。把整张图读入,然后再用Subsurface把字母一个一个“抠”出来,就像下面这样:
my_font_image = Pygame.load("font.png")letters = []letters["a"] = my_font_image.subsurface((0,0), (80,80))letters["b"] = my_font_image.subsurface((80,0), (80,80))填充Surface
填充有时候可以作为一种清屏的操作,把整个surface填上一种颜色:
screen.fill((0, 0, 0))同样可以提供一个矩形来制定填充哪个部分(这也可以作为一种画矩形的方法)。
设置Surface的像素
我们能对Surface做的最基本的操作就是设置一个像素的色彩了,虽然我们基本不会这么做,但还是要了解。set_at方法可以做到这一点,它的参数是坐标和颜色,下面的小脚本会随机的在屏幕上画点:
#coding=utf-8'''Created on 2017年3月4日@author: zxt'''import pygamefrom pygame.locals import QUITfrom sys import exitfrom random import randintimport timepygame.init()screen = pygame.display.set_mode((640, 480), 0, 32)while True: for event in pygame.event.get(): if event.type == QUIT: pygame.display.quit() exit() screen.fill((255, 255, 255)) screen.lock() for i in xrange(100): rand_col = (randint(0, 255), randint(0, 255), randint(0, 255)) rand_pos = (randint(0, 639), randint(0, 479)) pygame.draw.rect(screen, rand_col, (rand_pos, (3, 3))) #screen.set_at(rand_pos, rand_col) time.sleep(0.01) screen.unlock() pygame.display.update()获得Surface上的像素
set_at的兄弟get_at可以帮我们做这件事,它接受一个坐标返回指定坐标点上的颜色。不过记住get_at在对hardware surface操作的时候很慢,而全屏的时候总是hardware的,所以慎用这个方法!
锁定Surface
当Pygame往surface上画东西的时候,首先会把surface锁住,以保证不会有其它的进程来干扰,画完之后再解锁。锁和解锁时自动发生的,所以有时候可能不那么有效率,比如上面的例子,每次画100个点,那么就得锁解锁100次,现在我们把两句注释去掉,再执行看看是不是更快了(好吧,其实我没感觉出来,因为现在的机器性能都不错,这么点的差异还不太感觉的出来。不过请相信我~复杂的情况下会影响效率的)?
当你手动加锁的时候,一定不要忘记解锁,否则pygame有可能会失去响应。虽然上面的例子可能没问题,但是隐含的bug是我们一定要避免的事情。
Blitting
blit的的中文翻译给人摸不着头脑的感觉,可以译为位块传送(bit block transfer),其意义是将一个平面的一部分或全部图象整块从这个平面复制到另一个平面,下面还是直接使用英文。
blit是对表面做的最多的操作,我们在前面的程序中已经多次用到,不多说了;blit的还有一种用法,往往用在对动画的表现上,比如下例通过对frame_no的值的改变,我们可以把不同的帧(同一副图的不同位置)画到屏幕上:
screen.blit(ogre, (300, 200), (100 * frame_no, 0, 100, 100))
新闻热点
疑难解答