本文经受权转自 PHPHub 社区php
Intervention/image 是为 Laravel 定制的图片处理工具, 它提供了一套易于表达的方式来建立、编辑图片。git
本文章由 The EST Group 成员 @monkey 撰写, 首发地为 PHPHub 社区.github
Demo 代码请见:https://github.com/zhengjinghua/est-image-demoshell
请参照文档 如何利用 Homestead 快速运行一个 Laravel 项目.数组
安装;缓存
修改配置信息;微信
基础用法;app
特点功能.composer
接下来是详细解说.框架
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, // ... ],
此扩展包默认使用 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' );
到此, 此拓展包即安装成功!
// 修改指定图片的大小 $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);
除上文介绍的基本用法以外, 此扩展包还支持:
图片上传功能;
图片缓存功能;
图片过滤功能: 将图片按照统一规则进行转换;
图片动态处理: 根据访问图片的 URL 参数自动调整图片大小
更多的例子请移步 官方文档 参考.
欢迎关注 LaravelTips
, 一个专一于为 Laravel 开发者服务, 致力于帮助开发者更好的掌握 Laravel 框架, 提高开发效率的微信公众号.