# 图像处理
## 安装扩展
使用`Composer`安装`ThinkPHP5`的图像处理类库:
```
composer require topthink/think-image
```
## 图像操作
下面来看下图像操作类的基础方法。
### 打开图像文件
假设当前入口文件目录下面有一个`image.png`文件,如图所示:
![](https://box.kancloud.cn/88e25fed9c22b2333334799f8484f952_768x432.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();
// 返回图片的尺寸数组 0 图片宽度 1 图片高度
$size = $image->size();
```
### 裁剪图片
使用`crop`和`save`方法完成裁剪图片功能。
```
$image = \think\Image::open('./image.png');
//将图片裁剪为300x300并保存为crop.png
$image->crop(300, 300)->save('./crop.png');
```
生成的图片如图:
![](https://box.kancloud.cn/b46e4b15f928daf684058dff7077d0af_300x300.png)
支持从某个坐标开始裁剪,例如下面从(100,30)开始裁剪,例如:
```
$image = \think\Image::open('./image.png');
//将图片裁剪为300x300并保存为crop.png
$image->crop(300, 300,100,30)->save('./crop.png');
```
生成的图片如图:
![](https://box.kancloud.cn/b46e4b15f928daf684058dff7077d0af_300x300.png)
### 生成缩略图
使用`thumb`方法生成缩略图,例如:
```
$image = \think\Image::open('./image.png');
// 按照原图的比例生成一个最大为150*150的缩略图并保存为thumb.png
$image->thumb(150, 150)->save('./thumb.png');
```
生成的缩略图如图所示:
我们看到实际生成的缩略图并不是150\*150,因为默认采用原图等比例缩放的方式生成缩略图,最大宽度是150。
可以支持其他类型的缩略图生成,设置包括`\think\Image`的下列常量或者对应的数字:
```
//常量,标识缩略图等比例缩放类型
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');
```
后生成的缩略图效果如图:
![](https://box.kancloud.cn/9f0c37dc57cc38fccb00dbecca801013_150x150.png)
再比如我们右下角剪裁
```
$image = \think\Image::open('./image.png');
// 按照原图的比例生成一个最大为150*150的缩略图并保存为thumb.png
$image->thumb(150,150,\think\Image::THUMB_SOUTHEAST)->save('./thumb.png');
```
生成的缩略图效果如图:
![](https://box.kancloud.cn/144414432d50e94938754a8f775c69af_150x150.png)
这里就不再对其他用法一一举例了。
### 图像翻转
使用`flip`可以对图像进行翻转操作,默认是以x轴进行翻转,例如:
```
$image = \think\Image::open('./image.png');
// 对图像进行以x轴进行翻转操作
$image->flip()->save('./filp_image.png');
```
生成的效果如图:
![](https://box.kancloud.cn/2016-07-23_579366dfb73f3.png)
我们也可以改变参数,以y轴进行翻转,例如:
```
$image = \think\Image::open('./image.png');
// 对图像进行以y轴进行翻转操作
$image->flip(\think\image::FLIP_Y)->save('./filp_image.png');
```
生成的效果如图:
![](https://box.kancloud.cn/2016-07-23_579366e000540.png)
> 图像的翻转可以理解为图像的镜面效果与图像旋转有所不同。
### 图像旋转
使用`rotate`可以对图像进行旋转操作(默认是顺时针旋转90度),我们用默认90度进行旋转举例:
```
$image = \think\Image::open('./image.png');
// 对图像使用默认的顺时针旋转90度操作
$image->rotate()->save('./rotate_image.png');
```
生成的效果如图:
![](https://box.kancloud.cn/9e926b44ae235cdf8b9a635297e4a786_432x767.png)
### 图像保存参数
`save`方法可以配置的参数
参数默认描述pathname必填项图像保存路径名称type默认与原图相同图像类型quality80图像质量interlacetrue是否对JPEG类型图像设置隔行扫描> 设置隔行扫描的情况下在网页进行浏览时。是从上到下一行一行的显示,否则图片整个显示出来 然后由模糊到清晰显示。
### 添加水印
系统支持添加图片及文字水印,下面依次举例说明
添加图片水印,我们下载官网logo文件到根目录进行举例:
```
$image = \think\Image::open('./image.png');
// 给原图左上角添加水印并保存water_image.png
$image->water('./logo.png')->save('water_image.png');
```
`water`方法的第二个参数表示水印的位置,默认值是`WATER_SOUTH`,可以传入下列`\think\Image`类的常量或者对应的数字:
```
//常量,标识左上角水印
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');
```
生成的图片效果如下:
![](https://box.kancloud.cn/30d6a32b977c060bf6f4996053e5bca7_768x432.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');
```
生成的图片效果如下:
![](https://box.kancloud.cn/67fb22eaa6b1f2c1325d498d2ecadbe9_768x432.png)
也可以支持给图片添加文字水印(我们复制一个字体文件`HYQingKongTiJ.ttf`到入口目录),我们现在生成一个像素20px,颜色为`#ffffff`的水印效果:
```
$image = \think\Image::open('./image.png');
// 给原图左上角添加水印并保存water_image.png
$image->text('十年磨一剑 - 为API开发设计的高性能框架','HYQingKongTiJ.ttf',20,'#ffffff')->save('text_image.png');
```
生成的图片效果:
![](https://box.kancloud.cn/a38f1ee79cfbce71d6ddc50959a35c92_768x432.png)
### 文字水印参数
文字水印比较多,在此只做说明不做演示了
参数默认描述text不能为空添加的文字font不能为空字体文件路径size不能为空字号,单位是像素color\#00000000文字颜色locateWATER\_SOUTHEAST文字写入位置offset0文字相对当前位置的偏移量angle0文字倾斜角度
- 序言
- 基础
- 安装
- 开发规范
- 目录结构
- 配置
- 架构
- 架构总览
- 入口文件
- URL访问
- 模块设计
- 命名空间
- 容器和依赖注入
- Facade
- 钩子和行为
- 中间件
- 路由
- 路由定义
- 变量规则
- 路由地址
- 闭包支持
- 路由参数
- 路由缓存
- 跨域请求
- 注解路由
- 路由分组
- MISS路由
- 资源路由
- 快捷路由
- 路由别名
- 路由绑定
- 域名路由
- URL生成
- 控制器
- 控制器定义
- 前置操作
- 跳转和重定向
- 空操作和空控制器
- 分层控制器
- 资源控制器
- 请求
- 请求对象
- 请求信息
- 输入变量
- 请求类型
- HTTP头信息
- 伪静态
- 参数绑定
- 请求缓存
- 响应
- 响应输出
- 响应参数
- 重定向
- 数据库
- 连接数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询表达式
- 链式操作
- 聚合查询
- 时间查询
- 高级查询
- 视图查询
- JSON字段
- 子查询
- 原生查询
- 查询事件
- 事务操作
- 监听SQL
- 存储过程
- 数据集
- 分布式数据库
- 模型
- 定义
- 新增
- 更新
- 删除
- 查询
- JSON字段
- 获取器
- 修改器
- 自动时间戳
- 只读字段
- 软删除
- 类型转换
- 数据完成
- 查询范围
- 模型输出
- 模型事件
- 模型关联
- 一对一关联
- 一对多关联
- 远程一对多
- 多对多关联
- 多态关联
- 关联预载入
- 关联统计
- 关联输出
- 视图
- 视图渲染
- 视图赋值
- 视图过滤
- 模板引擎
- 模板
- 变量输出
- 使用函数
- 运算符
- 原样输出
- 模板注释
- 模板布局
- 模板继承
- 包含文件
- 输出替换
- 标签库
- 内置标签
- 循环标签
- 比较标签
- 条件判断
- 资源文件加载
- 标签嵌套
- 原生PHP
- 定义标签
- 标签扩展
- 错误和日志
- 异常处理
- 日志处理
- 调试
- 调试模式
- Trace调试
- 性能调试
- SQL调试
- 变量调试
- 远程调试
- 验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 路由验证
- 内置规则
- 独立验证
- 静态调用
- 表单令牌
- 杂项
- 缓存
- Session
- Cookie
- 多语言
- 分页
- 上传
- 命令行
- 启动内置服务器
- 自动生成目录结构
- 创建类库文件
- 生成类库映射文件
- 清除缓存文件
- 生成配置缓存文件
- 生成数据表字段缓存
- 生成路由映射缓存
- 自定义指令
- 扩展库
- 验证码
- 图像处理
- Time
- 数据库迁移工具
- Workerman
- MongoDb
- 单元测试
- 安全和性能
- 安全建议
- 优化建议
- 附录
- 助手函数
- 升级指导
- 更新日志