Intervention/image 圖片處理擴展包的安裝和使用

本文經受權轉自 PHPHub 社區php

說明

Intervention/image 是爲 Laravel 定製的圖片處理工具, 它提供了一套易於表達的方式來建立、編輯圖片。git

本文章由 The EST Group 成員 @monkey 撰寫, 首發地爲 PHPHub 社區.github

Demo 代碼請見:https://github.com/zhengjinghua/est-image-demoshell

Demo

Demo 截圖

Demo 運行

請參照文檔 如何利用 Homestead 快速運行一個 Laravel 項目.數組

文章概覽

  1. 安裝;緩存

  2. 修改配置信息;微信

  3. 基礎用法;app

  4. 特點功能.composer

接下來是詳細解說.框架

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 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);

4. 特點功能

除上文介紹的基本用法以外, 此擴展包還支持:

  • 圖片上傳功能;

  • 圖片緩存功能;

  • 圖片過濾功能: 將圖片按照統一規則進行轉換;

  • 圖片動態處理: 根據訪問圖片的 URL 參數自動調整圖片大小

更多的例子請移步 官方文檔 參考.


歡迎關注 LaravelTips, 一個專一於爲 Laravel 開發者服務, 致力於幫助開發者更好的掌握 Laravel 框架, 提高開發效率的微信公衆號.

相關文章
相關標籤/搜索