Intervention Image是一个开源的PHP图像处理和操作库,可不依赖于框架单独使用,也提供了对Laravel的友好支持。它提供了一种创建PHP图像处理,编辑和合成图像且富有表现力的简便方法,并支持当前两个最常见的图像处理库:GD Library和Imagick。
编写该类是为了使PHP图像操作更容易和更具表现力。 无论您是要创建图像缩略图,水印还是对大型图像文件进行格式化,Intervention Image都可以帮助您以最少的代码行轻松地管理每个任务。
支持对图片尺寸/质量压缩、图片合并、添加水印等常用功能。
环境
及以下库二选一
安装
$ composer require intervention/image
复制
用法
// import the Intervention Image Manager Class
use Intervention\Image\ImageManager;
// create an image manager instance with favored driver
$manager = new ImageManager(array('driver' => 'imagick'));
// to finally create image instances
$image = $manager->make('public/foo.jpg')->resize(300, 200);
复制
或使用静态方法
// import the Intervention Image Manager Class
use Intervention\Image\ImageManagerStatic as Image;
// configure with favored image driver (gd by default)
Image::configure(array('driver' => 'imagick'));
// and you are ready to go ...
$image = Image::make('public/foo.jpg')->resize(300, 200);
复制
在Laravel中的用法配置
在 config/app.php 中配置 providers
Intervention\Image\ImageServiceProvider::class
复制
配置 aliases
'Image' => Intervention\Image\Facades\Image::class
复制
生成配置文件
此扩展包默认使用GD库来进行图片处理,但由于 GD 库对图像的处理效率要稍逊色于 ImageMagick 库,因此推荐替换为 ImageMagick 库来进行图像处理。(如果遇到不稳定、超时、未响应等问题,建议替换为 imagemagick 库)
$ php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravelRecent"
复制
执行此命令会在 config 文件夹下新增 image.php 配置文件,里面可配置扩展包驱动,默认为 GD
用法
$image = Image::make($path);
// 尺寸等比压缩,最大宽度800
if (($width = $image->getWidth()) > 800) {
// 等比缩放,需要计算宽度缩放的比例,再计算出缩放后的图片高度
$proportion = $width / 800;
$height = ceil($image->getHeight() / $proportion);
$image = $image->resize(800, $height);
}
// 保存图片,并设置质量压缩为70
$image->save($path, 70);
复制
ImageMagick 库
安装扩展库
# 安装 ImageMagick 库
$ yum install -y ImageMagick ImageMagick-devel
# 安装PHP扩展
$ pecl install imagick
复制
修改 php.ini
extension=imagick.so
复制
最后重启 php-fpm
$ php-fpm restart
复制
(编辑:92站长网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|