基于PHP实现生成随机水印图片
基于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库中的方法,就可以实现创建图片、为图片添加文字水印、或图片水印。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/ghjbk/p/7645434.html
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。