页面利用渐进式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 相关文章推荐
模拟OICQ的实现思路和核心程序(二)
Oct 09 PHP
基于mysql的bbs设计(二)
Oct 09 PHP
PHP实现用户认证及管理完全源码
Mar 11 PHP
PHP 函数语法介绍一
Jun 14 PHP
php 创建以UNIX时间戳命名的文件夹(示例代码)
Mar 08 PHP
PHP连接sql server 2005环境配置及问题解决
Aug 08 PHP
php+MySQL判断update语句是否执行成功的方法
Aug 28 PHP
Yii2 输出xml格式数据的方法
May 03 PHP
详细对比php中类继承和接口继承
Oct 11 PHP
laravel 操作数据库常用函数的返回值方法
Oct 11 PHP
使用laravel根据用户类型来显示或隐藏字段
Oct 17 PHP
tp5.1 框架数据库高级查询技巧实例总结
May 25 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
全国FM电台频率大全 - 6 辽宁省
2020/03/11 无线电
论坛头像随机变换代码
2006/10/09 PHP
PHP 程序授权验证开发思路
2009/07/09 PHP
WordPress开发中短代码的实现及相关函数使用技巧
2016/01/05 PHP
laravel 框架结合关联查询 when()用法分析
2019/11/22 PHP
js实现运动logo图片效果及运动元素对象sportBox使用方法
2012/12/25 Javascript
firefox浏览器不支持innerText的解决方法
2013/08/07 Javascript
写得不错的jquery table鼠标经过变色代码
2013/09/27 Javascript
JavaScript splice()方法详解
2020/09/22 Javascript
Js实现手机发送验证码时按钮延迟操作
2014/06/20 Javascript
Json实现异步请求提交评论无需跳转其他页面
2014/10/11 Javascript
javascript实现任务栏消息提示的简单实例
2016/05/31 Javascript
NODE.JS跨域问题的完美解决方案
2016/10/20 Javascript
详解Node.js串行化流程控制
2017/05/04 Javascript
JS Object.preventExtensions(),Object.seal()与Object.freeze()用法实例分析
2018/08/25 Javascript
详解Node.js读写中文内容文件操作
2018/10/10 Javascript
微信小程序简单的canvas裁剪图片功能详解
2019/07/12 Javascript
vue把输入框的内容添加到页面的实例讲解
2019/11/11 Javascript
Python实现的简单万年历例子分享
2014/04/25 Python
Python学习笔记之if语句的使用示例
2017/10/23 Python
Python定时发送消息的脚本:每天跟你女朋友说晚安
2018/10/21 Python
python实现电子书翻页小程序
2019/07/23 Python
pytorch模型预测结果与ndarray互转方式
2020/01/15 Python
Pycharm无法打开双击没反应的问题及解决方案
2020/08/17 Python
Pycharm创建文件时自动生成文件头注释(自定义设置作者日期)
2020/11/24 Python
全球工业:Global Industrial
2020/02/01 全球购物
介绍一下Prototype的$()函数,$F()函数,$A()函数都是什么作用?
2014/03/05 面试题
银行贷款承诺书
2014/03/29 职场文书
入党积极分子评语
2014/05/04 职场文书
幼儿园课题实施方案
2014/05/14 职场文书
解除财产保全担保书
2014/05/20 职场文书
学校党的群众路线教育实践活动对照检查材料
2014/09/24 职场文书
上课玩手机的检讨书
2014/10/01 职场文书
2015社区个人工作总结范文
2015/05/13 职场文书
导师鉴定意见
2015/06/05 职场文书
负责培养人意见
2015/06/05 职场文书