php面向对象与面向过程两种方法给图片添加文字水印


Posted in PHP onAugust 26, 2015

目前绝大多数PHP程序员使用面向过程的方式,因为解析WEB页面本身就非常“过程化”(从一个标签到另一个标签)。在HTML中嵌入过程处理代码是很直接自然的作法,所以PHP程序员通常使用这种方式。

如果你是刚接触PHP,用面向过程的风格来书写代码很可能是你唯一的选择。但是如果你经常上PHP论坛和新闻组的话,你应该会看到有关“对象”的文章。你也可能看到过如何书写面向对象的PHP代码的教程。或者你也可能下载过一些现成的类库,并尝试着去实例化其中的对象和使用类方法--尽管你可能没有真正理解这些类为什么可以工作,或者为什么需要使用面向对象的方法来实现功能。

应该使用“面向对象”的风格还是“面向过程”的风格?双方各有支持者。像“对象是低效的”或“对象非常棒”这样的议论也时有耳闻。本文不尝试轻易判定两种方法的哪种具有绝对的优势,而是要找出每种方法的优缺点。

1:面向对象的实现利用php给图片添加水印方法

class Image_class {
  private $image;
  private $info;
  /**
   * @param $src:图片路径
   * 加载图片到内存中
   */
  function __construct($src){
    $info = getimagesize($src);
    $type = image_type_to_extension($info[2],false);
    $this -> info =$info;
    $this->info['type'] = $type;
    $fun = "imagecreatefrom" .$type;
    $this -> image = $fun($src);
  }
  /**
   * @param $fontsize: 字体大小
   * @param $x: 字体在图片中的x位置
   * @param $y: 字体在图片中的y位置
   * @param $color: 字体的颜色是一个包含rgba的数组
   * @param $text: 想要添加的内容
   * 操作内存中的图片,给图片添加文字水印
   */
  public function fontMark($fontsize,$x,$y,$color,$text){
    $col = imagecolorallocatealpha($this->image,$color[0],$color[1],$color[2],$color[3]);
    imagestring($this->image,$fontsize,$x,$y,$text,$col);
  }
  /*
   * 输出图片到浏览器中
   */
  public function show(){
    header('content-type:' . $this -> info['mime']);
    $fun='image' . $this->info['type'];
    $fun($this->image);
  }
  /**
   * 销毁图片
   */
  function __destruct(){
    imagedestroy($this->image);
  }
}
//对类的调用
$obj = new Image_class('001.png');
$obj->fontMark(20,20,30,array(255,255,255,60),'hello');
$obj->show();

2: 面向过程的编写利用php给图片添加水印方法:

//指定图片路径
$src = '001.png';
//获取图片信息
$info = getimagesize($src);
//获取图片扩展名
$type = image_type_to_extension($info[2],false);
//动态的把图片导入内存中
$fun = "imagecreatefrom{$type}";
$image = $fun('001.png');
//指定字体颜色
$col = imagecolorallocatealpha($image,255,255,255,50);
//指定字体内容
$content = 'helloworld';
//给图片添加文字
imagestring($image,5,20,30,$content,$col);
//指定输入类型
header('Content-type:'.$info['mime']);
//动态的输出图片到浏览器中
$func = "image{$type}";
$func($image);
//销毁图片
imagedestroy($image);

以上代码示例是介绍php面向对象与面向过程两种方法给图片添加文字水印,希望大家喜欢。

PHP 相关文章推荐
php FLEA中二叉树数组的遍历输出
Sep 26 PHP
PHP图片等比缩放类SimpleImage使用方法和使用实例分享
Apr 10 PHP
又一个PHP实现的冒泡排序算法分享
Aug 21 PHP
PHP中定义数组常量(array常量)的方法
Nov 17 PHP
ThinkPHP 404页面的设置方法
Jan 14 PHP
php计算一个文件大小的方法
Mar 30 PHP
php+mysql实现简单的增删改查功能
Jul 13 PHP
PHP简单实现DES加密解密的方法
Jul 12 PHP
PHP使用Redis替代文件存储Session的方法
Feb 15 PHP
php生成网页桌面快捷方式
May 05 PHP
PHP中OpenSSL加密问题整理
Dec 14 PHP
PHP htmlspecialchars_decode()函数用法讲解
Mar 01 PHP
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
Aug 25 #PHP
百度地图API使用方法详解
Aug 25 #PHP
PHP实现生成唯一会员卡号
Aug 24 #PHP
PHP实现微信发红包程序
Aug 24 #PHP
php 利用socket发送HTTP请求(GET,POST)
Aug 24 #PHP
php实现递归的三种基本方式
Jul 04 #PHP
php析构函数的简单使用说明
Aug 24 #PHP
You might like
搭建基于Docker的PHP开发环境的详细教程
2015/07/01 PHP
PHP实现四种基础排序算法的运行时间比较(推荐)
2016/08/11 PHP
详解PHP处理密码的几种方式
2016/11/30 PHP
php 从指定数字中获取随机组合的简单方法(推荐)
2017/04/05 PHP
PHP常量define和const的区别详解
2019/05/18 PHP
在iframe里的页面编写js,实现在父窗口上创建动画效果展开和收缩的div(不变动iframe父窗口代码)
2011/12/20 Javascript
FusionCharts图表显示双Y轴双(多)曲线
2012/11/22 Javascript
js实现页面转发功能示例代码
2013/08/05 Javascript
jquery仿搜索自动联想功能代码
2014/05/23 Javascript
JavaScript实现动态创建CSS样式规则方案
2014/09/06 Javascript
javascript解三阶幻方(九宫格)
2015/04/22 Javascript
JavaScript创建闭包的两种方式的优劣与区别分析
2015/06/22 Javascript
第三篇Bootstrap网格基础
2016/06/21 Javascript
JavaScript实现三级联动菜单实例代码
2017/06/26 Javascript
详解最新vue-cli 2.9.1的webpack存在问题
2017/12/16 Javascript
在Vue中使用echarts的方法
2018/02/05 Javascript
js异步上传多张图片插件的使用方法
2018/10/22 Javascript
10行代码实现微信小程序滑动tab切换
2018/12/28 Javascript
详解VScode编辑器vue环境搭建所遇问题解决方案
2019/04/26 Javascript
[48:52]DOTA2上海特级锦标赛A组小组赛#2 Secret VS CDEC第一局
2016/02/25 DOTA
Python优化技巧之利用ctypes提高执行速度
2016/09/11 Python
python中lambda()的用法
2017/11/16 Python
浅析Python数据处理
2018/05/02 Python
python爬虫之urllib库常用方法用法总结大全
2018/11/14 Python
python基于itchat模块实现微信防撤回
2019/04/29 Python
图解python全局变量与局部变量相关知识
2019/11/02 Python
pycharm中leetcode插件使用图文详解
2020/12/07 Python
详解移动端h5页面根据屏幕适配的四种方案
2020/04/15 HTML / CSS
大学生个人自荐信样本
2014/03/02 职场文书
发展党员工作情况汇报
2014/10/28 职场文书
2015年办公室文员工作总结
2015/04/24 职场文书
道歉情书大全
2015/05/12 职场文书
离职信范本
2015/06/23 职场文书
jQuery实现影院选座订座效果
2021/04/13 jQuery
Java面试题冲刺第十七天--基础篇3
2021/08/07 面试题
vue中 this.$set的使用详解
2021/11/17 Vue.js