PHP添加文字水印或图片水印的水印类完整源代码与使用示例


Posted in PHP onMarch 18, 2019

PHP实现的给图片添加水印功能,可添加文字水印或图片水印,使用文字水印时需要提供字体文件,使用图片水印时需要提供水印图片,水印图片不能比要添加水印的图片大,请使用背景透明的水印图片。

该水印类支持自定义水印位置、自定义水印大小和水印的透明度,字体水印可自定义颜色等,功能已相应完善。

完整源代码如下(注解中已给出使用示例):

<?php
/**
 * 图片加水印类,支持文字水印、透明度设置、自定义水印位置等。
 * 使用示例:
 *   $obj = new WaterMask($imgFileName);  //实例化对象
 *   $obj->$waterType = 1;   //类型:0为文字水印、1为图片水印
 *   $obj->$transparent = 45;   //水印透明度
 *   $obj->$waterStr = '3water.com';  //水印文字
 *   $obj->$fontSize = 18;   //文字字体大小
 *   $obj->$fontColor = array(255,255,255);  //水印文字颜色(RGB)
 *   $obj->$fontFile = 'AHGBold.ttf';  //字体文件
 * ……
 *   $obj->output();    //输出水印图片文件覆盖到输入的图片文件
 */
class WaterMask{
  public $waterType     = 0;   //水印类型:0为文字水印、1为图片水印
  public $pos        = 0;   //水印位置
  public $transparent    = 45;   //水印透明度
  public $waterStr      = '3water.com';  //水印文字
  public $fontSize      = 18;   //文字字体大小
  public $fontColor     = array(255,255,255);  //水印文字颜色(RGB)
  public $fontFile      = 'AHGBold.ttf';  //字体文件
  public $waterImg      = 'logo.png';  //水印图片
  private $srcImg       = '';   //需要添加水印的图片
  private $im         = '';   //图片句柄
  private $water_im      = '';   //水印图片句柄
  private $srcImg_info    = '';   //图片信息
  private $waterImg_info   = '';   //水印图片信息
  private $str_w       = '';   //水印文字宽度
  private $str_h       = '';   //水印文字高度
  private $x         = '';   //水印X坐标
  private $y         = '';   //水印y坐标
  function __construct($img) {    //析构函数
    $this->srcImg = file_exists($img) ? $img : die('"'.$img.'" 源文件不存在!');
  }
  private function imginfo() { //获取需要添加水印的图片的信息,并载入图片。
    $this->srcImg_info = getimagesize($this->srcImg);
    switch ($this->srcImg_info[2]) {
      case 3:
        $this->im = imagecreatefrompng($this->srcImg);
        break 1;
      case 2:
        $this->im = imagecreatefromjpeg($this->srcImg);
        break 1;
      case 1:
        $this->im = imagecreatefromgif($this->srcImg);
        break 1;
      default:
        die('原图片('.$this->srcImg.')格式不对,只支持PNG、JPEG、GIF。');
    }
  }
  private function waterimginfo() { //获取水印图片的信息,并载入图片。
    $this->waterImg_info = getimagesize($this->waterImg);
    switch ($this->waterImg_info[2]) {
      case 3:
        $this->water_im = imagecreatefrompng($this->waterImg);
        break 1;
      case 2:
        $this->water_im = imagecreatefromjpeg($this->waterImg);
        break 1;
      case 1:
        $this->water_im = imagecreatefromgif($this->waterImg);
        break 1;
      default:
        die('水印图片('.$this->srcImg.')格式不对,只支持PNG、JPEG、GIF。');
    }
  }
  private function waterpos() { //水印位置算法
    switch ($this->pos) {
      case 0:   //随机位置
        $this->x = rand(0,$this->srcImg_info[0]-$this->waterImg_info[0]);
        $this->y = rand(0,$this->srcImg_info[1]-$this->waterImg_info[1]);
        break 1;
      case 1:   //上左
        $this->x = 0;
        $this->y = 0;
        break 1;
      case 2:   //上中
        $this->x = ($this->srcImg_info[0]-$this->waterImg_info[0])/2;
        $this->y = 0;
        break 1;
      case 3:   //上右
        $this->x = $this->srcImg_info[0]-$this->waterImg_info[0];
        $this->y = 0;
        break 1;
      case 4:   //中左
        $this->x = 0;
        $this->y = ($this->srcImg_info[1]-$this->waterImg_info[1])/2;
        break 1;
      case 5:   //中中
        $this->x = ($this->srcImg_info[0]-$this->waterImg_info[0])/2;
        $this->y = ($this->srcImg_info[1]-$this->waterImg_info[1])/2;
        break 1;
      case 6:   //中右
        $this->x = $this->srcImg_info[0]-$this->waterImg_info[0];
        $this->y = ($this->srcImg_info[1]-$this->waterImg_info[1])/2;
        break 1;
      case 7:   //下左
        $this->x = 0;
        $this->y = $this->srcImg_info[1]-$this->waterImg_info[1];
        break 1;
      case 8:   //下中
        $this->x = ($this->srcImg_info[0]-$this->waterImg_info[0])/2;
        $this->y = $this->srcImg_info[1]-$this->waterImg_info[1];
        break 1;
      default:  //下右
        $this->x = $this->srcImg_info[0]-$this->waterImg_info[0];
        $this->y = $this->srcImg_info[1]-$this->waterImg_info[1];
        break 1;
    }
  }
  private function waterimg() {
    if ($this->srcImg_info[0] <= $this->waterImg_info[0] || $this->srcImg_info[1] <= $this->waterImg_info[1]){
      die('水印比原图大!');
    }
    $this->waterpos();
    $cut = imagecreatetruecolor($this->waterImg_info[0],$this->waterImg_info[1]);
    imagecopy($cut,$this->im,0,0,$this->x,$this->y,$this->waterImg_info[0],$this->waterImg_info[1]);
    $pct = $this->transparent;
    imagecopy($cut,$this->water_im,0,0,0,0,$this->waterImg_info[0],$this->waterImg_info[1]);
    imagecopymerge($this->im,$cut,$this->x,$this->y,0,0,$this->waterImg_info[0],$this->waterImg_info[1],$pct);
  }
  private function waterstr() {
    $rect = imagettfbbox($this->fontSize,0,$this->fontFile,$this->waterStr);
    $w = abs($rect[2]-$rect[6]);
    $h = abs($rect[3]-$rect[7]);
    $fontHeight = $this->fontSize;
    $this->water_im = imagecreatetruecolor($w, $h);
    imagealphablending($this->water_im,false);
    imagesavealpha($this->water_im,true);
    $white_alpha = imagecolorallocatealpha($this->water_im,255,255,255,127);
    imagefill($this->water_im,0,0,$white_alpha);
    $color = imagecolorallocate($this->water_im,$this->fontColor[0],$this->fontColor[1],$this->fontColor[2]);
    imagettftext($this->water_im,$this->fontSize,0,0,$this->fontSize,$color,$this->fontFile,$this->waterStr);
    $this->waterImg_info = array(0=>$w,1=>$h);
    $this->waterimg();
  }
  function output() {
    $this->imginfo();
    if ($this->waterType == 0) {
      $this->waterstr();
    }else {
      $this->waterimginfo();
      $this->waterimg();
    }
    switch ($this->srcImg_info[2]) {
      case 3:
        imagepng($this->im,$this->srcImg);
        break 1;
      case 2:
        imagejpeg($this->im,$this->srcImg);
        break 1;
      case 1:
        imagegif($this->im,$this->srcImg);
        break 1;
      default:
        die('添加水印失败!');
        break;
    }
    imagedestroy($this->im);
    imagedestroy($this->water_im);
  }
}
?>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

PHP 相关文章推荐
用PHP来写记数器(详细介绍)
Oct 09 PHP
PHP迅雷、快车、旋风下载专用链转换代码
Jun 15 PHP
vs中通过剪切板循环来循环粘贴不同内容
Apr 30 PHP
php空间不支持socket但支持curl时recaptcha的用法
Nov 07 PHP
PHP取进制余数函数代码
Jan 19 PHP
PHP判断图片格式的七种方法小结
Jun 03 PHP
支持中文和其他编码的php截取字符串函数分享(截取中文字符串)
Mar 13 PHP
php中单个数据库字段多列显示(单字段分页、横向输出)
Jul 28 PHP
给PHP开发者的编程指南 第一部分降低复杂程度
Jan 18 PHP
php中钩子(hook)的原理与简单应用demo示例
Sep 03 PHP
PHP图像处理 imagestring添加图片水印与文字水印操作示例
Feb 06 PHP
PhpStorm 2020.3:新增开箱即用的PHP 8属性(推荐)
Oct 30 PHP
PHP实现对数字分隔加千分号的方法
Mar 18 #PHP
PHP生成指定范围内的N个不重复的随机数
Mar 18 #PHP
PHP中十六进制颜色与RGB颜色值互转的方法
Mar 18 #PHP
PHP将整数数字转换为罗马数字实例分享
Mar 17 #PHP
PHP标准库(PHP SPL)详解
Mar 16 #PHP
PHP PDO数据库操作预处理与注意事项
Mar 16 #PHP
php生成word并下载代码实例
Mar 15 #PHP
You might like
关于二级目录拖拽排序的实现(源码示例下载)
2013/04/26 PHP
ThinkPHP通过AJAX返回JSON的两种实现方法
2014/12/18 PHP
php使用curl打开https网站的方法
2015/06/17 PHP
PHP的几个常用加密函数
2016/02/03 PHP
PHP检测用户是否关闭浏览器的方法
2016/02/14 PHP
PHP微信公众号自动发送红包API
2016/06/01 PHP
php获取给定日期相差天数的方法分析
2017/02/20 PHP
php中错误处理操作实例分析
2019/08/23 PHP
jQuery 使用手册(一)
2009/09/23 Javascript
jQuery表单验证插件formValidator(改进版)
2012/02/03 Javascript
js离开或刷新页面检测(且兼容FF,IE,Chrome)
2014/03/05 Javascript
javascript自定义的addClass()方法
2014/05/28 Javascript
纯css实现窗户玻璃雨滴逼真效果
2015/08/23 Javascript
基于JavaScript实现的插入排序算法分析
2017/04/14 Javascript
vue src动态加载请求获取图片的方法
2018/10/17 Javascript
JavaScript一元正号运算符示例代码
2019/06/30 Javascript
vue props对象validator自定义函数实例
2019/11/13 Javascript
ES6 proxy和reflect的使用方法与应用实例分析
2020/02/15 Javascript
可拖拽组件slider.js使用方法详解
2020/12/04 Javascript
如何在JavaScript中正确处理变量
2020/12/25 Javascript
Python 错误和异常小结
2013/10/09 Python
零基础写python爬虫之打包生成exe文件
2014/11/06 Python
python中Flask框架简单入门实例
2015/03/21 Python
python基于http下载视频或音频
2018/06/20 Python
python sorted方法和列表使用解析
2019/11/18 Python
Python和Sublime整合过程图示
2019/12/25 Python
python使用nibabel和sitk读取保存nii.gz文件实例
2020/07/01 Python
来自美国主售篮球鞋的零售商店:KICKSUSA
2017/11/28 全球购物
泰国第一的化妆品网站:Konvy
2018/02/25 全球购物
体育专业个人的求职信范文
2013/09/21 职场文书
批评与自我批评材料
2014/02/15 职场文书
电子商务专业学生职业生涯规划
2014/03/07 职场文书
预备党员入党自我评价范文
2014/03/10 职场文书
植物生产学专业求职信
2014/08/08 职场文书
react中props 的使用及进行限制的方法
2021/04/28 Javascript
vue中使用mockjs配置和使用方式
2022/04/06 Vue.js