Javascript.RU

Уменьшить размер изображения php уменьшение качества картинки пример class php jpeg gif png

В гугле найти пример сложнее чем написать самому
Решил написать свой класс для обработки и уменьшения размера фотографий

Возможности класса:
- пропорционально уменьшать размер фото по ширине либо по высоте
- уменьшить фото в процентном соотношении
- вписать фотографию в рамку определенного размера
- произвольное изменение размера фотографии
- изменить качество фотографии
- вывод сгенерированной фотографии без сохранения
- сохранение фотографии на сервере
- назначение фото прав доступа

<?php
class picture {
	
	private $image_file;
	
	public $image;
	public $image_type;
	public $image_width;
	public $image_height;
	
	
	public function __construct($image_file) {
		$this->image_file=$image_file;
		$image_info = getimagesize($this->image_file);
		$this->image_width = $image_info[0];
		$this->image_height = $image_info[1];
		switch($image_info[2]) {
			case 1: $this->image_type = 'gif'; break;//1: IMAGETYPE_GIF
			case 2: $this->image_type = 'jpeg'; break;//2: IMAGETYPE_JPEG
			case 3: $this->image_type = 'png'; break;//3: IMAGETYPE_PNG
			case 4: $this->image_type = 'swf'; break;//4: IMAGETYPE_SWF
			case 5: $this->image_type = 'psd'; break;//5: IMAGETYPE_PSD
			case 6: $this->image_type = 'bmp'; break;//6: IMAGETYPE_BMP
			case 7: $this->image_type = 'tiffi'; break;//7: IMAGETYPE_TIFF_II (порядок байт intel)
			case 8: $this->image_type = 'tiffm'; break;//8: IMAGETYPE_TIFF_MM (порядок байт motorola)
			case 9: $this->image_type = 'jpc'; break;//9: IMAGETYPE_JPC
			case 10: $this->image_type = 'jp2'; break;//10: IMAGETYPE_JP2
			case 11: $this->image_type = 'jpx'; break;//11: IMAGETYPE_JPX
			case 12: $this->image_type = 'jb2'; break;//12: IMAGETYPE_JB2
			case 13: $this->image_type = 'swc'; break;//13: IMAGETYPE_SWC
			case 14: $this->image_type = 'iff'; break;//14: IMAGETYPE_IFF
			case 15: $this->image_type = 'wbmp'; break;//15: IMAGETYPE_WBMP
			case 16: $this->image_type = 'xbm'; break;//16: IMAGETYPE_XBM
			case 17: $this->image_type = 'ico'; break;//17: IMAGETYPE_ICO
			default: $this->image_type = ''; break;
		}
		$this->fotoimage();
	}
	
	private function fotoimage() {
		switch($this->image_type) {
			case 'gif': $this->image = imagecreatefromgif($this->image_file); break;
			case 'jpeg': $this->image = imagecreatefromjpeg($this->image_file); break;
			case 'png': $this->image = imagecreatefrompng($this->image_file); break;
		}
	}
	
	public function autoimageresize($new_w, $new_h) {
		$difference_w = 0;
		$difference_h = 0;
		if($this->image_width < $new_w && $this->image_height < $new_h) {
			$this->imageresize($this->image_width, $this->image_height);
		}
		else {
			if($this->image_width > $new_w) {
				$difference_w = $this->image_width - $new_w;
			}
			if($this->image_height > $new_h) {
				$difference_h = $this->image_height - $new_h;
			}
				if($difference_w > $difference_h) {
					$this->imageresizewidth($new_w);
				}
				elseif($difference_w < $difference_h) {
					$this->imageresizeheight($new_h);
				}
				else {
					$this->imageresize($new_w, $new_h);
				}
		}
	}
	
	public function percentimagereduce($percent) {
		$new_w = $this->image_width * $percent / 100;
		$new_h = $this->image_height * $percent / 100;
		$this->imageresize($new_w, $new_h);
	}
	
	public function imageresizewidth($new_w) {
		$new_h = $this->image_height * ($new_w / $this->image_width);
		$this->imageresize($new_w, $new_h);
	}
	
	public function imageresizeheight($new_h) {
		$new_w = $this->image_width * ($new_h / $this->image_height);
		$this->imageresize($new_w, $new_h);
	}
	
	public function imageresize($new_w, $new_h) {
		$new_image = imagecreatetruecolor($new_w, $new_h);
		imagecopyresampled($new_image, $this->image, 0, 0, 0, 0, $new_w, $new_h, $this->image_width, $this->image_height);
		$this->image_width = $new_w;
		$this->image_height = $new_h;
		$this->image = $new_image;
	}
	
	public function imagesave($image_type='jpeg', $image_file=NULL, $image_compress=100, $image_permiss='') {
		if($image_file==NULL) {
			switch($this->image_type) {
				case 'gif': header("Content-type: image/gif"); break;
				case 'jpeg': header("Content-type: image/jpeg"); break;
				case 'png': header("Content-type: image/png"); break;
			}
		}
		switch($this->image_type) {
			case 'gif': imagegif($this->image, $image_file); break;
			case 'jpeg': imagejpeg($this->image, $image_file, $image_compress); break;
			case 'png': imagepng($this->image, $image_file); break;
		}
		if($image_permiss != '') {
			chmod($image_file, $image_permiss);
		}
	}
	
	public function imageout() {
		imagedestroy($this->image);
	}
	
	public function __destruct() {
		
	}
	
}
?>

заюзывать просто

пропорционально изменяем размер изображение и сохраняем на сервере не изменяя расширения файла
полученное изображение не будет превышать по высоте 400 пикселей и по ширине 300
т.е. автоматически впишется в нужные размеры

$new_image = new picture('url или файл');
$new_image->autoimageresize(300, 400);
$new_image->imagesave($new_image->image_type, 'папка на сервере');
$new_image->imageout();

вывод на экран не изменяя расширения файла

$new_image = new picture('url или файл');
$new_image->autoimageresize(300, 400);
$new_image->imagesave($new_image->image_type, NULL);
$new_image->imageout();

сохраняем на сервере и выбираем тип файла на выходе

$new_image = new picture('url или файл');
$new_image->autoimageresize(300, 400);
$new_image->imagesave('png', 'папка на сервере');
$new_image->imageout();

ужимаем файл и выводим на экран

$new_image = new picture('url или файл');
$new_image->autoimageresize(300, 400);
$new_image->imagesave('jpeg', NULL, 75);
$new_image->imageout();

сохраняем на сервере, ужимаем и устанавливаем права доступа

$new_image = new picture('url или файл');
$new_image->autoimageresize(300, 400);
$new_image->imagesave('jpeg', 'папка на сервере', 75, 0777);
$new_image->imageout();

Уменьшаем изображение по ширине

$new_image = new picture('url или файл');
$new_image->imageresizewidth(300);
$new_image->imagesave($new_image->image_type, 'папка на сервере');
$new_image->imageout();

Уменьшаем изображение по высоте

$new_image = new picture('url или файл');
$new_image->imageresizeheight(400);
$new_image->imagesave($new_image->image_type, 'папка на сервере');
$new_image->imageout();

произвольно уменьшаем изображение не сохраняя пропорции

$new_image = new picture('url или файл');
$new_image->imageresize(300,400);
$new_image->imagesave($new_image->image_type, 'папка на сервере');
$new_image->imageout();

уменьшаем изображение в процентном соотношении

$new_image = new picture('url или файл');
$new_image->percentimagereduce(30);
$new_image->imagesave($new_image->image_type, 'папка на сервере');
$new_image->imageout();

протестировано на http://nagon.net/knigi.php

+1

Автор: Гость (не зарегистрирован), дата: 18 ноября, 2012 - 10:30
#permalink

Зачем всю портянку со switch нужно было помещать в конструктор, ведь как мне кажется это отдельная тема для разговора.
Для многих сайтов есть ограничения как для расширения, так для размера картинки. Я не затрагиваю ваш класс для изменения размера...
Даже если мы посмотрим на тот же контакт, то есть ограничение по расширению...
Но, данный Класс отлично послужит фундаментом на начальном этапе.


Автор: гугл (не зарегистрирован), дата: 9 января, 2013 - 10:18
#permalink

Надеюсь, автор уже открыл для себя image_type_to_extension, image_type_to_mime_type и вообще документацию!

Можно спокойно было убрать свитчи в конструкторе и функции imagesave.


Автор: Гость (не зарегистрирован), дата: 26 мая, 2013 - 00:17
#permalink

Вы реализовали почти все потребности, кроме нужных мне.... Хотя их легко добиться, имея ваш скрипт, но всё же... другим в помощь, возможно захотите завершить.

код номер два - создаёт изображение, со значениями не превышающими указанные width height. А как же ситуация,когда изображение должно стать не меньше переданных width+height???

т.е., к примеру, скрипту передано 150,150. А изображение 1500 на 2000. Значит выходящая превьюшка должна быть 150х200
По сути дела, определив предварительно ширину и высоту изображения можно в зависимости от того, что меньше, выполнить 3 и 4 с конца код. Но всё же, раз взялись, доделывайте. Удачи

p.s.: Если в вашем коде это реализованно и я упустил, прошу понять и простить


Отправить комментарий

Приветствуются комментарии:
  • Полезные.
  • Дополняющие прочитанное.
  • Вопросы по прочитанному. Именно по прочитанному, чтобы ответ на него помог другим разобраться в предмете статьи. Другие вопросы могут быть удалены.
    Для остальных вопросов и обсуждений есть форум.
P.S. Лучшее "спасибо" - не комментарий, как все здорово, а рекомендация или ссылка на статью.
Содержание этого поля является приватным и не предназначено к показу.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Разрешены HTML-таги: <strike> <a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> <u> <i> <b> <pre> <img> <abbr> <blockquote> <h1> <h2> <h3> <h4> <h5> <p> <div> <span> <sub> <sup>
  • Строки и параграфы переносятся автоматически.
  • Текстовые смайлы будут заменены на графические.

Подробнее о форматировании

CAPTCHA
Антиспам
6 + 7 =
Введите результат. Например, для 1+3, введите 4.
 
Поиск по сайту
Другие записи этого автора
gordon freeman
Реклама
Содержание

Учебник javascript

Основные элементы языка

Сундучок с инструментами

Интерфейсы

Все об AJAX

Оптимизация

Разное

Дерево всех статей

Популярные таги
Последние комментарии
Последние темы на форуме
Forum