圖像處理
安裝擴展
使用Composer安裝ThinkPHP5的圖像處理類庫:
composer require topthink/think-image
圖像操作
下面來看下圖像操作類的基礎方法。
打開圖像文件
假設當前入口文件目錄下面有一個image.png文件,如圖所示:

使用open方法打開圖像文件進行相關操作:
$image = \think\Image::open('./image.png');
也可以從直接獲取當前請求中的文件上傳對象,例如:
$image = \think\Image::open(request()->file('image'));
獲取圖像信息
可以獲取打開圖片的信息,包括圖像大小、類型等,例如:
$image = \think\Image::open('./image.png');
// 返回圖片的寬度
$width = $image->width();
// 返回圖片的高度
$height = $image->height();
// 返回圖片的類型
$type = $image->type();
// 返回圖片的mime類型
$mime = $image->mime();
// 返回圖片的尺寸數(shù)組 0 圖片寬度 1 圖片高度
$size = $image->size();
裁剪圖片
使用crop和save方法完成裁剪圖片功能。
$image = \think\Image::open('./image.png');
//將圖片裁剪為300x300并保存為crop.png
$image->crop(300, 300)->save('./crop.png');
生成的圖片如圖:

支持從某個坐標開始裁剪,例如下面從(100,30)開始裁剪,例如:
$image = \think\Image::open('./image.png');
//將圖片裁剪為300x300并保存為crop.png
$image->crop(300, 300,100,30)->save('./crop.png');
生成的圖片如圖:

生成縮略圖
使用thumb方法生成縮略圖,例如:
$image = \think\Image::open('./image.png');
// 按照原圖的比例生成一個最大為150*150的縮略圖并保存為thumb.png
$image->thumb(150, 150)->save('./thumb.png');
生成的縮略圖如圖所示:
我們看到實際生成的縮略圖并不是150*150,因為默認采用原圖等比例縮放的方式生成縮略圖,最大寬度是150。
可以支持其他類型的縮略圖生成,設置包括\think\Image的下列常量或者對應的數(shù)字:
//常量,標識縮略圖等比例縮放類型
const THUMB_SCALING = 1;
//常量,標識縮略圖縮放后填充類型
const THUMB_FILLED = 2;
//常量,標識縮略圖居中裁剪類型
const THUMB_CENTER = 3;
//常量,標識縮略圖左上角裁剪類型
const THUMB_NORTHWEST = 4;
//常量,標識縮略圖右下角裁剪類型
const THUMB_SOUTHEAST = 5;
//常量,標識縮略圖固定尺寸縮放類型
const THUMB_FIXED = 6;
比如我們居中裁剪:
$image = \think\Image::open('./image.png');
// 按照原圖的比例生成一個最大為150*150的縮略圖并保存為thumb.png
$image->thumb(150,150,\think\Image::THUMB_CENTER)->save('./thumb.png');
后生成的縮略圖效果如圖:

再比如我們右下角剪裁
$image = \think\Image::open('./image.png');
// 按照原圖的比例生成一個最大為150*150的縮略圖并保存為thumb.png
$image->thumb(150,150,\think\Image::THUMB_SOUTHEAST)->save('./thumb.png');
生成的縮略圖效果如圖:

這里就不再對其他用法一一舉例了。
圖像翻轉
使用flip可以對圖像進行翻轉操作,默認是以x軸進行翻轉,例如:
$image = \think\Image::open('./image.png');
// 對圖像進行以x軸進行翻轉操作
$image->flip()->save('./filp_image.png');
生成的效果如圖:

我們也可以改變參數(shù),以y軸進行翻轉,例如:
$image = \think\Image::open('./image.png');
// 對圖像進行以y軸進行翻轉操作
$image->flip(\think\image::FLIP_Y)->save('./filp_image.png');
生成的效果如圖:

圖像的翻轉可以理解為圖像的鏡面效果與圖像旋轉有所不同。
圖像旋轉
使用rotate可以對圖像進行旋轉操作(默認是順時針旋轉90度),我們用默認90度進行旋轉舉例:
$image = \think\Image::open('./image.png');
// 對圖像使用默認的順時針旋轉90度操作
$image->rotate()->save('./rotate_image.png');
生成的效果如圖:

圖像保存參數(shù)
save方法可以配置的參數(shù)
| 參數(shù) | 默認 | 描述 |
|---|---|---|
| pathname | 必填項 | 圖像保存路徑名稱 |
| type | 默認與原圖相同 | 圖像類型 |
| quality | 80 | 圖像質量 |
| interlace | true | 是否對JPEG類型圖像設置隔行掃描 |
設置隔行掃描的情況下在網頁進行瀏覽時。是從上到下一行一行的顯示,否則圖片整個顯示出來 然后由模糊到清晰顯示。
添加水印
系統(tǒng)支持添加圖片及文字水印,下面依次舉例說明
添加圖片水印,我們下載官網logo文件到根目錄進行舉例:
$image = \think\Image::open('./image.png');
// 給原圖左上角添加水印并保存water_image.png
$image->water('./logo.png')->save('water_image.png');
water方法的第二個參數(shù)表示水印的位置,默認值是WATER_SOUTH,可以傳入下列\think\Image類的常量或者對應的數(shù)字:
//常量,標識左上角水印
const WATER_NORTHWEST = 1;
//常量,標識上居中水印
const WATER_NORTH = 2;
//常量,標識右上角水印
const WATER_NORTHEAST = 3;
//常量,標識左居中水印
const WATER_WEST = 4;
//常量,標識居中水印
const WATER_CENTER = 5;
//常量,標識右居中水印
const WATER_EAST = 6;
//常量,標識左下角水印
const WATER_SOUTHWEST = 7;
//常量,標識下居中水印
const WATER_SOUTH = 8;
//常量,標識右下角水印
const WATER_SOUTHEAST = 9;
我們用左上角來進行測試:
$image = \think\Image::open('./image.png');
// 給原圖左上角添加水印并保存water_image.png
$image->water('./logo.png',\think\Image::WATER_NORTHWEST)->save('water_image.png');
生成的圖片效果如下:

還可以支持水印圖片的透明度(0~100,默認值是100),例如:
$image = \think\Image::open('./image.png');
// 給原圖左上角添加透明度為50的水印并保存alpha_image.png
$image->water('./logo.png',\think\Image::WATER_NORTHWEST,50)->save('alpha_image.png');
生成的圖片效果如下:

也可以支持給圖片添加文字水?。ㄎ覀儚椭埔粋€字體文件HYQingKongTiJ.ttf到入口目錄),我們現(xiàn)在生成一個像素20px,顏色為#ffffff的水印效果:
$image = \think\Image::open('./image.png');
// 給原圖左上角添加水印并保存water_image.png
$image->text('十年磨一劍 - 為API開發(fā)設計的高性能框架','HYQingKongTiJ.ttf',20,'#ffffff')->save('text_image.png');
生成的圖片效果:

文字水印參數(shù)
文字水印比較多,在此只做說明不做演示了
| 參數(shù) | 默認 | 描述 |
|---|---|---|
| text | 不能為空 | 添加的文字 |
| font | 不能為空 | 字體文件路徑 |
| size | 不能為空 | 字號,單位是像素 |
| color | #00000000 | 文字顏色 |
| locate | WATER_SOUTHEAST | 文字寫入位置 |
| offset | 0 | 文字相對當前位置的偏移量 |
| angle | 0 | 文字傾斜角度 |
