有损vs无损

图片文件格式有可能会对图片的文件大小进行不同程度的压缩,图片的压缩分为有损压缩和无损压缩两种。

有损压缩。指在压缩文件大小的过程中,损失了一部分图片的信息,也即降低了图片的质量,并且这种损失是不可逆的,我们不可能从有一个有损压缩过的图片中恢复出全来的图片。常见的有损压缩手段,是按照一定的算法将临近的像素点进行合并。

无损压缩。只在压缩文件大小的过程中,图片的质量没有任何损耗。我们任何时候都可以从无损压缩过的图片中恢复出原来的信息。

索引色vs直接色

计算机在表示颜色的时候,有两种形式,一种称作索引颜色(Index Color),一种称作直接颜色(Direct Color)。

索引色。用一个数字来代表(索引)一种颜色,在存储图片的时候,存储一个数字的组合,同时存储数字到图片颜色的映射。这种方式只能存储有限种颜色,通常是256种颜色,对应到计算机系统中,使用一个字节的数字来索引一种颜色。

直接色。使用四个数字来代表一种颜色,这四个数字分别代表这个颜色中红色、绿色、蓝色以及透明度。现在流行的显示设备可以在这四个维度分别支持256种变化,所以直接色可以表示2的32次方种颜色。当然并非所有的直接色都支持这么多种,为压缩空间使用,有可能只有表达红、绿、蓝的三个数字,每个数字也可能不支持256种变化之多。

点阵图vs矢量图

点阵图,也叫做位图,像素图。构成点阵图的最小单位是象素,位图就是由象素阵列的排列来实现其显示效果的,每个象素有自己的颜色信息,在对位图图像进行编辑操作的时候,可操作的对象是每个象素,我们可以改变图像的色相、饱和度、明度,从而改变图像的显示效果。点阵图缩放会失真,用最近非常流行的沙画来比喻最恰当不过,当你从远处看的时候,画面细腻多彩,但是当你靠的非常近的时候,你就能看到组成画面的每粒沙子以及每个沙粒的颜色。

矢量图,也叫做向量图。矢量图并不纪录画面上每一点的信息,而是纪录了元素形状及颜色的算法,当你打开一付矢量图的时候,软件对图形象对应的函数进行运算,将运算结果[图形的形状和颜色]显示给你看。无论显示画面是大还是小,画面上的对象对应的算法是不变的,所以,即使对画面进行倍数相当大的缩放,其显示效果仍然相同(不失真)。

BMP

BitMap的缩写,是无损的、既支持索引色也支持直接色的、点阵图。

这是一种比较老的图片格式。BMP是无损的,但同时这种图片格式几乎没有对数据进行压缩,所以BMP格式的图片通常具有较大的文件大小。虽然同时支持索引色和直接色是一个优点,但是太大的文件格式格式导致它几乎没有用武之地,现在除了在Windows操作系统中还比较常见之外,我们几乎看不到它。从上图中可以看到,在同样的图片质量下,BMP格式的图片文件大小是GIF格式的很多倍。

GIF

全称Graphics Interchange Format,采用LZW压缩算法进行编码。

是无损的、采用索引色的、点阵图。GIF是无损的,采用GIF格式保存图片不会降低图片质量。但得益于数据的压缩,GIF格式的图片,其文件大小要远小于BMP格式的图片。文件小,是GIF格式的优点,同时,GIF格式还具有支持动画以及透明的优点。但,GIF格式仅支持8bit的索引色,即在整个图片中,只能存在256种不同的颜色。GIF格式适用于对色彩要求不高同时需要文件体积较小的场景,比如企业Logo、线框类的图等。因其体积小的特点,现在GIF被广泛的应用在各类网站中。

JPEG

JPEG是有损的、采用直接色的、点阵图。

JPEG图片格式的设计目标,是在不影响人类可分辨的图片质量的前提下,尽可能的压缩文件大小。这意味着JPEG去掉了一部分图片的原始信息,也即是进行了有损压缩。JPEG的图片的优点,是采用了直接色,得益于更丰富的色彩,JPEG非常适合用来存储照片,用来表达更生动的图像效果,比如颜色渐变。与GIF相比,JPEG不适合用来存储企业Logo、线框类的图。因为有损压缩会导致图片模糊,而直接色的选用,又会导致图片文件较GIF更大。

PNG-8

PNG全称Portable Network Graphics,PNG-8是PNG的索引色版本。PNG-8是无损的、使用索引色的、点阵图。

PNG是一种比较新的图片格式,PNG-8是非常好的GIF格式替代者,在可能的情况下,应该尽可能的使用PNG-8而不是GIF,因为在相同的图片效果下,PNG-8具有更小的文件体积。除此之外,PNG-8还支持透明度的调节,而GIF并不支持。 现在,除非需要动画的支持,否则我们没有理由使用GIF而不是PNG-8。当然了,PNG-8本身也是支持动画的,只是浏览器支持得不好,不像GIF那样受到广泛的支持。可以看到PNG-8具有更好的透明度支持。

PNG-24

PNG-24是PNG的直接色版本。

PNG-24是无损的、使用直接色的、点阵图。无损的、使用直接色的点阵图,听起来非常像BMP,是的,从显示效果上来看,PNG-24跟BMP没有不同。PNG-24的优点在于,它压缩了图片的数据,使得同样效果的图片,PNG-24格式的文件大小要比BMP小得多。当然,PNG24的图片还是要比JPEG、GIF、PNG-8大得多。虽然PNG-24的一个很大的目标,是替换JPEG的使用。但一般而言,PNG-24的文件大小是JPEG的五倍之多,而显示效果则通常只能获得一点点提升。所以,只有在你不在乎图片的文件体积,而想要最好的显示效果时,才应该使用PNG-24格式。另外,PNG-24跟PNG-8一样,是支持图片透明度的。

SVG

全称Scalable Vector Graphics,是无损的、矢量图。

SVG跟上面这些图片格式最大的不同,是SVG是矢量图。这意味着SVG图片由直线和曲线以及绘制它们的方法组成。当你放大一个SVG图片的时候,你看到的还是线和曲线,而不会出现像素点。这意味着SVG图片在放大时,不会失真,所以它非常适合用来绘制企业Logo、Icon等。 SVG是很多种矢量图中的一种,它的特点是使用XML来描述图片。借助于前几年XML技术的流行,SVG也流行了很多。使用XML的优点是,任何时候你都可以把它当做一个文本文件来对待,也就是说,你可以非常方便的修改SVG图片,你所需要的只需要一个文本编辑器。SVG并非只能绘制简单的Logo类的图片,它可以绘制出精致的图片的,比如下面这涨,嗯。

WebP

WebP是谷歌开发的一种新图片格式,WebP是同时支持有损和无损压缩的、使用直接色的、点阵图。

从名字就可以看出来它是为Web而生的,什么叫为Web而生呢?就是说相同质量的图片,WebP具有更小的文件体积。现在网站上充满了大量的图片,如果能够降低每一个图片的文件大小,那么将大大减少浏览器和服务器之间的数据传输量,进而降低访问延迟,提升访问体验。在无损压缩的情况下,相同质量的WebP图片,文件大小要比PNG小26%;在有损压缩的情况下,具有相同图片精度的WebP图片,文件大小要比JPEG小25%~34%;WebP图片格式支持图片透明度,一个无损压缩的WebP图片,如果要支持透明度只需要22%的格外文件大小。想象Web上的图片之多,百分之几十的提升,是非常非常大的优化。只可惜,目前只有Chrome浏览器和Opera浏览器支持WebP格式,所以WebP的应用并不广泛。为了使用更先进的技术,比如WebP图片格式,来压缩互联网上传输的数据流量,谷歌甚至提供了Chrome Data Compression Proxy,设置了Chrome Data Compression Proxy作为Web代理之后,你访问的所有网站中的图片,在经过Proxy的时候,都会被转换成WebP格式,以降低图片文件的大小。

referencePNG vs. GIF vs. JPEG vs. SVG - When best to use?https://zh.wikipedia.org/wiki/%E5%8F%AF%E7%B8%AE%E6%94%BE%E5%90%91%E9%87%8F%E5%9C%96%E5%BD%A2https://developers.google.com/speed/webp/ High Performance Browser Networking by Ilya Grigorik

作者:赵鑫
链接:https://www.zhihu.com/question/20028452/answer/142593276
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

几种常见图片格式优缺点分析相关推荐

  1. 几种常见PCB表面处理优缺点分析,用对场景很重要

    作为一个在PCB生产行业做了15年的工程师,遇到过很多的小问题,往往是在设计的过程中,不注意一些小细节造成的,那么在PCB的生产过程中也会造成一定的影响.一些软件上的小问题.过孔时的注意事项,这都是基 ...

  2. 几种常见图片文件格式的优缺点

    本文主要介绍和比较几种常见图片文件格式的优缺点. 1.有损vs无损 图片文件格式有可能会对图片的文件大小进行不同程度的压缩,图片的压缩分为有损压缩和无损压缩两种. 有损压缩.指在压缩文件大小的过程中, ...

  3. 前端常见图片格式整理

    前端常见图片格式整理 PNG (Portable Network Graphics,便携式网络图形,1996) PNG有8位.24位.32位三种形式,其中8位PNG支持两种不同的透明形式(索引透明和a ...

  4. threejs加载obj模型_倾斜摄影三维模型几种常见的格式,你能说出哪些?

    本文首发于公众号Wish3D,原文链接:倾斜摄影三维模型几种常见的格式,你能说出哪些? 无人机航拍的影像经过建模软件处理产出之时,有很多成果的数据需要我们去选择输出,对于新手而言,如何选择数据格式呢? ...

  5. 常见图片格式与调色算法

    一.常见图片格式 1):JPEG 格式 同等于 JPG 和 JPE 格式 有损压缩 储存空间小 除RGB三色外,无法保留透明度.动画等任何信息 颜色品质不错,但是在压缩过程中图像品质会有着肉眼可见的下 ...

  6. 几种基本图片格式的区别与不同(bmp,jpg,png,gif,tif)

    Hello,我们又见面了! 本文为EricNTH的原创博客,转载请注明出处. 本文写于两年前,有一万多阅读,本人实在激动,便扩充了webp.ico.svg.raw等内容,修正了原有的错误内容,搬到了我 ...

  7. diy 扫地机器人 滚刷_无滚刷PK有滚刷:关于保洁机器人两种常见清扫结构的分析...

    目前市面上销售的保洁机器人从底部清扫结构上来看,主要分为两种结构类型:一类是以iRobot Roomba为代表的有滚刷三段式清扫结构,另一类则是以V-BOT为代表无滚刷双重清扫结构,今天爸爸乐轻松网主 ...

  8. c语言判断后缀是否为bmp,c语言_常见图片格式判断

    c语言_常见图片格式判断 我想尽各种思路.今天,终于把图片判断搞定了. 在此,我写一下我的思路.希望对那些不想看代码的朋友们有帮助. 常风的的图片格式有:bmp,png,jpg,gif等图片格式. 我 ...

  9. JPG格式图片怎么弄?分享两种转换图片格式方法

    将图片格式转换成JPG格式应该怎么弄呢?大家在日常中经常会使用图片,有很多的图片格式是我们使用不到的,碰到个别的图片格式我们可能还会打不开.遇到这种情况时,我们可以把图片的格式转换成我们最常使用的JP ...

最新文章

  1. EOS账户和钱包综合指南
  2. Android SQlite数据库的使用(三)-将数据库文件连同应用程序一起发布
  3. FastCGI模块(FastCGI)
  4. keil mdk5安装
  5. Spring data elasticsearch的使用
  6. Linux 之八 完整嵌入式 Linux 环境、(交叉)编译工具链、CPU 体系架构、嵌入式系统构建工具
  7. hdu 2586 How far away ?
  8. Web文件的ContentType类型大全
  9. 巴巴运动网学习笔记(36-40)
  10. gephi java教程_Gephi的使用--以社交网络图为例
  11. python 3的33个保留字列表_python 33个保留字是什么意思
  12. 收藏 | 使用 Mask-RCNN 在实例分割应用中克服过拟合
  13. php array_key_exists() 与 isset() 的区别
  14. 网页中Flash播放器常用参数设置(转)
  15. libcudart.so.8.0 cannot open shared object file: No such file or directory
  16. 理解允许定位,音频,网络电话..
  17. groupby多个字段性能_SQL 性能优化
  18. ROS语音交互系统_(2)利用讯飞TTS实现ROS下语音合成播报
  19. python毕业设计题目推荐汽车销售系统
  20. 如何入门网络爬虫,摸索一年的心里路程

热门文章

  1. 脚本实现监控APP的专项数据:CPU 内存 电量 流量
  2. 【JavaScript】JS处理32位整型位运算
  3. getElementById的用法
  4. 程序员如何获得中级工程师高级工程师职称
  5. Oracle Tuning的一些总结 --葛宏宾
  6. ie检查服务器证书吊销,检查服务器证书吊销选项在哪里?服务器证书无效怎么办?...
  7. Web前端开发——CSS样式(Ⅱ)背景、超链接样式
  8. 遵义微红科技浅谈怎样经营社区团购平台才能提升成功率?
  9. 地统计分析工具GS+9.0
  10. 手机显示网关服务器未开,小森生活无可用网关服务器怎么回事?无可用网关服务器解决方法[多图]...