質問

ImageMagickを使用してアップロードされたファイルのサイズを変更しますが、それらが処理されている間、サムネイルが正常になるユーザーに回転するGIFホイールを表示したいです。私は約7サイズの親指を務め、途中で32×32サイズに残るホイールがシンプルなビットです。

私が知る必要があるのは、依然としてアニメーションを保持しながら上記をすることができます

例:

このイメージ: この画像

このサイズから始まります このサイズ

アニメーション

役に立ちましたか?

解決

GIFアニメーション画像を透かして透かしに使用するPHP魔女に解決策があります。 それは黒い背景を作成し、それに画像を置き、そして透かしを置く...

watermarkpath = 'path to wathermarkimage.jpg|gif|png';
$imagepath= 'path to the image';     
$watermark = new Imagick($watermarkpath);
 $GIF = new Imagick();
 $GIF->setFormat("gif");

$animation = new Imagick($imagepath);
foreach ($animation as $frame) {

    $iWidth = $frame->getImageWidth();
    $iHeight = $frame->getImageHeight();
    $wWidth = $watermark->getImageWidth();
    $wHeight = $watermark->getImageHeight();

    if ($iHeight < $wHeight || $iWidth < $wWidth) {
        // resize the watermark
        $watermark->scaleImage($iWidth, $iHeight);

        // get new size
        $wWidth = $watermark->getImageWidth();
        $wHeight = $watermark->getImageHeight();
    }

    $bgframe = new Imagick();
    $bgframe->newImage(($iWidth), ($iHeight + 80), new ImagickPixel('Black'));
    $bgframe->setImageDelay($frame->getImageDelay());


    $x = ($iWidth) - $wWidth - 5;
    $y = ($iHeight + 80) - $wHeight - 5;


    $bgframe->compositeImage($frame, imagick::COMPOSITE_DEFAULT, 0, 0);
     $bgframe->flattenImages();
    $bgframe->compositeImage($watermark, imagick::COMPOSITE_OVER, $x, $y);
     $bgframe->flattenImages();
    $GIF->addImage($bgframe);
}



$GIF->writeimages($imagepath,true);
.

他のヒント

このフィドルをチェックして、あなたが望むものを含めるかもしれません: http://jsfiddle.net/tgdfb/1/

jQueryを使いますが、簡単に適応できます...

は、ImageMagickを通してこれを行う自動化された方法を見つけることができなかった後、Photoshopによって手動でこれを行った。私は 'COALESCE'の国旗が見つかりましたが、他にはあまりない。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top