Intervention/image 图片处理扩展包的安装和使用

9 篇文章 1 订阅

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

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

Demo
Demo 截图

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,
    // ...
  ],
  1. 图片处理库的配置
    此扩展包默认使用 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);
  1. 特色功能
    除上文介绍的基本用法之外,此扩展包还支持:

图片上传功能;
图片缓存功能;
图片过滤功能:将图片按照统一规则进行转换;
图片动态处理:根据访问图片的 URL 参数自动调整图片大小
更多的例子请移步 官方文档 参考.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值