图片加载原理

那年仲夏 提交于 2019-11-29 04:11:30

图片加载 是有 CPU GPU 联合协作的

CPU 是 用来计算 视图创建 视图frame 图片解码(将压缩的图片数据解码成未压缩的位图形式,为什么要压缩图片,因为图片数据太大,实际上不管是JPEG还是PNG 都是一种压缩的位图图形格式,只不过PNG 图片是无损压缩,并且支持alpha通道。而JPEG图片则是有损压缩,可以指定0 - 100%的压缩比。然而,将磁盘中图片渲染到屏幕之前,必须要得到图片的原始像素数据,才能让GPU渲染,GPU渲染流程 :

1.GPU获取图片的坐标

2.将坐标交给顶点着色器

3.将图片光栅化(获取图片对应屏幕上的像素点)

4.片元着色器计算(计算每个像素点的最终显示颜色值)

5.从帧缓冲区(Frame buffer)中渲染到屏幕上。

图片解压缩的原理:

当未解压缩的图片要渲染到屏幕时,系统会在主线程对图片进行解压缩,而如果图片已经解压缩了,系统就不会再对图片进行解压缩。因此,要在子线程提前对图片进行强制解压缩即可

而强制解压缩的原理就是对图片进行重新绘制,得到一张新的解压缩后的位图。核心函数是

CGBitmapContentCreate 创建一个位图上下文

CGContextDrawImage 将原始数据绘制到上下文中

 CGBitmapContextCreateImage 创建一张新的解压缩后的位图

 开源框架 YYImage ,SDWebImage 都是这个原理

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!