PHP 开发学习[3] —— 文字水印,缩略图,图片水印实现类

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/details/51598081

1.实现类参考代码

class ImageToTest {
    /**
     * 图片的基本信息
     */
    private $info;
    private $image;
    public function __construct($src){
        $info = getimagesize($src);
        $this->info = array(
            'width'=> $info[0],
            'height'=> $info[1],
            'type'=> image_type_to_extension($info[2],false),
            'mime'=>$info['mime']
        );
        $fun = "imagecreatefrom{$this->info['type']}";
        $this->image = $fun($src);
    }
    /**
     * 操作图片 (压缩)
     */
    public function thumb($width,$height){
        $image_thumb = imagecreatetruecolor($width,$height);
        imagecopyresampled($image_thumb,$this->image,0,0,0,0,$width,$height,
            $this->info['width'],$this->info['height']);
        imagedestroy($this->image);
        $this->image = $image_thumb;
    }
    /**
     * 操作图片(添加文字水印)
     */
    public function fontMark($content,$font_url,$size,$color,$local,$angle){
        $col = imagecolorallocatealpha($this->image,$color[0],$color[1],$color[2],$color[3]);
        imagettftext($this->image,$size,$angle,$local['x'],$local['y'],$col,$font_url,$content);
    }

    /**
     * 操作图片(添加水印图片)
     */
    public function imageMark($source,$local,$alpha){
        //1.获取水印图片的基本信息
        $info2 = getimagesize($source);
        //2.通过水印的图片编号来获取水印的图片类型
        $type2 = image_type_to_extension($info2[2],false);
        //3.在内存中创建一个和我们的水印图像一致的图像类型
        $func2 = "imagecreatefrom{$type2}";
        //4.把水印图片复制到内存中
        $water = $func2($source);
        //5.合并图片
        imagecopymerge($this->image,$water,$local['x'],$local['y'],0,0,$info2[0],$info2[1],$alpha);
        //6.销毁水印图片
        imagedestroy($water);
    }
    /**
     * 在浏览器中输出图片
     */
    public function show(){
        header("Content-type:".$this->info['mime']);
        $funs = "image{$this->info['type']}";
        $funs($this->image);
    }
    /**
     * 把图片保存到硬盘里
     */
    public function save($newName){
        $funs = "image{$this->info['type']}";
        $funs($this->image,'./outPut/'.$newName.'.'.$this->info['type']);
    }
    /**
     * 销毁图片  使用析构函数
     */
    public function __destruct()
    {
        imagedestroy($this->image);
    }
}

2.测试参考代码

require_once('ImageToTest.class.php');

/*$src = './image/wbg.jpg';
$image = new ImageToTest($src);
$image->thumb(700,550);
$image->show();*/


/*$src2 = './image/wbg.jpg';
$content = 'SGC';
$font_url = './image/YGYcuhei.ttf';
$size = 33;
$color = array(
    0=>2,
    1=>222,
    2=>222,
    3=>60
);
$local = array(
    'x'=>20,
    'y'=>100
);
$angle = 10;
$image2 = new ImageToTest($src2);
$image2->fontMark($content,$font_url,$size,$color,$local,$angle);
$image2->show();
$image2->save('hahahah');*/

$src3 = './image/wbg.jpg';
$source = './image/water.jpg';

$local = array(
    'x'=>20,
    'y'=>100
);
$font_url = './image/YGYcuhei.ttf';
$size = 38;
$color = array(
    0=>2,
    1=>222,
    2=>222,
    3=>60
);
$alpha = 60;
$angle = 50;
$image3 = new ImageToTest($src3);
$image3->imageMark($source,$local,$alpha);
$image3->thumb(700,550);
$image3->fontMark('Hello',$font_url,$size,$color,$local,$angle);
$image3->show();
$image3->save('WAWAWAWAWA');

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一“技”之长

Bootstrap响应式前端框架笔记十一——分页与标签

    在开发搜索结果页、列表页时通常会使用到分页器控件,Bootstrap中提供了方便的类来进行分页器的创建,示例如下:

14330
来自专栏Thinks

【译】W3C WAI-ARIA最佳实践 -- 控件

手风琴是个垂直罗列的元素组合,例如标签或缩略图,这允许用户切换内容模块的展示。每个标签元素可以被用来展开折叠、暴露隐藏其相关内容。手风琴一般被用来减少页面滚动,...

29730
来自专栏一个爱瞎折腾的程序猿

HTML5学习笔记

参考资料:http://www.runoob.com/html/html-tutorial.html

21330
来自专栏积累沉淀

JavaScript 事件基础补充

JavaScript事件是由访问Web页面的用户引起的一系列操作,例如:用户点击。当用户执行某些操作的时候,再去执行一系列代码。 一.事件介绍 JavaScri...

26650
来自专栏非著名程序员

AndroidTShare Weekly No.10

本周热点开源项目 SpinMenu 转动轮盘样式的Fragment切换效果,非常漂亮。 效果图如下: ? 作者:Hitomi 项目开源地址:https://gi...

215100
来自专栏前端之心

你真的了解回流和重绘吗

最近有空对其进行了一些研究,看了一些博客和书籍,整理了一些内容并且结合一些例子,写了这篇文章,希望可以帮助到大家。

92550
来自专栏王磊的博客

vscode使用汇总——常用插件、常用配置、常用快捷键

一、代码提示快捷键设置:(keybindings.json) [ { "key": "ctrl+j", "command...

51070
来自专栏施炯的IoT开发专栏

Windows Mobile上的HTML解析器

Matjaž Prtenjak提出这个移动设备上HTML解析器、并表现在HTML Label上的最初目的,就是为了能够在界面上实时地改变一些控件上的文字内容和...

22650
来自专栏DeveWork

删除 WordPress 导航菜单的多余 CSS 选择器

在默认情况下,WordPress 的导航菜单会输出很多如menu-item、menu-item-type-taxonomy、menu-item-object-c...

19870
来自专栏Google Dart

AngularDart Material Design 切换 顶

用户可以点击切换按钮来更改状态。 通常,当您有一个ON / OFF选项时,您可以使用切换按钮。 如果您要一组中的多个选项中选中/取消选中,请改用material...

8520

扫码关注云+社区

领取腾讯云代金券