Home >Backend Development >PHP Tutorial >使用 Intervention/image 对 Laravel 项目中的图片进行处理

使用 Intervention/image 对 Laravel 项目中的图片进行处理

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-20 12:33:491198browse

说明

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

本文章由 The EST Group 成员 @monkey 撰写, 首发地为PHPHub 社区.

Demo 代码请见: https://github.com/zhengjinghua/est-image-demo

Demo

Demo 截图

Demo 运行

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

文章概览

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

接下来是详细解说.

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 autoloadrequire 'vendor/autoload.php';// 导入 Intervention Image Manager Classuse Intervention\Image\ImageManager;// 通过指定 driver 来创建一个 image manager 实例$manager = new ImageManager(array('driver' => 'imagick'));// 最后创建 image 实例$image = $manager->make('public/foo.jpg')->resize(300, 200);

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

// 引入 composer autoloadrequire 'vendor/autoload.php';// 导入 Intervention Image Manager Classuse 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');

到此, 此拓展包即安装成功 :beers: :beers: :beers:

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 参数自动调整图片大小

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

欢迎关注 LaravelTips , 一个专注于为 Laravel 开发者服务, 致力于帮助开发者更好的掌握 Laravel 框架, 提升开发效率的微信公众号.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn