Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解


Posted in PHP onNovember 14, 2017

前言

Intervention/image 是为 Laravel 定制的图片处理工具, 它提供了一套易于表达的方式来创建、编辑图片。

Demo 代码请见:

Github:https://github.com/zhengjinghua/est-image-demo

本地下载:http://xiazai.3water.com/201711/yuanma/est-image-demo(3water.com).rar

Demo

Demo 截图

Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解

Demo 运行

请参照文档 如何利用 Homestead 快速运行一个 Laravel 项目.

文章概览

  • 安装;
  • 修改配置信息;
  • 基础用法;
  • 特色功能.

接下来是详细解说.

1. 安装

1). 使用 composer 安装:

composer require intervention/image

上面的命令会

2). 修改 app/config/app.php 添加 ServiceProvider:

// 将下面代码添加到 providers 数组中
'providers' => [
 // ...
 Intervention\Image\ImageServiceProvider::class,
 // ...
 ],


// 将下面代码添加到 aliases 数组中
'aliases' => [
 // ...
 'Image' => Intervention\Image\Facades\Image::class,
 // ...
 ],

2. 图片处理库的配置

此扩展包默认使用 PHP 的 GD 库来进行图像处理, 但由于 GD 库对图像的处理效率要稍逊色于 imagemagick 库, 因此这里推荐替换为 imagemagick 库来进行图像处理.

开始之前, 你得先确定本地已经安装好 GD 或 Imagick.

在使用 Intervention Image 的时候, 你只需要给 ImageManager 传一个数组参数就可以完成 GD 和 Imagick 库之间的互相切换.

如下所示:

// 引入 composer autoload
require 'vendor/autoload.php';

// 导入 Intervention Image Manager Class
use Intervention\Image\ImageManager;

// 通过指定 driver 来创建一个 image manager 实例
$manager = new ImageManager(array('driver' => 'imagick'));

// 最后创建 image 实例
$image = $manager->make('public/foo.jpg')->resize(300, 200);

另外你也可以使用 ImageManager 的静态版本, 如下所示:

// 引入 composer autoload
require 'vendor/autoload.php';

// 导入 Intervention Image Manager Class
use Intervention\Image\ImageManagerStatic as Image;

// 通过指定 driver 来创建一个 image manager 实例 (默认使用 gd)
Image::configure(array('driver' => 'imagick'));

// 最后创建 image 实例
$image = Image::make('public/foo.jpg')->resize(300, 200);

生成 config/image.php 配置文件:

php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"

运行上面的命令后, 会在项目中生成 config/image.php 配置文件, 打开此文件并将 driver 修改成 imagick:

return array(
 'driver' => 'imagick'
);

到此, 此拓展包即安装成功!

3. 基础用法

// 修改指定图片的大小
$img = Image::make('images/avatar.jpg')->resize(200, 200);

// 插入水印, 水印位置在原图片的右下角, 距离下边距 10 像素, 距离右边距 15 像素
$img->insert('images/watermark.png', 'bottom-right', 15, 10);

// 将处理后的图片重新保存到其他路径
$img->save('images/new_avatar.jpg');

/* 上面的逻辑可以通过链式表达式搞定 */
$img = Image::make('images/avatar.jpg')->resize(200, 200)->insert('images/new_avatar.jpg', 'bottom-right', 15, 10);

4. 特色功能

除上文介绍的基本用法之外, 此扩展包还支持:

  • 图片上传功能;
  • 图片缓存功能;
  • 图片过滤功能: 将图片按照统一规则进行转换;
  • 图片动态处理: 根据访问图片的 URL 参数自动调整图片大小

更多的例子请移步 官方文档 参考.

intervention/image 中的一个小坑及其破解之法

事实上 intervention/iamge 用了很有些时日了,它的 api 设计得很简洁,文档也很全面,用起来相当顺手。

不过最近无意间发现了一个小坑。因为需要合成带微信头像的二维码,我使用 Image::make($avatarUrl) (这里的 $avatarUrl 是微信头像的链接)来产生头像,然后合成到二维码图像中去(还包括一些其它操作,比如使用模板背景、写入文字)。

写完之后一运行,发现相当慢,平均耗时 23 秒左右。起初以为是因为合成过程中进行的操作比较多、尺寸比较大,本来就应该是这个速度。不过后来闲下来,开始试着优化,即使不能提升速度,至少也搞清楚到底是什么原因这么耗时。

这一通折腾下来,发现真相竟然与合成操作的多少、尺寸没有多大关系。而关键在于我创建头像数据的姿势。

为了说明这个问题,特意写了下面的代码进行对比。

// 记录开始时间
$startTimestamp = microtime(true);

$url = 'http://wx.qlogo.cn/mmopen/XxT9TiaJ1ibf06TNRCMjQADS4opDHvQLguLZHpqkRlvuJYZicvJW4iaOalPsKIs0kpZ3F6864ZzibyObYiaucUQSrdp4pFTNDyIpxw/0';

$avatar = \Image::make($url);

// 记录结束时间
$endTimestamp = microtime(true);

info($startTimestamp);
info($endTimestamp);
info($endTimestamp - $startTimestamp);

Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解

上面这段代码使用 Image::make($url) 的形式,直接从 url 生成头像。从记录的日志数据来看,耗时基本上在 16 秒左右。

后来,想到了一个新姿势,其实也就是在尝试优化的过程中折腾时想到的。见下面代码:

$startTimestamp = microtime(true);

$client = new \GuzzleHttp\Client();

$url = 'http://wx.qlogo.cn/mmopen/XxT9TiaJ1ibf06TNRCMjQADS4opDHvQLguLZHpqkRlvuJYZicvJW4iaOalPsKIs0kpZ3F6864ZzibyObYiaucUQSrdp4pFTNDyIpxw/0';

$avatarResponse = $client->get($url);

$avatar = \Image::make($avatarResponse->getBody()->getContents());

$endTimestamp = microtime(true);

info($startTimestamp);
info($endTimestamp);
info($endTimestamp - $startTimestamp);

在这里我先使用 GuzzleHttp 获取头像,再使用 Image::make($data) 创建头像。

注意,要高潮了…… sunglasses

看看下面的日志截图,三次平均耗时在 0.07 秒左右,和前面的 16 秒相比,差了 200 多倍。

Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解

至于为什么会出现这种现象,自己也没搞清楚,但这无疑是一点比较有用且小众的经验。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
几种有用的变型 PHP中循环语句的用法介绍
Jan 30 PHP
PHP JS Ip地址及域名格式检测代码
Sep 27 PHP
php打造智能化的柱状图程序,用于报表等
Jun 19 PHP
腾讯CMEM的PHP扩展编译安装方法
Sep 25 PHP
PHP利用APC模块实现大文件上传进度条的方法
Oct 29 PHP
PHP中加速、缓存扩展的区别和作用详解(eAccelerator、memcached、xcache、APC )
Jul 09 PHP
PHP简单检测网址是否能够正常打开的方法
Sep 04 PHP
PHP入门教程之表单与验证实例详解
Sep 11 PHP
Yii2.0 Basic代码中路由链接被转义的处理方法
Sep 21 PHP
PHP二进制与字符串之间的相互转换教程
Oct 14 PHP
AES加解密在php接口请求过程中的应用示例
Oct 26 PHP
phpStorm+XDebug+chrome 配置详解
Apr 01 PHP
PHP中递归的实现实例详解
Nov 14 #PHP
利用Homestead快速运行一个Laravel项目的方法详解
Nov 14 #PHP
PHP对称加密算法(DES/AES)类的实现代码
Nov 14 #PHP
浅谈PHP中如何实现Hook机制
Nov 14 #PHP
PHP实现将几张照片拼接到一起的合成图片功能【便于整体打印输出】
Nov 14 #PHP
PHP封装的XML简单操作类完整实例
Nov 13 #PHP
PHP开发中解决并发问题的几种实现方法分析
Nov 13 #PHP
You might like
php基础设计模式大全(注册树模式、工厂模式、单列模式)
2015/08/31 PHP
深入理解PHP内核(一)
2015/11/10 PHP
JavaScript入门学习书籍推荐
2008/06/12 Javascript
JavaScript入门教程(6) Window窗口对象
2009/01/31 Javascript
JS 遮照层实现代码
2010/03/31 Javascript
跨浏览器的 mouseenter mouseleave 以及 compareDocumentPosition的使用说明
2010/05/04 Javascript
图片上传插件jquery.uploadify详解
2013/11/15 Javascript
浅谈javascript六种数据类型以及特殊注意点
2013/12/20 Javascript
JavaScript弹出窗口方法汇总
2014/08/12 Javascript
JavaScript动态改变div属性的实现方法
2015/07/22 Javascript
基于javascript实现图片滑动效果
2016/05/07 Javascript
node.js爬取中关村的在线电瓶车信息
2018/11/13 Javascript
JavaScript模板引擎实现原理实例详解
2018/12/14 Javascript
如何在Vue.js中实现标签页组件详解
2019/01/02 Javascript
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析
2019/05/22 Javascript
JS实现商品橱窗特效
2020/01/09 Javascript
完美解决vue 中多个echarts图表自适应的问题
2020/07/19 Javascript
vue从后台渲染文章列表以及根据id跳转文章详情详解
2020/12/14 Vue.js
python基于windows平台锁定键盘输入的方法
2015/03/05 Python
Python  pip安装lxml出错的问题解决办法
2017/02/10 Python
Python实现学生成绩管理系统
2020/04/05 Python
Python 十六进制整数与ASCii编码字符串相互转换方法
2018/07/09 Python
Python mutiprocessing多线程池pool操作示例
2019/01/30 Python
Python通过kerberos安全认证操作kafka方式
2020/06/06 Python
Python异常处理机制结构实例解析
2020/07/23 Python
Python中logger日志模块详解
2020/08/04 Python
利用HTML5实现使用按钮控制背景音乐开关
2015/09/21 HTML / CSS
国际化的太阳镜及太阳镜配件零售商:Sunglass Hut
2016/07/26 全球购物
DogBuddy荷兰:找到你最完美的狗保姆
2019/04/17 全球购物
农业大学毕业生的个人自我评价
2013/10/11 职场文书
减负增效提质方案
2014/05/23 职场文书
雷人标语集锦
2014/06/19 职场文书
2014年国庆标语
2014/06/30 职场文书
Django基础CBV装饰器和中间件
2022/03/22 Python
vue3引入highlight.js进行代码高亮的方法实例
2022/04/08 Vue.js
详解SQL报错盲注
2022/07/23 SQL Server