页面利用渐进式JPEG来提升用户体验度


Posted in PHP onDecember 01, 2014

今天才认识到原来JPEG文件有两种保存方式他们分别是Baseline JPEG(标准型)和Progressive JPEG(渐进式)。两种格式有相同尺寸以及图像数据,他们的扩展名也是相同的,唯一的区别是二者显示的方式不同。

Baseline JPEG

这种类型的JPEG文件存储方式是按从上到下的扫描方式,把每一行顺序的保存在JPEG文件中。打开这个文件显示它的内容时,数据将按照存储时的顺序从上到下一行一行的被显示出来,直到所有的数据都被读完,就完成了整张图片的显示。如果文件较大或者网络下载速度较慢,那么就会看到图片被一行行加载的效果,这种格式的JPEG没有什么优点,因此,一般都推荐使用Progressive JPEG。

页面利用渐进式JPEG来提升用户体验度

Progressive JPEG

和Baseline一遍扫描不同,Progressive JPEG文件包含多次扫描,这些扫描顺寻的存储在JPEG文件中。打开文件过程中,会先显示整个图片的模糊轮廓,随着扫描次数的增加,图片变得越来越清晰。这种格式的主要优点是在网络较慢的情况下,可以看到图片的轮廓知道正在加载的图片大概是什么。在一些网站打开较大图片时,你就会注意到这种技术。

页面利用渐进式JPEG来提升用户体验度

渐进式图片带来的好处是可以让用户在没有下载完图片就可以看到最终图像的大致轮廓,一定程度上可以提升用户体验。(瀑布留的网站建议还是使用标准型的)

页面利用渐进式JPEG来提升用户体验度

另外渐进式的图片的大小并不会和基本的图片大小相差很多,有时候可能会比基本图片更小。渐进式的图片的缺点就是吃用户的CPU和内存,不过对于现在的电脑来说这点图片的计算并不算什么。

说了这边多下面就改讲讲怎么讲图片保存为或者转化为Progressive JPEG了。

1、PhotoShop

在photoshop中有“存储为web所用格式”,打开后选择“连续”就是渐进式JPEG。

页面利用渐进式JPEG来提升用户体验度 

具体教程参考 https://3water.com/photoshop/182198.html

2、Linux

检测是否为progressive jpeg : identify -verbose filename.jpg | grep Interlace(如果输出 None 说明不是progressive jpeg;如果输出 Plane 说明是 progressive jpeg。)

将basic jpeg转换成progressive jpeg:> convert infile.jpg -interlace Plane outfile.jpg

3、PHP

使用 imageinterlace 和 imagejpeg 函数我们可以轻松解决转换问题。

<?php
    $im = imagecreatefromjpeg('pic.jpg');
    imageinterlace($im, 1);
    imagejpeg($im, './php_interlaced.jpg', 100);
    imagedestroy($im);
?>

4、Python

import PIL
from exceptions import IOError
img = PIL.Image.open("c:\\users\\biaodianfu\\pictures\\in.jpg")
destination = "c:\\users\\biaodianfu\\pictures\\test.jpeg"
try:
  img.save(destination, "JPEG", quality=80, optimize=True, progressive=True)
except IOError:
  PIL.ImageFile.MAXBLOCK = img.size[0] * img.size[1]
  img.save(destination, "JPEG", quality=80, optimize=True, progressive=True)

5、jpegtran

jpegtran -copy none -progressive <inputfile> <outputfile>

6、C#

using (Image source = Image.FromFile(@"D:\temp\test2.jpg")) { 
  ImageCodecInfo codec = ImageCodecInfo.GetImageEncoders().First(c => c.MimeType == "image/jpeg"); 
  EncoderParameters parameters = new EncoderParameters(3);
  parameters.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 100L);
  parameters.Param[1] = new EncoderParameter(System.Drawing.Imaging.Encoder.ScanMethod, (int)EncoderValue.ScanMethodInterlaced);
  parameters.Param[2] = new EncoderParameter(System.Drawing.Imaging.Encoder.RenderMethod, (int)EncoderValue.RenderProgressive); 
  source.Save(@"D:\temp\saved.jpg", codec, parameters);
}

以上就是使用渐进式JPEG图片来提升页面体验度的全部内容了,很简单实用,这里推荐给小伙伴们。

PHP 相关文章推荐
PHP5新特性: 更加面向对象化的PHP
Nov 18 PHP
php SQL Injection with MySQL
Feb 27 PHP
php 记录进行累加并显示总时长为秒的结果
Nov 04 PHP
PHP+MySQL统计该库中每个表的记录数并按递减顺序排列的方法
Feb 15 PHP
Yii调试查看执行SQL语句的方法
Jul 15 PHP
浅谈php中的访问修饰符private、protected、public的作用范围
Nov 20 PHP
详解php实现页面静态化原理
Jun 21 PHP
thinkPHP框架实现多表查询的方法
Jun 14 PHP
PHP结合Ffmpeg快速搭建流媒体服务的实践记录
Oct 31 PHP
Laravel框架控制器的middleware中间件用法分析
Sep 30 PHP
laravel实现按月或天或小时统计mysql数据的方法
Oct 09 PHP
php页面函数设置超时限制的方法
Dec 01 #PHP
PHP实现抓取HTTPS内容
Dec 01 #PHP
php设置静态内容缓存时间的方法
Dec 01 #PHP
thinkphp实现发送邮件密码找回功能实例
Dec 01 #PHP
PHP清除字符串中所有无用标签的方法
Dec 01 #PHP
php防止网站被刷新的方法汇总
Dec 01 #PHP
phpstorm编辑器乱码问题解决
Dec 01 #PHP
You might like
PHP+Mysql+jQuery实现动态展示信息
2011/10/08 PHP
js脚本分页代码分享(7种样式)
2015/08/19 Javascript
页面向下滚动ajax获取数据的实现方法(兼容手机)
2016/05/24 Javascript
Jqprint实现页面打印
2017/01/06 Javascript
Angular2使用Angular CLI快速搭建工程(一)
2017/05/21 Javascript
浅谈JS中的常用选择器及属性、方法的调用
2017/07/28 Javascript
js实现canvas图片与img图片的相互转换的示例
2017/08/31 Javascript
基于Vue实现微信小程序的图文编辑器
2018/07/25 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
2018/09/13 Javascript
vue实现与安卓、IOS交互的方法
2018/11/02 Javascript
vue实现公共方法抽离
2020/07/31 Javascript
javascript实现打砖块小游戏(附完整源码)
2020/09/18 Javascript
Python中多线程及程序锁浅析
2015/01/21 Python
Python编程实现输入某年某月某日计算出这一天是该年第几天的方法
2017/04/18 Python
python 限制函数调用次数的实例讲解
2018/04/21 Python
django用户登录和注销的实现方法
2018/07/16 Python
对python 匹配字符串开头和结尾的方法详解
2018/10/27 Python
python验证身份证信息实例代码
2019/05/06 Python
Python使用微信接入图灵机器人过程解析
2019/11/04 Python
pycharm永久激活超详细教程
2020/10/29 Python
使用jquery实现HTML5响应式导航菜单教程
2014/04/02 HTML / CSS
老海军美国官网:Old Navy
2016/09/05 全球购物
澳大利亚潮流尖端的快时尚品牌:Cotton On
2016/09/26 全球购物
加拿大高尔夫超市:Golf Town
2018/01/12 全球购物
英国假发网站:Hothair
2018/02/23 全球购物
苏格兰销售女装、男装和童装的连锁店:M&Co
2018/03/16 全球购物
size?法国官网:英国伦敦的球鞋精品店
2020/03/15 全球购物
上班玩手机检讨书
2014/02/17 职场文书
大学生职业规划书的范本
2014/02/18 职场文书
社区优秀志愿者先进事迹
2014/05/09 职场文书
2016年教师寒假学习心得体会
2015/10/09 职场文书
导游词之嵊泗列岛
2019/10/30 职场文书
带你彻底理解JavaScript中的原型对象
2021/04/14 Javascript
JavaWeb实现显示mysql数据库数据
2022/03/19 Java/Android
SQLServer权限之只开启创建表权限
2022/04/12 SQL Server
在NumPy中深拷贝和浅拷贝相关操作的定义和背后的原理
2022/04/14 Python