Intervention Image 是一个PHP图片操作处理库,为图片创建、修改及压缩等处理提供了便捷方式。此外,还提供了服务提供者和门面以便集成到Laravel应用中。
1、安装
安装Intervention Image之前,需要确保PHP版本>=5.4并且安装了Fileinfo扩展,以及GD库(>=2.0)或者Imagick扩展(>=6.5.7)。
我们使用Composer在命令行安装最新版本的Intervention Image:
composer require intervention/image
2、集成到Laravel
前面已经提到,Intervention Image 提供了相应的服务提供者和门面以便集成到Laravel应用。
安装好Intervention Image后,打开config/app.php
,注册如下服务提供者到$providers
数组:
Intervention\Image\ImageServiceProvider::class
然后添加如下门面到$aliaes
数组:
'Image' => Intervention\Image\Facades\Image::class
这样我们就可以在Laravel应用代码中直接使用Image
了。
3、配置
默认情况下,Intervention Image使用PHP的GD库扩展处理所有图片,如果你想要切换到Imagick,你可以将配置文件拉到应用中:
php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"
这样对应的配置文件会被拷贝到config/image.php
,这样你可以在该配置文件中修改图片处理驱动配置。
4、使用示例
Route::get('/', function(){ $img = Image::make('foo.jpg')->resize(300, 200); return $img->response('jpg'); });
更多使用方法请参考 Intervention Image 官方文档:http://image.intervention.io/
在 Laravel 5 中集成 Intervention Image 实现对图片的创建、修改和压缩处理
Intervention Image是一个PHP图片操作处理库,为图片创建、修改及压缩等处理提供了便捷方式。此外,还提供了服务提供者和门面以便集成到Laravel应用中。
1、安装
安装Intervention Image之前,需要确保PHP版本>=5.4并且安装了Fileinfo扩展,以及GD库(>=2.0)或者Imagick扩展(>=6.5.7)。
我们使用Composer在命令行安装最新版本的Intervention Image:
composer require intervention/image
执行命令后,会在项目composer.json文件中的require中增加如下图所示:
2、集成到Laravel
前面已经提到,Intervention Image 提供了相应的服务提供者和门面以便集成到Laravel应用。
安装好Intervention Image后,打开config/app.php
,注册如下服务提供者到$providers
数组:
然后添加如下门面到$aliaes
数组:
这样我们就可以在Laravel应用代码中直接使用Image
了。
3. 基础用法
使用时,如果laravel版本较高的已经引入命名空间的,需要在使用的时候,引用一下Image的命名空间,否则找不到该类。
4.具体用法
读取图像
从文件读图像
这个方法是高度定制的,不只能用路径,下面的输入格式都可以:
- 基于文件系统的图像路径
- 图像URL (
allow_url_fopen
必须启用). - 二进制图像数据
- Data-URL 编码图像数据
- Base64 编码图像数据
- PHP资源类型的gd.(在使用 GD 驱动时)
- Imagick实例 (在使用 Imagick 驱动时)
- Intervention\Image\Image 实例
- SplFileInfo 实例 (用来处理器Laravel 文件上传 通过 Symfony\Component\HttpFoundation\File\UploadedFile)
可以去API文档看更多例子。
创建新图像的更多例子,去看API文档。
看看下面的列表的一些方法。