- /*PHP 이미지와 텍스트 워터마크 라이브러리
-
- 이 클래스 라이브러리는 현재 텍스트 워터마크, 위치만 지원합니다. 오른쪽 하단, 색상은 랜덤입니다
-
- 호출 방법:
- 1. 워터마크를 적용해야 하는 파일 상단에 클래스 라이브러리를 소개합니다:
- include_once 'imageClass.php'
- 2. 새 클래스 선언:
- $tpl=new image_fu;
- 3. 이미지 워터마크에 대한 매개변수 제공:
- $tpl->img (이미지 경로, 워터마크 텍스트, 글꼴 경로, 글꼴 크기, 글꼴 각도);
- 예:$tpl->img('abc.jpg','워터마크 텍스트입니다.','ziti.ttf',30,0)
-
- */
-
- class image_fu{
-
- private $image;
- private $img_info;
- private $img_width;
- private $img_height;
- private $img_im;
- 비공개 $img_text;
- 비공개 $img_ttf= '';
- 비공개 $img_new;
- 비공개 $img_text_size;
- 비공개 $img_jd;
-
-
- 함수 img($img= '',$txt='',$ttf ='',$size=12,$jiaodu=0){
- if(isset($img)&&file_exists($img)){//이미지가 존재하는지 확인하세요.
- $this->image =$img ;
- $this->img_text=$txt;
- $this->img_text_size=$size;
- $this->img_jd=$ jiaodu;
- if(file_exists($ttf) ){
- $this->img_ttf=$ttf;
- }else{
- exit('글꼴 파일: '.$ttf.'는 그렇지 않습니다. 존재합니다!');
- }
- $ this->imgyesno();
- }else{
- exit('이미지 파일:'.$img.'이 존재하지 않습니다.');
- }
- }
-
- 비공개 함수 imgyesno(){
-
- $this->img_info =getimagesize($this->image);
- $this->img_width =$this->img_info[0];//이미지 너비
- $this->img_height=$this->img_info[1];//사진 높이
-
- //사진 유형 감지
- 스위치($this->img_info[2] ){
- 사례 1:$this->img_im = imagecreatefromgif($this->image);break
- 사례 2:$this- >img_im = imagecreatefromjpeg($this->image); break;
- 사례 3:$this->img_im = imagecreatefrompng($this->image);break
- default:exit('Image 형식은 워터마크를 지원하지 않습니다');
- }
-
- $this->img_text();
- }
-
-
- 비공개 함수 img_text(){
-
- imagealphblending($this->img_im,true);
-
- //색상 설정
- $color=imagecolorallocate($this->img_im,255,255,255);
- $txt_height=$this ->img_text_size;
- $txt_jiaodu=$this- >img_jd;
- $ttf_im=imagettfbbox($txt_height,$txt_jiaodu,$this->img_ttf,$this->img_text);
- $w = $ttf_im[2] - $ttf_im[6] ;
- $h = $ttf_im[3] - $ttf_im[7]
- //$w = $ttf_im[7]; //$h = $ttf_im[8];
-
- unset($ttf_im);
-
- $txt_y =$this->img_height*0.5;
- $txt_x =$this- >img_width*0.2;
- //$txt_y = 0;
- //$txt_x =0;
-
-
-
- $this->img_new=@imagettftext($this ->img_im,$txt_height,$txt_jiaodu,$txt_x, $txt_y,$color,$this->img_ttf,$this->img_text);
-
- @unlink($this->image );//이미지 삭제
- switch($this- >img_info[2]) {//배경 이미지 형식 가져오기
- 사례 1:imagegif($this->img_im,$this-> ;image);break
- 사례 2:imagejpeg($this ->img_im,$this->image);break
- 사례 3:imagepng($this->img_im,$this-> ;image);break;
- default:exit('워터마크 이미지 실패');
- }
-
- }
-
-
- //이미지 표시
- function img_show( ){echo '';}
-
- //메모리 해제
- private function img_nothing(){
- unset($this->img_info)
- imagedestroy($this->img_im)
- }
-
- }
-
- ?>
-
코드 복사
-
/**
- * 由 JetBrains PhpStorm 建立。
- * 使用者:taoqili
- * 日期:12-7-18
- * 時間:上午10:42
- */
- header("Content-Type: text/html; charset=utf-8");
- error_reporting(E_ERROR | E_WARNING);
- include "Uploader.class.php";
- //上傳圖片框中的描述表單名稱,
- $title = htmlspecialchars($_POST['pictitle'], ENT_QUOTES);
- $path = htmlspecialchars($_POST['dir'], ENT_QUOTES);
-
- //上傳設定
- $config = array(
- "savePath" //上傳設定
- $config = array(
- "savePath" = => path == "1" ? "upload/" : "upload1/"),
- "maxSize" => 1000, //單位KB
- "allowFiles" => array(".gif", ".png ", ".jpg", ".jpeg", ".bmp")
- );
-
- //產生上傳實例物件並完成上傳
- $up = new Uploader("upfile", $config);
-
- /**
- * 得到上傳檔案所對應的各個參數,陣列結構
- * array(
- * "originalName" => "", //原始檔案名稱
- * "name" => "", //新檔案名稱
- * "url" => "", //傳回的位址
- * "size" => "", //檔案大小
- * "type" => "" , //檔案類型
- * "state" => "" //上傳狀態,上傳成功時必須回傳"SUCCESS"
- * )
- */
- $info = $up->getFileInfo();
-
- /**
- * 傳回資料json資料
- * {
- * 'url' :'a.jpg', //儲存後的檔案路徑
- * 'title' :'hello', / /檔案描述,對圖片來說在前端會加入到title屬性上
- * 'original' :'b.jpg', //原始檔名
- * 'state' :'SUCCESS' //上傳狀態,成功時返回SUCCESS,其他任何值將原樣返回至圖片上傳框
- * }
- */
-
- /* include "imgwater.php";
- $tpl=new image_fu;
- $tpl->img($info['url'],'http://www.zgxbzh.com/', 'simsun.ttc',30,0);*/
-
- echo "{'url':'" . $info["url"] . "','title':'" . $title . "','original':'" . $info["originalName"] . "','state':'" . $info["state"] . "'}";
-
複製程式碼
|