Home Backend Development PHP Tutorial PHP图片处理扩展php_imagick类库使用

PHP图片处理扩展php_imagick类库使用

Jun 20, 2016 pm 01:02 PM

一个好用的封装PHP扩展php_imagick的类库

imagick提供了极其丰富的处理图片方法,下面介绍一个封装php_imagick的类库:

class lib_image_imagick
{
	private $image = null;
	private $type = null;
 
	// 构造函数
	public function __construct(){}
 
 
	// 析构函数
	public function __destruct()
	{
	    if($this->image!==null) $this->image->destroy(); 
	}
 
	// 载入图像
	public function open($path)
	{
		$this->image = new Imagick( $path );
		if($this->image)
		{
		    $this->type = strtolower($this->image->getImageFormat());
		}
		return $this->image;
	}
	
	public function cropimage($width=0, $height=0){
		if($width<=0 || $height<=0) return;
		$this->image->cropThumbnailImage($width, $height);
	}
	
	public function thumbnailImage($width=0, $height=0){
		if($width<=0) return;
		$this->image->thumbnailImage($width, NULL);
	}
 
	public function crop($x=0, $y=0, $width=null, $height=null)
	{
	    if($width==null) $width = $this->image->getImageWidth()-$x;
	    if($height==null) $height = $this->image->getImageHeight()-$y;
	    if($width<=0 || $height<=0) return;
	    
	    if($this->type==&#39;gif&#39;)
	    {
            $image = $this->image;
	        $canvas = new Imagick();
	        
        	$images = $image->coalesceImages();
    	    foreach($images as $frame){
    	        $img = new Imagick();
    	        $img->readImageBlob($frame);
                $img->cropImage($width, $height, $x, $y);
 
                $canvas->addImage( $img );
                $canvas->setImageDelay( $img->getImageDelay() );
                $canvas->setImagePage($width, $height, 0, 0);
            }
            
            $image->destroy();
	        $this->image = $canvas;
	    }
	    else
	    {
	        $this->image->cropImage($width, $height, $x, $y);
	    }
	}
 
	/*
	* 更改图像大小
	$fit: 适应大小方式
	&#39;force&#39;: 把图片强制变形成 $width X $height 大小
	&#39;scale&#39;: 按比例在安全框 $width X $height 内缩放图片, 输出缩放后图像大小 不完全等于 $width X $height
	&#39;scale_fill&#39;: 按比例在安全框 $width X $height 内缩放图片,安全框内没有像素的地方填充色, 使用此参数时可设置背景填充色 $bg_color = array(255,255,255)(红,绿,蓝, 透明度) 透明度(0不透明-127完全透明))
	其它: 智能模能 缩放图像并载取图像的中间部分 $width X $height 像素大小
	$fit = &#39;force&#39;,&#39;scale&#39;,&#39;scale_fill&#39; 时: 输出完整图像
	$fit = 图像方位值 时, 输出指定位置部分图像 
	字母与图像的对应关系如下:
	
	north_west   north   north_east
	
	west         center        east
	
	south_west   south   south_east
	
	*/
	public function resize_to($width = 100, $height = 100, $fit = &#39;center&#39;, $fill_color = array(255,255,255,0) )
	{
	    
	    switch($fit)
	    {
	        case &#39;force&#39;:
        	    if($this->type==&#39;gif&#39;)
        	    {
        	        $image = $this->image;
        	        $canvas = new Imagick();
        	        
        	        $images = $image->coalesceImages();
            	    foreach($images as $frame){
            	        $img = new Imagick();
            	        $img->readImageBlob($frame);
                        $img->thumbnailImage( $width, $height, false );
 
                        $canvas->addImage( $img );
                        $canvas->setImageDelay( $img->getImageDelay() );
                    }
                    $image->destroy();
	                $this->image = $canvas;
        	    }
        	    else
        	    {
        	        $this->image->thumbnailImage( $width, $height, false );
        	    }
	            break;
	        case &#39;scale&#39;:
	            if($this->type==&#39;gif&#39;)
        	    {
        	        $image = $this->image;
        	        $images = $image->coalesceImages();
        	        $canvas = new Imagick();
            	    foreach($images as $frame){
            	        $img = new Imagick();
            	        $img->readImageBlob($frame);
                        $img->thumbnailImage( $width, $height, true );
 
                        $canvas->addImage( $img );
                        $canvas->setImageDelay( $img->getImageDelay() );
                    }
                    $image->destroy();
	                $this->image = $canvas;
        	    }
        	    else
        	    {
        	        $this->image->thumbnailImage( $width, $height, true );
        	    }
	            break;
	        case &#39;scale_fill&#39;:
	            $size = $this->image->getImagePage(); 
	            $src_width = $size[&#39;width&#39;];
	            $src_height = $size[&#39;height&#39;];
	            
                $x = 0;
                $y = 0;
                
                $dst_width = $width;
                $dst_height = $height;
 
	    		if($src_width*$height > $src_height*$width)
				{
					$dst_height = intval($width*$src_height/$src_width);
					$y = intval( ($height-$dst_height)/2 );
				}
				else
				{
					$dst_width = intval($height*$src_width/$src_height);
					$x = intval( ($width-$dst_width)/2 );
				}
 
                $image = $this->image;
                $canvas = new Imagick();
                
                $color = &#39;rgba(&#39;.$fill_color[0].&#39;,&#39;.$fill_color[1].&#39;,&#39;.$fill_color[2].&#39;,&#39;.$fill_color[3].&#39;)&#39;;
        	    if($this->type==&#39;gif&#39;)
        	    {
        	        $images = $image->coalesceImages();
            	    foreach($images as $frame)
            	    {
            	        $frame->thumbnailImage( $width, $height, true );
 
            	        $draw = new ImagickDraw();
                        $draw->composite($frame->getImageCompose(), $x, $y, $dst_width, $dst_height, $frame);
 
                        $img = new Imagick();
                        $img->newImage($width, $height, $color, &#39;gif&#39;);
                        $img->drawImage($draw);
 
                        $canvas->addImage( $img );
                        $canvas->setImageDelay( $img->getImageDelay() );
                        $canvas->setImagePage($width, $height, 0, 0);
                    }
        	    }
        	    else
        	    {
        	        $image->thumbnailImage( $width, $height, true );
        	        
        	        $draw = new ImagickDraw();
                    $draw->composite($image->getImageCompose(), $x, $y, $dst_width, $dst_height, $image);
                    
        	        $canvas->newImage($width, $height, $color, $this->get_type() );
                    $canvas->drawImage($draw);
                    $canvas->setImagePage($width, $height, 0, 0);
        	    }
        	    $image->destroy();
	            $this->image = $canvas;
	            break;
			default:
				$size = $this->image->getImagePage(); 
			    $src_width = $size[&#39;width&#39;];
	            $src_height = $size[&#39;height&#39;];
	            
                $crop_x = 0;
                $crop_y = 0;
                
                $crop_w = $src_width;
                $crop_h = $src_height;
                
	    	    if($src_width*$height > $src_height*$width)
				{
					$crop_w = intval($src_height*$width/$height);
				}
				else
				{
				    $crop_h = intval($src_width*$height/$width);
				}
                
			    switch($fit)
	            {
			    	case &#39;north_west&#39;:
			    	    $crop_x = 0;
			    	    $crop_y = 0;
			    	    break;
        			case &#39;north&#39;:
        			    $crop_x = intval( ($src_width-$crop_w)/2 );
        			    $crop_y = 0;
        			    break;
        			case &#39;north_east&#39;:
        			    $crop_x = $src_width-$crop_w;
        			    $crop_y = 0;
        			    break;
        			case &#39;west&#39;:
        			    $crop_x = 0;
        			    $crop_y = intval( ($src_height-$crop_h)/2 );
        			    break;
        			case &#39;center&#39;:
        			    $crop_x = intval( ($src_width-$crop_w)/2 );
        			    $crop_y = intval( ($src_height-$crop_h)/2 );
        			    break;
        			case &#39;east&#39;:
        			    $crop_x = $src_width-$crop_w;
        			    $crop_y = intval( ($src_height-$crop_h)/2 );
        			    break;
        			case &#39;south_west&#39;:
        			    $crop_x = 0;
        			    $crop_y = $src_height-$crop_h;
        			    break;
        			case &#39;south&#39;:
        			    $crop_x = intval( ($src_width-$crop_w)/2 );
        			    $crop_y = $src_height-$crop_h;
        			    break;
        			case &#39;south_east&#39;:
        			    $crop_x = $src_width-$crop_w;
        			    $crop_y = $src_height-$crop_h;
        			    break;
        			default:
        			    $crop_x = intval( ($src_width-$crop_w)/2 );
        			    $crop_y = intval( ($src_height-$crop_h)/2 );
	            }
	            
	            $image = $this->image;
	            $canvas = new Imagick();
	            
	    	    if($this->type==&#39;gif&#39;)
        	    {
        	        $images = $image->coalesceImages();
            	    foreach($images as $frame){
            	        $img = new Imagick();
            	        $img->readImageBlob($frame);
                        $img->cropImage($crop_w, $crop_h, $crop_x, $crop_y);
                        $img->thumbnailImage( $width, $height, true );
                        
                        $canvas->addImage( $img );
                        $canvas->setImageDelay( $img->getImageDelay() );
                        $canvas->setImagePage($width, $height, 0, 0);
                    }
        	    }
        	    else
        	    {
        	        $image->cropImage($crop_w, $crop_h, $crop_x, $crop_y);
        	        $image->thumbnailImage( $width, $height, true );
        	        $canvas->addImage( $image );
        	        $canvas->setImagePage($width, $height, 0, 0);
        	    }
        	    $image->destroy();
	            $this->image = $canvas;
	    }
	    
	}
	
 
	
 
	// 添加水印图片
	public function add_watermark($path, $x = 0, $y = 0)
	{
        $watermark = new Imagick($path);
        $draw = new ImagickDraw();
        $draw->composite($watermark->getImageCompose(), $x, $y, $watermark->getImageWidth(), $watermark->getimageheight(), $watermark);
 
	    if($this->type==&#39;gif&#39;)
	    {
	        $image = $this->image;
            $canvas = new Imagick();
        	$images = $image->coalesceImages();
    	    foreach($image as $frame)
    	    {
                $img = new Imagick();
    	        $img->readImageBlob($frame);
                $img->drawImage($draw);
                
                $canvas->addImage( $img );
                $canvas->setImageDelay( $img->getImageDelay() );
            }
            $image->destroy();
	        $this->image = $canvas;
	    }
	    else
	    {
	        $this->image->drawImage($draw);
	    }
	}
 
	
	// 添加水印文字
	public function add_text($text, $x = 0 , $y = 0, $angle=0, $style=array())
	{
        $draw = new ImagickDraw();
        if(isset($style[&#39;font&#39;])) $draw->setFont($style[&#39;font&#39;]);
        if(isset($style[&#39;font_size&#39;])) $draw->setFontSize($style[&#39;font_size&#39;]);
	    if(isset($style[&#39;fill_color&#39;])) $draw->setFillColor($style[&#39;fill_color&#39;]);
	    if(isset($style[&#39;under_color&#39;])) $draw->setTextUnderColor($style[&#39;under_color&#39;]);
	    
	    if($this->type==&#39;gif&#39;)
	    {
    	    foreach($this->image as $frame)
    	    {
    	        $frame->annotateImage($draw, $x, $y, $angle, $text);
    	    }
	    }
	    else
	    {
	        $this->image->annotateImage($draw, $x, $y, $angle, $text);
	    }
	}
	
	
	// 保存到指定路径
	public function save_to( $path )
	{
	    if($this->type==&#39;gif&#39;)
	    {
	        $this->image->writeImages($path, true);
	    }
	    else
	    {
	        $this->image->writeImage($path);
	    }
	}
 
	// 输出图像
	public function output($header = true)
	{
	    if($header) header(&#39;Content-type: &#39;.$this->type);
	    echo $this->image->getImagesBlob();		
	}
 
	
	public function get_width()
	{
        $size = $this->image->getImagePage(); 
        return $size[&#39;width&#39;];
	}
	
	public function get_height()
	{
	    $size = $this->image->getImagePage(); 
        return $size[&#39;height&#39;];
	}
 
	// 设置图像类型, 默认与源类型一致
	public function set_type( $type=&#39;png&#39; )
	{
	    $this->type = $type;
        $this->image->setImageFormat( $type );
	}
 
	// 获取源图像类型
	public function get_type()
	{
		return $this->type;
	}
 
 
	// 当前对象是否为图片
	public function is_image()
	{
		if( $this->image )
			return true;
		else
			return false;
	}
	
 
 
	public function thumbnail($width = 100, $height = 100, $fit = true){ $this->image->thumbnailImage( $width, $height, $fit );} // 生成缩略图 $fit为真时将保持比例并在安全框 $width X $height 内生成缩略图片
 
	/*
	添加一个边框
	$width: 左右边框宽度
	$height: 上下边框宽度
	$color: 颜色: RGB 颜色 &#39;rgb(255,0,0)&#39; 或 16进制颜色 &#39;#FF0000&#39; 或颜色单词 &#39;white&#39;/&#39;red&#39;...
	*/
	public function border($width, $height, $color=&#39;rgb(220, 220, 220)&#39;)
	{
		$color=new ImagickPixel();
		$color->setColor($color);
		$this->image->borderImage($color, $width, $height);
	}
	
	public function blur($radius, $sigma){$this->image->blurImage($radius, $sigma);} // 模糊
	public function gaussian_blur($radius, $sigma){$this->image->gaussianBlurImage($radius, $sigma);} // 高斯模糊
	public function motion_blur($radius, $sigma, $angle){$this->image->motionBlurImage($radius, $sigma, $angle);} // 运动模糊
	public function radial_blur($radius){$this->image->radialBlurImage($radius);} // 径向模糊
 
	public function add_noise($type=null){$this->image->addNoiseImage($type==null?imagick::NOISE_IMPULSE:$type);} // 添加噪点
	
	public function level($black_point, $gamma, $white_point){$this->image->levelImage($black_point, $gamma, $white_point);} // 调整色阶
	public function modulate($brightness, $saturation, $hue){$this->image->modulateImage($brightness, $saturation, $hue);} // 调整亮度、饱和度、色调
 
	public function charcoal($radius, $sigma){$this->image->charcoalImage($radius, $sigma);} // 素描
	public function oil_paint($radius){$this->image->oilPaintImage($radius);} // 油画效果
	
	public function flop(){$this->image->flopImage();} // 水平翻转
	public function flip(){$this->image->flipImage();} // 垂直翻转
 
}
Copy after login


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Apr 05, 2025 am 12:04 AM

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Describe the SOLID principles and how they apply to PHP development. Describe the SOLID principles and how they apply to PHP development. Apr 03, 2025 am 12:04 AM

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to automatically set permissions of unixsocket after system restart? How to automatically set permissions of unixsocket after system restart? Mar 31, 2025 pm 11:54 PM

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

How to send a POST request containing JSON data using PHP's cURL library? How to send a POST request containing JSON data using PHP's cURL library? Apr 01, 2025 pm 03:12 PM

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

Framework Security Features: Protecting against vulnerabilities. Framework Security Features: Protecting against vulnerabilities. Mar 28, 2025 pm 05:11 PM

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

Customizing/Extending Frameworks: How to add custom functionality. Customizing/Extending Frameworks: How to add custom functionality. Mar 28, 2025 pm 05:12 PM

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

See all articles