前端性能调优 sprite图片

对于图片文件,我们不可以用yui-compressor进行压缩,但是我们可以吧若干个小图片sprite成一张大图片然后给出每个图片的坐标,从而减少网络IO的次数开销。


具体步骤是:


(1)压缩所有的图片文件成一个zip包

(2)上传到以下地址:http://spritegen.website-performance.org/

(3)然后它就会产生一个报告然后告诉你css的改变并且创建sprite后的图片

这个sprite后的图片如下:

23113415_3UYM.png

然后对应的坐标也改变了,如下:

23113415_WAQn.png


然后我们就可以直接移植到项目中使用了。

本文出自 “平行线的凝聚” 博客,请务必保留此出处http://supercharles888.blog.51cto.com/609344/1213140

转载于:https://my.oschina.net/yangff/blog/186830

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用`pygame.sprite.Sprite`类可以更方便地管理和绘制多个图片对象。下面是一个使用Sprite类实现图片动画的示例代码: ```python import pygame pygame.init() # 窗口大小 win_width = 500 win_height = 500 # 创建窗口 win = pygame.display.set_mode((win_width, win_height)) pygame.display.set_caption("Sprite Animation") # 加载图片 img1 = pygame.image.load("img1.png") img2 = pygame.image.load("img2.png") img3 = pygame.image.load("img3.png") # 设置动画帧数 fps = 10 # 创建时钟 clock = pygame.time.Clock() # 创建精灵组 sprites = pygame.sprite.Group() # 定义精灵类 class MySprite(pygame.sprite.Sprite): def __init__(self, img, x, y): super().__init__() self.image = img self.rect = self.image.get_rect() self.rect.x = x self.rect.y = y # 创建精灵对象 sprite1 = MySprite(img1, 50, 50) sprite2 = MySprite(img2, 150, 50) sprite3 = MySprite(img3, 250, 50) sprites.add(sprite1, sprite2, sprite3) # 运行游戏 run = True while run: # 控制帧数 clock.tick(fps) # 监听事件 for event in pygame.event.get(): if event.type == pygame.QUIT: run = False # 重绘窗口 win.fill((255, 255, 255)) sprites.draw(win) pygame.display.update() # 退出pygame pygame.quit() ``` 在上述代码中,我们首先加载了三张图片,并设置了动画帧数。然后创建了一个精灵组,并定义了一个精灵类,该类继承自`pygame.sprite.Sprite`类,并重写了`__init__`方法,用于初始化精灵对象的属性。然后创建了三个精灵对象,将它们添加到精灵组中。在每一帧重新绘制窗口时,我们只需要用`sprites.draw(win)`方法即可将精灵组中的所有精灵对象绘制到窗口上。 使用Sprite类实现图片动画时,我们可以更方便地管理和操作多个图片对象,而且代码也更加简洁和易读。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值