我们使用的是tp5自带的类库
## 安装扩展
使用`Composer`安装`ThinkPHP5`的图像处理类库:
~~~
composer require topthink/think-image
~~~
## 图像操作
下面来看下图像操作类的基础方法。
### 打开图像文件
假设当前入口文件目录下面有一个`image.png`文件,如图所示:
![](https://box.kancloud.cn/2015-10-11_5619d5ea20c05.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/2016-07-13_5785f04a3cbb5.jpg)
支持从某个坐标开始裁剪,例如下面从(100,30)开始裁剪,例如:
~~~
$image = \think\Image::open('./image.png');
//将图片裁剪为300x300并保存为crop.png
$image->crop(300, 300,100,30)->save('./crop.png');
~~~
生成的图片如图:
![](https://box.kancloud.cn/2016-07-13_5785f04a59e46.jpg)
### 生成缩略图
使用`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/2016-07-13_5785f04a7c337.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/2016-07-13_5785f04a8f8ab.png)
这里就不再对其他用法一一举例了。
### 图像翻转
使用`flip`可以对图像进行翻转操作,默认是以x轴进行翻转,例如:
~~~
$image = \think\Image::open('./image.png');
// 对图像进行以x轴进行翻转操作
$image->flip()->save('./filp_image.png');
~~~
生成的效果如图:
![](https://box.kancloud.cn/2016-07-14_578755c5e35da.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-14_578755c6142e5.png)
> 图像的翻转可以理解为图像的镜面效果与图像旋转有所不同。
### 图像旋转
使用`rotate`可以对图像进行旋转操作(默认是顺时针旋转90度),我们用默认90度进行旋转举例:
~~~
$image = \think\Image::open('./image.png');
// 对图像使用默认的顺时针旋转90度操作
$image->rotate()->save('./rotate_image.png');
~~~
生成的效果如图:
![](https://box.kancloud.cn/2016-07-14_578755c631296.png)
### 图像保存参数
`save`方法可以配置的参数
| 参数 | 默认 | 描述 |
| --- | --- | --- |
| pathname | 必填项 | 图像保存路径名称 |
| type | 默认与原图相同 | 图像类型 |
| quality | 80 | 图像质量 |
| interlace | true | 是否对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/2016-07-13_5785f04aa1a2e.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/2015-10-11_5619d5ead899f.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/2016-07-13_5785f431f39ea.png)
### 文字水印参数
文字水印比较多,在此只做说明不做演示了
| 参数 | 默认 | 描述 |
| --- | --- | --- |
| text | 不能为空 | 添加的文字 |
| font | 不能为空 | 字体文件路径 |
| size | 不能为空 | 字号,单位是像素 |
| color | #00000000 | 文字颜色 |
| locate | WATER\_SOUTHEAST | 文字写入位置 |
| offset | 0 | 文字相对当前位置的偏移量 |
| angle | 0 | 文字倾斜角度 |
- 课程介绍
- thinkphp5.0
- 安装
- 开发规范
- 目录结构
- 配置参数
- 系统常量
- tp5自带的函数
- 助手函数
- 扩展类库
- 基本类库
- Workerman
- think-queue
- 验证码
- 图片
- 权限认证
- 课前准备
- 数据库设计
- 模块设计
- 管理员管理
- 添加
- 编辑
- 删除和批量删除
- 列表页
- 实列
- 权限管理
- 操作日志
- 基于行为的日记录
- 行为日志的扩展
- 助手类库
- 自建函数
- 将数组转成uri字符串
- 获取当前服务器的IP
- curl-post
- 截取文字中间的字符串
- 检查中文姓名
- 省市区分别截取
- 抽奖概率问题
- 短信邮箱模板替换
- 生成csv
- PHP 图片转base64
- 银行卡验证
- json返回接口封装
- 无限极分类
- 病毒
- xml和数组互转
- xml转成数组
- 数组转xml
- tp控制器相关
- 获取thinkph5下控制器和方法名
- 后台查询的简单封装
- 网址信息
- 获取网站logo
- 判断url是否存在
- 获取title
- 判断远程文件是否存在
- 获取页面所有链接
- 过滤
- 截取
- 时间
- 获取服务器信息
- 根据id生成唯一邀请码
- 随机颜色
- 数组字符串互换
- 创建多级目录
- 懒人查询
- 时间和时间戳转换
- 房间id生菜
- 获取需要的数组元素
- 文件和文件夹
- 文件类库
- 文件夹
- 七牛云
- 七牛云运用场景
- 七牛云使用实例
- 邮箱
- 邮箱验证
- 邮箱发送
- 数据库
- 数据库在thinkphp中的补充方法
- 备份和安全
- sql执行
- 数据库备份2
- 时间日历
- 时间格式化
- 日历
- 图片相关
- 自动获取图片主题颜色
- 获取html中的图片路径
- 获取图片场景
- 获取图片实践
- 图片处理类
- 图片处理场景
- 图片处理实践
- 数据验证分析
- 身份证相关
- 新闻
- 自建类库
- 简易分类库
- php 压缩CSS代码
- 身份证
- 分词和抽词
- 分词应用场景
- 分词实践
- 中文转拼音
- 中文转拼音场景
- 中文转拼音实践
- 二维码操作
- 二维码场景
- 二维码实践
- 短地址
- PHPWord
- 插件化
- 插件扩展库
- 插件列表
- 插件安装和卸载
- 插件实践
- 插件的离线安装
- 计划任务
- 计划任务安装
- 计划任务实践
- 定时器
- 注册登录
- 普通登录注册
- 第三方登录注册
- jwt接口登录注册
- 短信
- 飞鸽短信
- 阿里短信
- 消息队列
- 网站地图
- 全站静态化
- 缓存
- 文件导出
- PDF生成
- phpword
- PHPExcel
- 其他类库
- 百度
- 百度语音
- 快递
- 跨域问题
- 宝塔
- 搜索记录