位图/矢量图/GIF/PNG/JPEG/WEBP一网打尽

news2025/1/10 23:39:38

想把一件事做好,那就先把眼前的小事攻克

大家好,我是「柒八九」。一个「专注于前端开发技术/RustAI应用知识分享」Coder

前言

最近,在做项目资源打包优化。如果大家做过类似的工作,在操作过程中,想必有一个资源肯定是绕不开的。那就是「图片资源」。无论,我们项目是用Webpack还是Vite亦或是Rspack

因为,作为一个功能完备的项目,或多或少都会用到图片(首页功能介绍/轮播图),然后针对图片的格式又有很多。这就需要我们对项目中不同的图片资源做针对性的处理。常规的操作基本就是「压缩」。这点我们在前端项目里都有啥?有过介绍。

alt

而我们今天不是将如何在项目中优化图片资源,而是像大家科普一下「那些不为人知的图片知识」。下面的内容,我们都是选择我们平时开发中常见的知识点,针对一些特别拗口的东西,我们就不介绍了。

好了,天不早了,干点正事哇。

alt

我们能所学到的知识点

  1. 栅格图(位图) vs 矢量图
  2. 位图常见格式
  3. 图片转换网站

1. 栅格图(位图) vs 矢量图

什么是栅格图?

下面是从维基百科中截取的关于栅格图[1]的介绍。

alt

就像图片中截取的那样,栅格图「像素」为主要信息的载体,通过内部的值的变化来呈现我们页面中想要显示的内容。

下面的笑脸图案就是一个栅格图。当放大时,单个像素会呈现为正方形。进一步放大,可以分析

每个像素,它们的颜色是通过绿的数值组合构成的。

alt

像我们平时见到的GIF/PNG/JPEG/WEBP都属于栅格图。看到这些图片格式,是不是感觉到倍感亲切。没关系,我们下文中会着力介绍他们。

其中,栅格图其实还有一个大家耳熟能详的名字 - 位图(Bitmap Graphics)。

alt

还有一点,再多啰嗦点,不知道大家看到Raster/Bitmap是不是感觉在哪里见过。(如果大家看过之前的像素是怎样练成的)。

alt

也就是说栅格图/位图是浏览器内置的一种显示格式。大千世界,就是这么神奇。更加一步讲,如果我们不做特殊说明和处理,我们在浏览器中看到的图像信息都是以像素为基础的。(这点和我们即将要讲到的矢量图有天壤之别)

正因为栅格图是基于像素的,它能够显示让人叹为观止的视觉表现,但也正是这一点导致它们在可扩展性网络性能等方面的能力欠佳。

任何位图图形中的像素数量都是固定的,这意味着任何尝试调整大小/放大都将导致失真和/或模糊的视觉效果,因为系统无法凭空创建额外的像素。

矢量图

我们继续从维基百科中寻找关于矢量图[2]的信息。

alt

从上面的信息,我们可以得知。矢量图是使用「数学公式」生成的,这些公式转化为在网格上对齐的点、线和曲线。

矢量图不是基于像素的,这意味着在调整大小时不受限制。它们是分辨率独立的 - 我们可以调整矢量图形的大小而不会丢失质量或出现视觉伪影。

矢量图可以帮助我们创建性能友好的 UI 设计元素、可以无限缩放,或者以极低成本制作的快速加载的解释性动画。基于这些特性,我们如果考虑网络性能时并且图像的还原度不是很高的话,我们一般首选SVG(可缩放的矢量图)。

矢量图形常见于 SVGWMFEPSPDFCDRAI 类型的图形文件格式。

位图和矢量图如何抉择

那么说了这么多,我们该在项目中如何抉择使用哪个格式的图片信息进行图片信息的展示呢?

  • 如果我们项目中如果对图像展示有较高的要求,那么我们就需要选择 位图,但是由于其文件资源较大,我们在兼顾展示的情况下还需要做一点的优化处理。
  • 如果项目中对色彩还原度不是很高,并且还需要兼容PC/移动端等弱网环境,那么在一些不是很重要的部分(图标/Icon等)就可以选用 矢量图

一言以蔽之:位图能够表现更多的色彩能力,但是它的文件较大并且对显示媒介的分辨率依赖性极强,而矢量图在牺牲了色彩细节,但是它具有很高的延展性。

下面,我们就介绍一下我们常见的图片格式。


2. 位图常见格式

上节中我们从内部实现原理角度来简单介绍了位图矢量图。这节我们来位图中常见的格式(Gif/Png/JPeg/Webp),并且每种格式各自的优缺点和对应的适用场景。

常见位图格式及特性支持

色彩支持

alt
  • .gif:每像素8位:256种颜色
  • .jpg(.jpeg):每通道8位:1600万+种颜色
  • .png(apng):每通道8位:1600万+种颜色
  • .webp:每通道8位:1600万+种颜色

透明度

alt
  • .gif:1位透明度,像素要么透明要么不透明
  • .jpg(.jpeg):不支持透明度
  • .png(apng):支持完全半透明
  • .webp:支持完全半透明

是否支持动画

alt
  • .gif:支持
  • .jpg(.jpeg):不支持
  • .apng:支持(这里是 apng不是 png)
  • .webp:支持

文件初始大小和压缩性能

alt
  • .gif:无损压缩,文件大小较大
  • .jpg(.jpeg):有损压缩,文件大小较小
  • .png(apng):无损或接近无损压缩,更好的质量
  • .webp:有损压缩,文件大小较小

兼容性

alt
  • .gif:兼容性良好
  • .jpg(.jpeg):兼容性良好
  • .png(apng):在浏览器端兼容良好
  • .webp:在浏览器端兼容良好

基于上面的各种特性,我们可以用一个表格来展示。

扩展名色彩支持透明度压缩最佳用途
.gif每像素8位:256种颜色1位透明度,像素要么透明要么不透明无损压缩,文件大小较大较小的图形,颜色有限,短动画
.jpg, .jpeg每通道8位:1600万+种颜色不支持透明度有损压缩,文件大小较小全彩照片
.png, .apng每通道8位:1600万+种颜色支持完全半透明无损或接近无损压缩,更好的质量含有文本的图形和设计
.webp每通道8位:1600万+种颜色支持完全半透明有损压缩,文件大小较小Web图像,尤其是照片

GIF

我们继续从维基百科中寻找关于-GIF[3]的介绍。 alt

总结上面的信息可得出,GIFGraphics Interchange Format,图形交换格式)是一种无损、低分辨率和低帧率的图像格式,于1987年发明。它与所有网络浏览器兼容,易于嵌入到各种网站中。该格式支持256种颜色,不支持半透明效果。GIF文件适用于具有清晰边缘和线条以及少量颜色的图像。

GIF被大家熟知的就是表情包了。在各种社交app中层出不穷。然后它还可以用在公司官网用于展示较短的动态信息。

alt

想必大家在划水时,都是用gif来和朋友斗法。只所以能够以图片形式展示一段动画,就是

动态GIF是将图像或帧组合成单个文件,显示为短视频或动画。

其实,针对GIF还有很多操作和优化空间。例如

  • 分辨率
  • 帧率
  • 速度/持续时间
  • 颜色

如果对这块感兴趣,可以参考gif 优化方案[4]


PNG

来自维基百科的介绍 - PNG[5] alt

总结上面的信息可得出,PNGPortable Network Graphics,便携式网络图形)是一种基于栅格的高质量文件格式,是无损的,支持透明度。它保留了图像的所有细节,并拥有1600万种颜色,因此非常适合复杂的视觉效果。PNG文件可以在几乎任何图像查看器、网络浏览器和图形工具中查看。

这种格式从90年代开始存在,它是「为了替代GIF而创建」的,因为GIF涉及版权费用。它已成为当今网络上最常见的图像格式之一。

PNG是用于徽标、图标、透明背景、具有硬边缘的图形以及颜色较少和/或包含文本的图像的理想选择。

PNG的主要类型如下

  • PNG-8:支持256种颜色
  • PNG-24:支持1600万种颜色
  • PNG-32:支持1600万种颜色以及高级透明度支持

GIF VS PNG

从上面的介绍中我们可以得出GIF算是最早的图片格式,那就意味着后面出现的各种图片格式都是直接或者间接的去弥补它的错误或者增强它的某些特性。

所以,我们下面的每介绍一个图片格式,都会以GIF为标准进行对比。

GIFPNG之间的相似之处是功能性的,因为PNG是设计来取代GIF的。GIFPNG都是由二维颜色点阵(即像素)组成的栅格格式。

PNG相对于GIF的以下3个主要优势:

  1. Alpha通道: PNG的第一个优势是 Alpha通道,提供可变透明度。在 PNG中,每个像素可以具有不同级别的透明度。
  2. 伽马校正:PNG的第二个优势是伽马校正,使得跨平台对比度增强的控制成为可能。
  3. 渐进式图像呈现: PNG的第三个优势与渐进式图像呈现有关;虽然 GIF只有四个通道,但 PNG具有两维交错,七个通道,使其在视觉上更加吸引人。此外,与相似的 GIF相比, PNG可以实现高达25%的更好压缩。

在动画领域,GIF相比PNG有更好的展示效果,所以优先选择GIF格式。PNG旨在成为单一图像格式,并不用于创建动画图形。 尽管有一个名为MNG的支持动画的PNG版本,但由于实际原因,这种格式并不被广泛使用。

然而,还有一种较新的、非官方的PNG扩展称为APNG,它是为了动画目的而创建的。

APNG

APNGAnimated Portable Network Graphics,动态便携式网络图形)是一种栅格图形格式,也是PNG的一个非官方扩展。APNG具有无限帧率、非常好的压缩率和流畅的外观。

这项规范是在2004年创建的,旨在为动态PNG文件提供支持。

APNG使用相同的.png扩展名,支持24位图像和8位透明度,并且可以在FirefoxOperaChrome中打开。

alt

APNG可以被视为GIF的替代品,因为它提供了类似的可视化效果

它具有更高质量的调色板和透明度支持。它不仅比GIF看起来更好,GIF往往会出现像素化和颗粒状的情况,而且它的文件大小更小。


JPEG

来自维基百科的介绍 - JPEG[6]

alt

JPEGJoint Photographic Experts Group,联合摄影专家组)是一种常用于摄影和色彩丰富的图像的图像格式。它是最知名的格式之一,也是数字相机的默认设置。JPEG非常适合于在社交媒体和网站上使用的中等质量、逼真的图像。它的一个优点是被所有浏览器支持,并且可以被所有图像编辑软件编辑。

JPEG具有「有损压缩」,因此每次重新保存和导出图像时,图像的质量都会降低,因为原始数据在此过程中未被保留。

我们可以自由选择压缩的百分比,从0到100%。大多数图形专业人员选择大约60%-70%,因为在这个压缩级别下图像看起来仍然相当好。它不支持透明度或动画。

GIF vs JPEG

GIFJPEG之间的区别在于,对于具有有限色彩调色板的计算机图形(如图标、卡通图片),GIF是更好的选择,而JPEG是更适合照片和色彩丰富的图像,并且在打印时也表现良好。

在进行GIFJPEG比较时,图像质量和文件大小是考虑的两个主要因素。

如前所述,GIFJPEG之间的一个显著区别是JPEG在压缩时会丢失数据,而GIF使用的是无损压缩算法。

WebP

来自维基百科的介绍 - WebP[7] alt

WebP是一种用于网络的图像格式,旨在显示高质量但文件大小较小的图像,以改善加载时间。它可以根据我们的需要进行有损或无损压缩。WebP格式相对较新,因为它是由谷歌旗下的一家公司于2010年创建的。

WebP的主要优势是较小的文件大小,这导致了更好的用户体验和更快的加载时间。它支持透明度,并且据开发人员称,无损的WebP文件比PNG文件小26%

Webp具有很好的兼容性。

alt

GIF vs WebP

GIFWebP之间的区别在于它们的质量。WebP以较小的文件大小提供与GIF相同的质量,因此它显然是更好的选择。

AVIF

来自维基百科的介绍 - AVIF[8]

alt

除了WebP在流行度上的崛起之外,还有另一种现代图像格式旨在取代JPEGPNGGIFAVIF基于AV1视频格式,其压缩性能远远超过上述任何其他格式。这种开源格式于2019年发布,支持动画、透明度和多层图像。

虽然在兼容性方面比其他格式稍逊,但是总体还是可观的。 alt


3. 图片转换网站

针对图片的处理,在平时生活中,我们也需要对图片格式进行转换,图片资源的压缩等操作。

下面,就介绍几种博主平时用到的网站

  1. adobe[9] alt

  2. iloveimg[10] alt

后记

「分享是一种态度」

「全文完,既然看到这里了,如果觉得不错,随手点个赞和“在看”吧。」

alt

Reference

[1]

栅格图: https://en.wikipedia.org/wiki/Raster_graphics

[2]

矢量图: https://en.wikipedia.org/wiki/Vector_graphics

[3]

GIF: https://en.wikipedia.org/wiki/GIF

[4]

gif 优化方案: https://www.svgator.com/blog/animated-gif-best-practices-to-optimize-gifs-like-pros/

[5]

PNG: https://en.wikipedia.org/wiki/PNG

[6]

JPEG: https://en.wikipedia.org/wiki/JPEG

[7]

WebP: https://en.wikipedia.org/wiki/WebP

[8]

AVIF: https://en.wikipedia.org/wiki/AVIF

[9]

adobe: https://www.adobe.com/express/feature

[10]

iloveimg: https://www.iloveimg.com/

本文由 mdnice 多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1580395.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

实战:gcc-11.4.0编译wxWidgets-2.8.12的xrc演示例程

由于我上次编译安装的wxWidgets-2.8.12的abi是1009的,现在编译xrc演示程序也要使用09的abi才能正常运行。 到sourceforge去下载wxGTK-2.8.12,然后解压。 上述的文件夹中有msvc的make, 有watcom的makefile, 还有 unx 的makefile, 在mint-21.3上就用unx这…

配置VM开机自启动

1. 在此电脑-右键选择“管理”-服务和应用程序-服务中找到VMware Workstation Server服务(新版名称也可能是VMware自启动服务,自己找一下,服务属性里有描述信息的),将其启用并选择开机自动启动 新版参考官方文档&…

抖音变现项目有哪些?来这几个资源网站看看吧

做短视频就像是在做一道菜,你得有那么几个秘密武器,才能让你的作品从众多视频中脱颖而出。我这个视频剪辑界的“烹饪大师”,今天就来给大家分享一下我的厨房秘籍——那些让我视频大放异彩的素材网站。九才素材网: 说起九才素材网…

吴恩达深度学习笔记:深层神经网络(Deep Neural Networks)4.1-4.4

目录 第一门课:神经网络和深度学习 (Neural Networks and Deep Learning)第四周:深层神经网络(Deep Neural Networks)4.1 深层神经网络(Deep L-layer neural network)4.2 前向传播和反向传播(Forward and backward pro…

3dmax渲染十几个小时怎么办?3dmax怎么多机渲染

当使用3ds Max进行渲染作业时,如果发现单张图像的渲染时间长达十数小时,这可能是由于计算机硬件配置较低或渲染场景过于复杂所致。为了缩短渲染时间并提高效率,我们可以考虑采用多台计算机进行协同渲染。下面,让我们一起探讨如何通…

Webots常用的执行器(Python版)

文章目录 1. RotationalMotor2. LinearMotor3. Brake4. Propeller5. Pen6. LED 1. RotationalMotor # -*- coding: utf-8 -*- """motor_controller controller."""from controller import Robot# 实例化机器人 robot Robot()# 获取基本仿真步长…

【编译原理】Antlr 入门使用

前面文章我们学习了编译器前端的词法和语法分析工具,本篇我们来看看如何借助 Antlr 工具,快速生成词法和语法分析代码。 一、安装 mac 环境: 1)安装 brew install antlr2)配置 classpath (把 Antlr 的 J…

MySQL -- 07_最流行的查询需求分析(一些分组排序查询、开窗函数 dense_rank、distinct 去重函数 等~)

目录 最流行的查询需求分析07演示数据准备的SQL需求演示36、查询每一门课程成绩都在70分以上的姓名、课程名称和分数group by min() in() 函数 37、查询不及格的课程及学生普通表连接查询 38、查询课程编号为01语文且课程成绩在80分以上的学生的学号和姓名普通表连接查询 39、…

使用axios进行前后端数据传输

最近在和朋友合作写一个新的项目,前后端进行了分离,既然是分离的,肯定需要交互,今天这篇文章详细介绍一下数据交互的一种常见方式:使用axios,希望对大家有所帮助。 前端:以LoginPage.vue登录页面为例&…

扬帆出海扩规模,仍是比亚迪未来的发展关键?

又到了新能源车企公布阶段性成果的时期。 日前,乘联会预估2024年3月全国新能源乘用车厂商批发销量82万辆,同比增长33%,环比增长84%。其中,比亚迪继续领跑,3月销量超30万辆,环比增长147.8%,而这…

OpenHarmony实战:瑞芯微RK3566移植案例(上)

本文章是基于瑞芯微RK3566芯片的khdvk_3566b开发板,进行标准系统相关功能的移植,主要包括产品配置添加,内核启动、升级,音频ADM化,Camera,TP,LCD,WIFI,BT,vib…

中科院发布大模型想象增强法IAG,无需外部资源,想想就能变强

在人工智能领域,尤其是自然语言处理(NLP)的子领域——问答系统(QA)中,知识的获取和利用一直是推动技术进步的核心问题。近年来,大语言模型(LLMs)在各种任务中展现出了惊人…

【C语言】扫雷【附源码】

欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 一、扫雷游戏规则 尽快找到雷区中的所有不是地雷的格子,而不许踩到地雷。点开的数字是几,则说明该数字旁边的8个位置中有几个雷,如果挖开的是地雷,则会输掉游戏。 二、代码思路&…

Laravel 项目如何运行

如有一个 Laravel 项目,在配置好 PHP 版本和运行环境后,可以直接在项目下直接运行: php artisan serve 来启动你的项目。 通过浏览器查看 当项目运行后,默认的启动端口为 8000,可以通过浏览器来进行查看运行的 Larav…

C++性能测试工具

使用示例main.cpp // g-13 -O3 -stdc17 main.cpp profile.cpp #include <iostream> #include <chrono> #include <stdint.h> #include <mutex> // std::mutex#include "profile.h" #include "profile_rdtsc.h"std::mut…

GlusterFS分布式文件系统

一、GlusterFS简介 GlusterFS 是一个开源的分布式文件系统。由存储服务器、客户端以及NFS/Samba存储网关(可选&#xff0c;根据需要选择使用)组成。没有元数据服务器组件&#xff0c;这有助于提升整个系统的性能、可靠性和稳定性 二、GlusterFS特点 2.1 扩展性和高性能 Glu…

Tensorboard以及Transforms初步学习

一.前情提要 1.本文是代码结合知识点&#xff0c;注释即为知识点 2.主要详细讲解Tensorboard以及Transforms代码以及基础知识 3.若想深入学习&#xff0c;建议阅读 P3. Python学习中的两大法宝函数&#xff08;当然也可以用在PyTorch&#xff09;_哔哩哔哩_bilibili 二.简述…

Scala中如何使用Jsoup库处理HTML文档?

在当今互联网时代&#xff0c;数据是互联网应用程序的核心。对于开发者来说&#xff0c;获取并处理数据是日常工作中的重要一环。本文将介绍如何利用Scala中强大的Jsoup库进行网络请求和HTML解析&#xff0c;从而实现爬取京东网站的数据&#xff0c;让我们一起来探索吧&#xf…

云智慧发布对象关系型数据库CloudPanguDB,打破传统技术壁垒

近日&#xff0c;云智慧推出关系型数据库CloudPanguDB&#xff08;中文名称&#xff1a;盘古数据库&#xff09;&#xff0c;旨在通过高兼容性能和创新技术架构&#xff0c;降低企业项目整体运营成本。 无论是处理海量复杂数据&#xff0c;还是构建清晰有序的数据结构关系&…

c++ 谷歌glog日志库使用

效果如图&#xff1a; 本次使用qt环境演示&#xff0c;相关库文件和头文件下载链接&#xff1a;https://download.csdn.net/download/bangtanhui/89108477 将相关库文件和头文件&#xff0c;丢到工程目录下 然后需要在工程pro文件当中引入库文件和头文件&#xff1a; …