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基础知识:类与对象(2) 自动加载对象
Dec 13 PHP
PHP伪造referer实例代码
Sep 20 PHP
调整PHP的性能
Oct 30 PHP
destoon复制新模块的方法
Jun 21 PHP
php+mysqli事务控制实现银行转账实例
Jan 29 PHP
php去除二维数组的重复项方法
Nov 03 PHP
PHP时间类完整实例(非常实用)
Dec 25 PHP
PHP中Restful api 错误提示返回值实现思路
Apr 12 PHP
关于php中一些字符串总结
May 05 PHP
PHP编程实现多维数组按照某个键值排序的方法小结【2种方法】
Apr 27 PHP
详解PHP序列化和反序列化原理
Jan 15 PHP
php 原生分页
Apr 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
无数据库的详细域名查询程序PHP版(2)
2006/10/09 PHP
社区(php&&mysql)一
2006/10/09 PHP
php上传、管理照片示例
2006/10/09 PHP
PHP 登录完成后如何跳转上一访问页面
2014/01/14 PHP
php中rename函数用法分析
2014/11/15 PHP
jQuery Mobile + PHP实现文件上传
2014/12/12 PHP
PHP使用PDO实现mysql防注入功能详解
2019/12/20 PHP
常用参考资料(手册)下载或者链接
2006/07/22 Javascript
js实现楼层效果的简单实例
2016/07/15 Javascript
JavaScript判断数组是否存在key的简单实例
2016/08/03 Javascript
Ajax异步获取html数据中包含js方法无效的解决方法
2017/02/20 Javascript
利用jQuery实现一个简单的表格上下翻页效果
2017/03/14 Javascript
基于BootStrap multiselect.js实现的下拉框联动效果
2017/07/28 Javascript
Angular实现预加载延迟模块的示例
2017/10/12 Javascript
jQuery表单校验插件validator使用方法详解
2020/02/18 jQuery
浅析vue cli3 封装Svgicon组件正确姿势(推荐)
2020/04/27 Javascript
小程序Scroll-view上拉滚动刷新数据
2020/06/21 Javascript
[02:32]DOTA2亚洲邀请赛 VG战队巡礼
2015/02/03 DOTA
Python单例模式实例分析
2015/01/14 Python
python回溯法实现数组全排列输出实例分析
2015/03/17 Python
Python实现字符串与数组相互转换功能示例
2017/09/22 Python
使用Keras实现简单线性回归模型操作
2020/06/12 Python
keras输出预测值和真实值方式
2020/06/27 Python
解决Keras TensorFlow 混编中 trainable=False设置无效问题
2020/06/28 Python
Python依赖包迁移到断网环境操作
2020/07/13 Python
如何使用Django Admin管理后台导入CSV
2020/11/06 Python
详解Python+Selenium+ChromeDriver的配置和问题解决
2021/01/19 Python
一款超酷的js+css3实现的3D标签云特效兼容ie7/8/9
2013/11/18 HTML / CSS
美国时尚假发购物网站:Wigsbuy
2019/04/06 全球购物
大学生毕业求职简历的自我评价
2013/10/24 职场文书
银行实习生的自我评价
2013/12/09 职场文书
保卫科工作岗位职责
2014/03/01 职场文书
小学数学教学经验交流材料
2014/05/22 职场文书
护士求职信范文
2014/05/24 职场文书
《葡萄沟》教学反思
2016/02/23 职场文书
vue组件的路由高亮问题解决方法
2021/05/11 Vue.js