基于php的gd图形库,自己生成一张图片。仅限初识gd库,实例学习。
一、需求
网站的布局用到了类似慕课网课程列表的风格,每一个课程是一个banner图,图下面是标题加简介。因为课程的数量较大没有为所有的课程设计专门的banner,所以需要按照一定的规则,来自己生成图片(本打算用div布局来解决,但div+img在响应式布局中不是很好控制)。
生成的效果图:
二、工具&素材
1.php开启gd图形库扩展
2.准备多个小的水印图
3.获取预生成图片的背景色rgb值
三、代码
生成图片的过程,代码中做了详细的注释。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
class generaterandomimage
{
/** @var integer 图片宽度 */
public $imgwidth = 272;
/** @var integer 图片高度 */
public $imgheight = 162;
/** @var 根据type不同来生成不同的背景颜色,目前留个type分别为蓝色、紫色、黄色、绿色、灰色、土黄色 */
public $type = '' ;
/** @var 图片上要显示的文字 */
public $text = '' ;
/** @var integer 图片上文字的字体大小 */
public $fontsize = 16;
public function __construct( $type , $text )
{
$this ->type = $type ;
$this ->text = $text ;
}
/**
* 创建生成随机图片
* @author bignerd
* @since 2017-03-21t14:49:41+0800
*/
public function createimg()
{
/** @var 创建一个指定图片大小的空调色板
$image = imagecreate($this->imgwidth, $this->imgheight);
$rgb = $this->getbackground($this->type);
/** @var 为图片创建一个背景色 */
$backgroundcolor = imagecolorallocate( $image , $rgb [ 'r' ], $rgb [ 'g' ], $rgb [ 'b' ]);
/** @var 创建文字白色字体 */
$textcolor = imagecolorallocate( $image , 255, 255, 255);
/** @var 字体文件路径 */
$font = $_server [ 'document_root' ]. '/public/font/simhei.ttf' ;
$x = 18; //文字起始位置x坐标
$y = 50; //文字起始位置y坐标
/** 文字写入图片 */
$angle = 0; //角度0
imagettftext( $image , $this ->fontsize, $angle , $x , $y , $textcolor , $font , $this ->text);
/** @var 水印图片路径 **/
$waterimgpath = $this ->randwaterimage();
/** @var 获取图片信息,返回值$waterinfo[2] 为图片类型常量 */
$waterinfo = getimagesize ( $waterimgpath );
/** @var 将图片类型常量转换为真正的类型,如png */
$watertype = image_type_to_extension( $waterinfo [2], false); //获取文件类型
$createimagefunc = 'imagecreatefrom' . $watertype ;
/** @var 创建一个水印图片的副本 $createimagefunc 为根据图片类型来动态生成预调用的创建图片函数*/
$mask = $createimagefunc ( $waterimgpath );
$posx = $this ->imgwidth - $waterinfo [0]; //水印图片,在目标图片中的位置的x坐标
$posy = $this ->imgheight - $waterinfo [1]; //水印图片,在目标图片中的位置的y坐标
/** http请求响应类型设置为 image/png 以便直接显示为图片 */
header( "content-type:image/png" );
/** 水印图片复制到创建的image */
imagecopy( $image , $mask , $posx , $posy , 0, 0, $waterinfo [0], $waterinfo [1]);
imagepng( $image ); //输入图片到浏览器或者文件
imagedestroy( $image ); //销毁图片
}
/**
* 图片背景颜色的rgb值
* @author bignerd
* @since 2017-03-21t14:50:16+0800
*/
public function getbackground()
{
$background = [
'1' =>[ 'r' =>0, 'g' =>160, 'b' =>233],
'2' =>[ 'r' =>198, 'g' =>0, 'b' =>110],
'3' =>[ 'r' =>237, 'g' =>109, 'b' =>0],
'4' =>[ 'r' =>33, 'g' =>148, 'b' =>75],
'5' =>[ 'r' =>63, 'g' =>58, 'b' =>57],
'6' =>[ 'r' =>202, 'g' =>162, 'b' =>101],
];
return $background [ $this ->type];
}
/**
* 随机水印图片路径
* @author bignerd
* @since 2017-03-21t14:51:00+0800
* @return 路径
*/
public function randwaterimage()
{
$folder = [
'1' => 'product' , '2' => 'team' , '3' => 'architecture' , '4' => 'developer' , '5' => 'test' , '6' => 'engineer'
];
$targetfolder = $_server [ 'document_root' ]. '/public/images/role/' . $folder [ $this ->type]. '/' .rand(1,38). '.png' ;
return $targetfolder ;
}
}
$image = new generaterandomimage(1, "扛得住的mysql数据架构" );
$image ->createimg();
|
这样我们就可以直接在页面中使用 <img src="http://xxx.com/generaterandomimage.php" />来直接显示图片。
注意:过程中遇到过一个问题:如果水印图片是透明的png图片,那将水印图片复制到image中时,会显示为白色背景,与我们设定 的image背景无法透明融合,所以对随机的水印图片也需要做同样的颜色处理。
四、总结
这个小示例用简单的步骤来生成一张图片,直接显示在浏览器,也可以给imagepng加第二参数,也就是路径,以保存图片。所以学会示例中的几个gd库中的方法,就可以实现创建图片、为图片添加文字水印、或图片水印。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。