基于PHP实现生成随机水印图片

吾爱主题 阅读:191 2021-10-29 16:46:00 评论:0

基于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.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容