ホームページ > バックエンド開発 > PHPチュートリアル > PHP を使用して画像にテキストの透かしを追加する - オブジェクト指向およびプロセス指向のメソッドの実装

PHP を使用して画像にテキストの透かしを追加する - オブジェクト指向およびプロセス指向のメソッドの実装

WBOY
リリース: 2016-07-30 13:30:32
オリジナル
1626 人が閲覧しました

1: プロセス指向の記述方法

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

2: オブジェクト指向の実装方​​法

<span>class</span><span> Image_class {
    </span><span>private</span><span>$image</span><span>;
    </span><span>private</span><span>$info</span><span>;

    </span><span>/*</span><span>*
     * @param $src:图片路径
     * 加载图片到内存中
     </span><span>*/</span><span>function</span> __construct(<span>$src</span><span>){
        </span><span>$info</span> = <span>getimagesize</span>(<span>$src</span><span>);
        </span><span>$type</span> = image_type_to_extension(<span>$info</span>[2],<span>false</span><span>);
        </span><span>$this</span> -> info =<span>$info</span><span>;
        </span><span>$this</span>->info['type'] = <span>$type</span><span>;
        </span><span>$fun</span> = "imagecreatefrom" .<span>$type</span><span>;
        </span><span>$this</span> -> image = <span>$fun</span>(<span>$src</span><span>);
    }

    </span><span>/*</span><span>*
     * @param $fontsize: 字体大小
     * @param $x: 字体在图片中的x位置
     * @param $y: 字体在图片中的y位置
     * @param $color: 字体的颜色是一个包含rgba的数组
     * @param $text: 想要添加的内容
     * 操作内存中的图片,给图片添加文字水印
     </span><span>*/</span><span>public</span><span>function</span> fontMark(<span>$fontsize</span>,<span>$x</span>,<span>$y</span>,<span>$color</span>,<span>$text</span><span>){
        </span><span>$col</span> = imagecolorallocatealpha(<span>$this</span>->image,<span>$color</span>[0],<span>$color</span>[1],<span>$color</span>[2],<span>$color</span>[3<span>]);
        imagestring(</span><span>$this</span>->image,<span>$fontsize</span>,<span>$x</span>,<span>$y</span>,<span>$text</span>,<span>$col</span><span>);
    }
    </span><span>/*</span><span>     * 输出图片到浏览器中
     </span><span>*/</span><span>public</span><span>function</span><span> show(){
       </span><span>header</span>('content-type:' . <span>$this</span> -> info['mime'<span>]);
        </span><span>$fun</span>='image' . <span>$this</span>->info['type'<span>];
        </span><span>$fun</span>(<span>$this</span>-><span>image);
    }

    </span><span>/*</span><span>*
     * 销毁图片
     </span><span>*/</span><span>function</span><span> __destruct(){
        imagedestroy(</span><span>$this</span>-><span>image);
    }
}
</span><span>//</span><span>对类的调用</span><span>$obj</span> = <span>new</span> Image_class('001.png'<span>);
</span><span>$obj</span>->fontMark(20,20,30,<span>array</span>(255,255,255,60),'hello'<span>);
</span><span>$obj</span>->show();
ログイン後にコピー

上記では、PHP を使用して画像にテキストの透かしを追加する方法、つまりオブジェクト指向とプロセス指向の 2 つの方法の実装を紹介しました。内容の側面も含めて、PHP チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート