Хочу сделать чтобы были везде одинаковые аватарки. Круг, с диаметром 200. Если просто использовать border-radius, то прямоугольные изображения будут овальными, а мне нужен именно круг из середины. Так же пробовал с помощью такой функции:
<?
/*
$x_o и $y_o - координаты левого верхнего угла выходного изображения на исходном
$w_o и h_o - ширина и высота выходного изображения
*/
function crop($image, $x_o, $y_o, $w_o, $h_o) {
if (($x_o < 0) || ($y_o < 0) || ($w_o < 0) || ($h_o < 0)) {
echo "Некорректные входные параметры";
return false;
}
list($w_i, $h_i, $type) = getimagesize($image); // Получаем размеры и тип изображения (число)
$types = array("", "gif", "jpeg", "png" // Массив с типами изображений
$ext = $types[$type]; // Зная "числовой" тип изображения, узнаём название типа
if ($ext) {
$func = 'imagecreatefrom'.$ext; // Получаем название функции, соответствующую типу, для создания изображения
$img_i = $func($image); // Создаём дескриптор для работы с исходным изображением
} else {
echo 'Некорректное изображение'; // Выводим ошибку, если формат изображения недопустимый
return false;
}
if ($x_o + $w_o > $w_i) $w_o = $w_i - $x_o; // Если ширина выходного изображения больше исходного (с учётом x_o), то уменьшаем её
if ($y_o + $h_o > $h_i) $h_o = $h_i - $y_o; // Если высота выходного изображения больше исходного (с учётом y_o), то уменьшаем её
$img_o = imagecreatetruecolor($w_o, $h_o); // Создаём дескриптор для выходного изображения
imagecopy($img_o, $img_i, 0, 0, $x_o, $y_o, $w_o, $h_o); // Переносим часть изображения из исходного в выходное
$func = 'image'.$ext; // Получаем функция для сохранения результата
return $func($img_o, $image); // Сохраняем изображение в тот же файл, что и исходное, возвращая результат этой операции
?>
Но если задать crop(картинка, 0, 0, 200, 200), то он вырезает круг не из середины, а слева.
Как все же сделать? Любой способ попробую.
Не овальный border-radius используй. Php грузить нет смысла.
border-radius поставь 50% от ширины/длинны и будет круг.
При условии что ты сделаешь сразу max-width:200px; max-height:200px;
Ага, в таком случае мне сожмет картинку, а не обрежет ее.
Вот скрин:
STEM™, тебе так надо? или надо именно обрезать просто?
Ну $x_o, $y_o это вероятно отступы по осям х и y, у тебя они по нулям, по этому и обрезает слева.
Сделай нужные отступы вручную если входящее изображение имеет статические (не изменяющиеся) размеры. Или же немного математики чтобы разместить по центру в любом случае.
А можешь подробнее как сделать по центру при любом размере? В процентах задать мб?
Да, но только чтобы не сжималась картинка и не растягивалась.
STEM™, так ?