PHPackages                             tp5er/images - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Image &amp; Media](/categories/media)
4. /
5. tp5er/images

ActiveLibrary[Image &amp; Media](/categories/media)

tp5er/images
============

一个不依赖任何框架的image操作类，独立thinkphp3.2.3中Image类

1.0.0(4y ago)02.0k1MITPHP

Since May 5Pushed 3y agoCompare

[ Source](https://github.com/pkg6/think-image)[ Packagist](https://packagist.org/packages/tp5er/images)[ RSS](/packages/tp5er-images/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)DependenciesVersions (2)Used By (0)

> 参考thinkphp3.2.3中Image操作
>
>
>
> 不依赖任何框架
>
> 一般情况下都会安装gd库
>
> 需要Imagick请安装

实例化类库
-----

[](#实例化类库)

```
$image = new \tp5er\Images\Image();

```

默认使用GD库进行图像操作，如果需要使用Imagick库操作的话，需要改成：

```
$image = new \tp5er\Images\Image(\Think\Image::IMAGE_IMAGICK);
// 或者采用
$image = new \tp5er\Images\Image('Imagick');

```

图像操作
----

[](#图像操作)

下面来看下基础的图像操作功能的使用方法。

### 打开图像文件

[](#打开图像文件)

假设当前入口文件目录下面有一个1.jpg文件

使用open方法打开图像文件进行相关操作：

```
$image = \tp5er\Images\Image();
$image->open('./1.jpg');

```

也可以简化成下面的方式：

```
$image = new \tp5er\Images\Image(\tp5er\Images\Image::IMAGE_GD,'./1.jpg'); // GD库
// 或者
$image = new \tp5er\Images\Image(\tp5er\Images\Image::IMAGE_IMAGICK,'./1.jpg');  // imagick库

```

### 获取图像信息

[](#获取图像信息)

可以获取打开图片的信息，包括图像大小、类型等，例如：

```
$width = $image->width(); // 返回图片的宽度
$height = $image->height(); // 返回图片的高度
$type = $image->type(); // 返回图片的类型
$mime = $image->mime(); // 返回图片的mime类型
$size = $image->size(); // 返回图片的尺寸数组 0 图片宽度 1 图片高度

```

### 裁剪图片

[](#裁剪图片)

使用crop和save方法完成裁剪图片功能。

```
//将图片裁剪为400x400并保存为corp.jpg
$image->crop(400, 400)->save('./crop.jpg');

```

支持从某个坐标开始裁剪，例如下面从（100，30）开始裁剪：

```
//将图片裁剪为400x400并保存为corp.jpg
$image->crop(400, 400,100,30)->save('./crop.jpg');

```

### 生成缩略图

[](#生成缩略图)

使用thumb方法生成缩略图

```
// 按照原图的比例生成一个最大为150*150的缩略图并保存为thumb.jpg
$image->thumb(150, 150)->save('./thumb.jpg');

```

可以支持其他类型的缩略图生成，设置包括`\tp5er\Images\Image`的下列常量或者对应的数字：

```
IMAGE_THUMB_SCALE     =   1 ; //等比例缩放类型
IMAGE_THUMB_FILLED    =   2 ; //缩放后填充类型
IMAGE_THUMB_CENTER    =   3 ; //居中裁剪类型
IMAGE_THUMB_NORTHWEST =   4 ; //左上角裁剪类型
IMAGE_THUMB_SOUTHEAST =   5 ; //右下角裁剪类型
IMAGE_THUMB_FIXED     =   6 ; //固定尺寸缩放类型

```

#### 居中裁剪

[](#居中裁剪)

```
// 生成一个居中裁剪为150*150的缩略图并保存为thumb.jpg
$image->thumb(150, 150,\tp5er\Images\Image::IMAGE_THUMB_CENTER)->save('./thumb.jpg');

```

#### 左上角剪裁

[](#左上角剪裁)

```
$image->thumb(150, 150,\tp5er\Images\Image::IMAGE_THUMB_NORTHWEST)->save('./thumb.jpg');

```

#### 缩放填充

[](#缩放填充)

```
$image->thumb(150, 150,\tp5er\Images\Image::IMAGE_THUMB_FILLED)->save('./thumb.jpg');

```

#### 固定大小

[](#固定大小)

```
$image->thumb(150, 150,\tp5er\Images\Image::IMAGE_THUMB_FIXED)->save('./thumb.jpg');

```

### 添加图片水印

[](#添加图片水印)

```
//将图片裁剪为440x440并保存为corp.jpg
$image->crop(440, 440)->save('./crop.jpg');
// 给裁剪后的图片添加图片水印（水印文件位于./logo.png），位置为右下角，保存为water.gif
$image->water('./logo.png')->save("water.gif");
// 给原图添加水印并保存为water_o.gif（需要重新打开原图）
$image->open('./1.jpg')->water('./logo.png')->save("water_o.gif");

```

water方法的第二个参数表示水印的位置，可以传入下列Think\\Imag类的常量或者对应的数字：

```
IMAGE_WATER_NORTHWEST =   1 ; //左上角水印
IMAGE_WATER_NORTH     =   2 ; //上居中水印
IMAGE_WATER_NORTHEAST =   3 ; //右上角水印
IMAGE_WATER_WEST      =   4 ; //左居中水印
IMAGE_WATER_CENTER    =   5 ; //居中水印
IMAGE_WATER_EAST      =   6 ; //右居中水印
IMAGE_WATER_SOUTHWEST =   7 ; //左下角水印
IMAGE_WATER_SOUTH     =   8 ; //下居中水印
IMAGE_WATER_SOUTHEAST =   9 ; //右下角水印

```

例如：

```
$image->open('./1.jpg')->water('./logo.png',\tp5er\Images\Image::IMAGE_WATER_NORTHWEST)->save("water.jpg");

```

还可以支持水印图片的透明度（0~100，默认值是80），例如：

```
$image->open('./1.jpg')->water('./logo.png',\tp5er\Images\Image::IMAGE_WATER_NORTHWEST,50)->save("water.jpg");

```

也可以支持给图片添加文字水印（假设在入口文件的同级目录下存在1.ttf字体文件），例如：

```
$image->open('./1.jpg')->text('ThinkPHP','./1.ttf',20,'#000000',\tp5er\Images\Image::IMAGE_WATER_SOUTHEAST)->save("new.jpg");

```

###  Health Score

25

—

LowBetter than 37% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity16

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity48

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

1466d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/28b119a234a9963e2266b2b493c037b1d7f01d3e17a06a3ffe94481549efa47b?d=identicon)[1751212020](/maintainers/1751212020)

---

Top Contributors

[![chihqiang](https://avatars.githubusercontent.com/u/40115555?v=4)](https://github.com/chihqiang "chihqiang (1 commits)")

---

Tags

image

### Embed Badge

![Health badge](/badges/tp5er-images/health.svg)

```
[![Health](https://phpackages.com/badges/tp5er-images/health.svg)](https://phpackages.com/packages/tp5er-images)
```

###  Alternatives

[intervention/image

PHP Image Processing

14.3k194.3M2.2k](/packages/intervention-image)[league/glide

Wonderfully easy on-demand image manipulation library with an HTTP based API.

2.6k51.2M116](/packages/league-glide)[liip/imagine-bundle

This bundle provides an image manipulation abstraction toolkit for Symfony-based projects.

1.7k38.3M217](/packages/liip-imagine-bundle)[spatie/image

Manipulate images with an expressive API

1.4k54.4M137](/packages/spatie-image)[intervention/image-laravel

Laravel Integration of Intervention Image

1496.5M100](/packages/intervention-image-laravel)[intervention/gif

PHP GIF Encoder/Decoder

5520.3M9](/packages/intervention-gif)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
