У меня странная ситуация.
похоже, фон не всегда прозрачен, но в какой-то степени сломан …
вот код:
$angle = !empty($_GET['a']) ? (int)$_GET['a'] : 0;
$im = imagecreatefromgif(__DIR__ . '/track/direction1.gif');
imagealphablending($im, false);
imagesavealpha($im, true);
$transparency = imagecolorallocatealpha($im, 0, 0, 0, 127);
$rotated = imagerotate($im, $angle, $transparency);
imagealphablending($rotated, false);
imagesavealpha($rotated, true);
imagepng($rotated);
imagedestroy($rotated);
imagedestroy($im);
header('Content-Type: image/png');
просто не могу понять, что происходит … я что-то пропустил?
EDIT1
добавил, что func:
if(!function_exists('imagepalettetotruecolor'))
{
function imagepalettetotruecolor(&$src)
{
if(imageistruecolor($src))
{
return true;
}
$dst = imagecreatetruecolor(imagesx($src), imagesy($src));
$black = imagecolorallocate($dst, 0, 0, 0);
imagecolortransparent($dst, $black);
$black = imagecolorallocate($src, 0, 0, 0);
imagecolortransparent($src, $black);
imagecopy($dst, $src, 0, 0, 0, 0, imagesx($src), imagesy($src));
imagedestroy($src);
$src = $dst;
return true;
}
}
но вот застрял с этим квадратом не хочу быть прозрачным ….
imagerotate
плохо реализован; Я часто замечаю ошибки округления / обрезки. Если нужно, вы можете использовать 24bit прозрачное изображение PNG вместо прозрачного GIF (PNG поддерживает альфа-прозрачность, что означает, что края будут хорошо смешиваться с цветом фона HTML).
У функции есть проблемы с прозрачностью, и обходной путь должен добавить две дополнительные строки:
<?php
$angle = (int) $_GET['a'];
$source = imagecreatefrompng(__DIR__ . DIRECTORY_SEPARATOR . 'direction1.png');
$rotation = imagerotate($source, $angle, imageColorAllocateAlpha($source, 0, 0, 0, 127));
imagealphablending($rotation, false); // handle issue when rotating certain angles
imagesavealpha($rotation, true); // handle issue when rotating certain angles
header('Content-type: image/png');
imagepng($rotation);
imagedestroy($source);
imagedestroy($rotation);
Результат:
В качестве альтернативы могу ли я предложить CSS трансформация?
img:nth-child(2) {
transform: rotate(45deg);
}
img:nth-child(3) {
transform: rotate(90deg);
}
img:nth-child(4) {
transform: rotate(135deg);
}
<img src="http://i.stack.imgur.com/oZlZ9.png">
<img src="http://i.stack.imgur.com/oZlZ9.png">
<img src="http://i.stack.imgur.com/oZlZ9.png">
<img src="http://i.stack.imgur.com/oZlZ9.png">
imagecreatefromgif()
создает изображение с палитрой, а не изображение истинного цвета (потому что так кодирует изображение формат GIF). На изображениях с палитрой прозрачность работает иначе, чем на изображениях с истинным цветом и значением, для которого вы рассчитали $transparency
не помогает
Решение состоит в том, чтобы преобразовать $im
до истинного цвета, прежде чем вращать его. Функция imagepalettetotruecolor()
Является ли это. Он доступен начиная с PHP 5.5. Если вы застряли с более старой версией, вам нужно реализовать ее самостоятельно. Проверьте последний пример на документация страница, она уже реализована там и заботится о прозрачности (в ней есть пара незначительных ошибок, с которыми вы столкнетесь при запуске).