PHP-Klasse zum Generieren von Miniaturbildern

墨辰丷
Freigeben: 2023-03-30 13:22:02
Original
1621 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich die PHP-Klasse zum Generieren von Miniaturbildern vor. Ich hoffe, dass er für alle hilfreich ist.

Funktion: Unterstützt die Bildformate JPG, JPEG, GIF, PNG, BMP, unterstützt die Skalierung entsprechend dem Anteil des Originalbilds, Sie können auswählen, ob das Bild während des Bildskalierungsprozesses zugeschnitten werden soll, und Bildqualität hinzufügen Steuern Sie, um die Qualität der Miniaturansichten zu maximieren. Der Code der gesamten Klasse lautet wie folgt:

<?php
/**
 * 功能:php生成缩略图片的类
 */
 class ResizeImage{
  public $type;//图片类型
  public $width;//实际宽度
  public $height;//实际高度
  public $resize_width;//改变后的宽度
  public $resize_height;//改变后的高度
  public $cut;//是否裁图
  public $srcimg;//源图象 
  public $dstimg;//目标图象地址
  public $im;//临时创建的图象
  public $quality;//图片质量
  function resizeimage($img,$wid,$hei,$c,$dstpath,$quality=100){
   $this->srcimg=$img;
   $this->resize_width=$wid;
   $this->resize_height=$hei;
   $this->cut=$c;
   $this->quality=$quality;
   $this->type=strtolower(substr(strrchr($this->srcimg,&#39;.&#39;),1));//图片的类型
   $this->initi_img();//初始化图象
   $this -> dst_img($dstpath);//目标图象地址
   @$this->width=imagesx($this->im);
   @$this->height=imagesy($this->im);
   $this->newimg();//生成图象
   @ImageDestroy($this->im);
  }
  function newimg(){
   $resize_ratio=($this->resize_width)/($this->resize_height);//改变后的图象的比例
   @$ratio=($this->width)/($this->height);//实际图象的比例
   if(($this->cut)==&#39;1&#39;){//裁图
    if($img_func===&#39;imagepng&#39;&&(str_replace(&#39;.&#39;,&#39;&#39;,PHP_VERSION)>=512)){ //针对php版本大于5.12参数变化后的处理情况
     $quality=9;
    }
    if($ratio>=$resize_ratio){//高度优先
     $newimg=imagecreatetruecolor($this->resize_width,$this->resize_height);
     imagecopyresampled($newimg,$this->im,0,0,0,0,$this->resize_width,$this->resize_height,(($this->height)*$resize_ratio),$this->height);
     imagejpeg($newimg,$this->dstimg,$this->quality);
    }
    if($ratio<$resize_ratio){//宽度优先
     $newimg=imagecreatetruecolor($this->resize_width,$this->resize_height);
     imagecopyresampled($newimg,$this->im,0,0,0,0,$this->resize_width,$this->resize_height,$this->width,(($this->width)/$resize_ratio));
     imagejpeg($newimg,$this->dstimg,$this->quality);
    }
   }else{//不裁图
    if($ratio>=$resize_ratio){
     $newimg=imagecreatetruecolor($this->resize_width,($this->resize_width)/$ratio);
     imagecopyresampled($newimg,$this->im,0,0,0,0,$this->resize_width,($this->resize_width)/$ratio,$this->width,$this->height);
     imagejpeg($newimg,$this->dstimg,$this->quality);
    }
    if($ratio<$resize_ratio){
     @$newimg=imagecreatetruecolor(($this->resize_height)*$ratio,$this->resize_height);
     @imagecopyresampled($newimg,$this->im,0,0,0,0,($this->resize_height)*$ratio,$this->resize_height,$this->width,$this->height);
     @imagejpeg($newimg,$this->dstimg,$this->quality);
    }
   }
  }
  function initi_img(){//初始化图象
   if($this->type==&#39;jpg&#39; || $this->type==&#39;jpeg&#39;){
    $this->im=imagecreatefromjpeg($this->srcimg);
   }
   if($this->type==&#39;gif&#39;){
    $this->im=imagecreatefromgif($this->srcimg);
   }
   if($this->type==&#39;png&#39;){
    $this->im=imagecreatefrompng($this->srcimg);
   }
   if($this->type==&#39;wbm&#39;){
    @$this->im=imagecreatefromwbmp($this->srcimg);
   }
   if($this->type==&#39;bmp&#39;){
    $this->im=$this->ImageCreateFromBMP($this->srcimg);
   }
  }
  function dst_img($dstpath){//图象目标地址
   $full_length=strlen($this->srcimg);
   $type_length=strlen($this->type);
   $name_length=$full_length-$type_length;
   $name=substr($this->srcimg,0,$name_length-1);
   $this->dstimg=$dstpath;
   //echo $this->dstimg;
  }
   
  function ImageCreateFromBMP($filename){ //自定义函数处理bmp图片
   if(!$f1=fopen($filename,"rb"))returnFALSE;
   $FILE=unpack("vfile_type/Vfile_size/Vreserved/Vbitmap_offset",fread($f1,14));
   if($FILE[&#39;file_type&#39;]!=19778)returnFALSE;
   $BMP=unpack(&#39;Vheader_size/Vwidth/Vheight/vplanes/vbits_per_pixel&#39;.
     &#39;/Vcompression/Vsize_bitmap/Vhoriz_resolution&#39;.
     &#39;/Vvert_resolution/Vcolors_used/Vcolors_important&#39;,fread($f1,40));
   $BMP[&#39;colors&#39;]=pow(2,$BMP[&#39;bits_per_pixel&#39;]);
   if($BMP[&#39;size_bitmap&#39;]==0)$BMP[&#39;size_bitmap&#39;]=$FILE[&#39;file_size&#39;]-$FILE[&#39;bitmap_offset&#39;];
   $BMP[&#39;bytes_per_pixel&#39;]=$BMP[&#39;bits_per_pixel&#39;]/8;
   $BMP[&#39;bytes_per_pixel2&#39;]=ceil($BMP[&#39;bytes_per_pixel&#39;]);
   $BMP[&#39;decal&#39;]=($BMP[&#39;width&#39;]*$BMP[&#39;bytes_per_pixel&#39;]/4);
   $BMP[&#39;decal&#39;]-=floor($BMP[&#39;width&#39;]*$BMP[&#39;bytes_per_pixel&#39;]/4);
   $BMP[&#39;decal&#39;]=4-(4*$BMP[&#39;decal&#39;]);
   if($BMP[&#39;decal&#39;]==4)$BMP[&#39;decal&#39;]=0;
   $PALETTE=array();
   if($BMP[&#39;colors&#39;]<16777216)
   {
    $PALETTE=unpack(&#39;V&#39;.$BMP[&#39;colors&#39;],fread($f1,$BMP[&#39;colors&#39;]*4));
   }
   $IMG=fread($f1,$BMP[&#39;size_bitmap&#39;]);
   $VIDE=chr(0);
   $res=imagecreatetruecolor($BMP[&#39;width&#39;],$BMP[&#39;height&#39;]);
   $P=0;
   $Y=$BMP[&#39;height&#39;]-1;
   while($Y>=0)
   {
    $X=0;
    while($X<$BMP[&#39;width&#39;])
    {
     if($BMP[&#39;bits_per_pixel&#39;]==24)
      $COLOR=unpack("V",substr($IMG,$P,3).$VIDE);
     elseif($BMP[&#39;bits_per_pixel&#39;]==16)
     {
      $COLOR=unpack("n",substr($IMG,$P,2));
      $COLOR[1]=$PALETTE[$COLOR[1]+1];
     }
     elseif($BMP[&#39;bits_per_pixel&#39;]==8)
     {
      $COLOR=unpack("n",$VIDE.substr($IMG,$P,1));
      $COLOR[1]=$PALETTE[$COLOR[1]+1];
     }
     elseif($BMP[&#39;bits_per_pixel&#39;]==4)
     {
      $COLOR=unpack("n",$VIDE.substr($IMG,floor($P),1));
      if(($P*2)%2==0)$COLOR[1]=($COLOR[1]>>4);else$COLOR[1]=($COLOR[1]&0x0F);
      $COLOR[1]=$PALETTE[$COLOR[1]+1];
     }
     elseif($BMP[&#39;bits_per_pixel&#39;]==1)
     {
      $COLOR=unpack("n",$VIDE.substr($IMG,floor($P),1));
      if(($P*8)%8==0)$COLOR[1]=$COLOR[1]>>7;
      elseif(($P*8)%8==1)$COLOR[1]=($COLOR[1]&0x40)>>6;
      elseif(($P*8)%8==2)$COLOR[1]=($COLOR[1]&0x20)>>5;
      elseif(($P*8)%8==3)$COLOR[1]=($COLOR[1]&0x10)>>4;
      elseif(($P*8)%8==4)$COLOR[1]=($COLOR[1]&0x8)>>3;
      elseif(($P*8)%8==5)$COLOR[1]=($COLOR[1]&0x4)>>2;
      elseif(($P*8)%8==6)$COLOR[1]=($COLOR[1]&0x2)>>1;
      elseif(($P*8)%8==7)$COLOR[1]=($COLOR[1]&0x1);
      $COLOR[1]=$PALETTE[$COLOR[1]+1];
     }
     else
      returnFALSE;
     imagesetpixel($res,$X,$Y,$COLOR[1]);
     $X++;
     $P+=$BMP[&#39;bytes_per_pixel&#39;];
    }
    $Y--;
    $P+=$BMP[&#39;decal&#39;];
   }
   fclose($f1);
   return$res;
  }
   
 }
?>
Nach dem Login kopieren

Die Verwendungsmethode ist sehr einfach. Der Code lautet wie folgt:

$resizeimage=new ResizeImage(&#39;upload/abc.bmp&#39;, &#39;120&#39;, &#39;90&#39;, &#39;0&#39;, &#39;upload/xabc.bmp&#39;);
Nach dem Login kopieren


Eine weitere leistungsstarke PHP-Bildminiaturklasse: phpThumb

Neben der Skalierung von Bildern kann diese Klasse auch Bilder in verschiedene Formate für die Ausgabe konvertieren (z. B. die Ausgabe von Bildern im GIF-Format in das PNG-Format). Zu ihren besonderen Funktionen gehören auch Farbe, Spezialeffekte, usw.

Offizielle Website: http://phpthumb.sourceforge.net/

Wir werden phpThumb verwenden, das Open-Source-PHP-Skript, um Miniaturansichten im Handumdrehen zu generieren.

Laden Sie phpThumb herunter und extrahieren Sie es irgendwo in Ihrem Website-Ordner. Um nun ein Miniaturbild mit abgerundeten Ecken zu verwenden, verwenden Sie einfach das img-Tag von HTML mit src as

 <img src=”phpThumb.php?src=test.jpg&w=200&h=150&fltr[]=ric|20|20&f=png” /> 

 Adjust the path to phpThumb according to where you place the phpThumb files.

 <html> 
 <head>
 </head> 
 <body> 
  <img src="phpThumb/phpThumb.php?src=../images/test.jpg&w=400&fltr[]=fram|3|2|CC9966|333333|CCCCCC" alt=""> 
 </body> 
 </html>
Nach dem Login kopieren

Normalerweise wird nur die folgende Datei benötigt

Tatsächlich ist die Funktion von phpThumb leistungsfähiger als ich ursprünglich dachte. Lassen Sie uns einige seiner anderen nützlichen Parameter auflisten:

src: die Adresse des Zielbildes

w: die Breite des Ausgabebildes

h: Die Höhe des Ausgabebildes (falls nicht angegeben, wird es gemäß dem w-Parameter skaliert)

q: Wenn die Ausgabe im JPG-Format erfolgt , seine Ausgabequalität kann angegeben werden

bg: Ausgabehintergrund (falls erforderlich)

sw, sh, sx, sy: lokale Ausgabe, Breite, Höhe, Startposition

f: Ausgabeformat, kann JPEG, PNG, GIF, ICO sein

sfn: Gibt einen bestimmten Frame in der GIF-Animation aus

fltr[]: Filter, der viele Effekte haben kann, einschließlich Schärfung , Unschärfe, Drehung, Wasserzeichen, Rand, Maske, Farbanpassung usw.

Verwendungsdemonstration:

//加载类库文件

 require_once &#39;path/to/ThumbLib.inc.php&#39;;

 //实例化类库,传入你要处理的图片的地址可以是网络地址,也可以是本地地址

 $thumb = PhpThumbFactory::create(&#39;http://www.shlongyingjixie.com/&#39;);

 //把图片等比缩小到最大宽度 100px或者最高100px,当只输入一个参数的时候,是限制最宽的尺寸。

 $thumb->resize(100, 100);

 //把图片等比缩小到原来的百分数,比如50就是原来的50%。

 $thumb->resizePercent(50);

 //截取一个175px * 175px的图片,注意这个是截取,超出的部分直接裁切掉,不是强制改变尺寸。
 $thumb->adaptiveResize(175, 175);

 //从图片的中心计算,截取200px * 100px的图片。

 $thumb->cropFromCenter(200, 100);

 //截图,前两个参数分别是需要解出的图片的右上角的坐标X,Y。 后面两个参数是需要解出的图片宽,高。

 $thumb->crop(100, 100, 300, 200);
 
 //把图片顺时针反转180度

 $thumb->rotateImageNDegrees(180);

 //保存(生成)图片,你可以保存其他格式,详细参考文档

 $thumb->save( &#39;NewPath/Of/image.jpg &#39; );
Nach dem Login kopieren

Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass es für das Lernen aller hilfreich sein wird.

Verwandte Empfehlungen:

Analyse des asynchronen Hochladens einer PHP-Formulardatei im Iframe

Redis-Multibibliothek implementiert Wählen Sie in PHP die funktionale Singleton-Klasse aus (detaillierte Erklärung)

Detaillierte Erklärung der Methode der benutzerdefinierten PHP-Funktion, um zu bestimmen, ob es sich um eine Get/Post/Ajax-Übermittlung handelt

Das obige ist der detaillierte Inhalt vonPHP-Klasse zum Generieren von Miniaturbildern. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage