博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP生成随机水印图片
阅读量:5834 次
发布时间:2019-06-18

本文共 3476 字,大约阅读时间需要 11 分钟。

一、需求

网站的布局用到了类似慕课网课程列表的风格,每一个课程是一个banner图,图下面是标题加简介。因为课程的数量较大没有为所有的课程设计专门的banner,所以需要按照一定的规则,来自己生成图片(本打算用div布局来解决,但div+img在响应式布局中不是很好控制)。

生成的效果图:

效果图

二、工具&素材

1.PHP开启GD图形库扩展

2.准备多个小的水印图
3.获取预生成图片的背景色RGB值

三、代码

生成图片的过程,代码中做了详细的注释。

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" />来直接显示图片。

本文转自xsster51CTO博客,原文链接:http://blog.51cto.com/12945177/1929773 ,如需转载请自行联系原作者
你可能感兴趣的文章
数据分析相关
查看>>
Python LDAP中的时间戳转换为Linux下时间
查看>>
微信小程序蓝牙连接小票打印机
查看>>
C++_了解虚函数的概念
查看>>
全新jmeter视频已经上架
查看>>
Windows 8下如何删除无线配置文件
查看>>
oracle系列(五)高级DBA必知的Oracle的备份与恢复(全录收集)
查看>>
hp 服务器通过串口重定向功能的使用
查看>>
国外10大IT网站和博客网站
查看>>
android第十一期 - SmoothSwitchLibrary仿IOS切换Activity动画效果
查看>>
zabbix 批量web url监控
查看>>
MongoDB CookBook读书笔记之导入导出
查看>>
shell如何快速锁定所有账号
查看>>
HTML 5实现的手机摇一摇
查看>>
此博客不再发表对自己私事的看法
查看>>
导致Asp.Net站点重启的10个原因
查看>>
【PMP】Head First PMP 学习笔记 第一章 引言
查看>>
抓住云机遇编排工作 搞定复杂IT工作流
查看>>
MYSQL的longtext字段能放多少数据?
查看>>
MTK 平台上如何给 camera 添加一种 preview size
查看>>