Jak jednoduše tvořit vlastní animované GIFy - 3. díl

20. 2. 2013

Sdílet

Autor: Adobe/techhive.com
Ve třetím díle si vyzkoušíme tvorbu nového animovaného GIFu v programu Photoshop Elements 11.

1. díl - Úvod, historie GIFů

2. díl - Pokračování historie, limity GIFů

 

Vytváříme GIF

Tvorbu animovaných GIFů vám umožní spousta aplikací, my vám však ukážeme jen základy v programu Photoshop Elements, spotřebitelském editoru obrázků od Adobe, který vám umožní exportovat váš soubor jako animovaný GIF. Každý rámeček animace jednoduše umístíte jako zvláštní vrstvu a při exportu budou tyto vrstvy zkompilovány do animace. (Stejný postup, byť s mírně pozměněnými jednotlivými kroky, platí i pro bezplatnou alternativu Photoshopu – Gimp.

Následující kroky vás provedou tvorbou rotující „květinové“ grafiky.

1. krok: Otevřete Photoshop Elements a na startovací obrazovce vyberte Foto editor. Dále vyberte Soubor > Nový prázdný soubor. Pojmenujte nový dokument třeba Animace a potom definujte jeho velikost. GIFy jsou nejlepší celkem malé, takže vyberte rozměry kupříkladu 640 x 360. Nyní nastavte Obsah pozadí (Background Contents) na Transparentní a klikněte na OK. Jakmile se váš dokument otevře, klikněte na volbu Expert nahoře, potom na tlačítko Vrstvy (vpravo dole), abyste v průběhu tvorby mohli sledovat vrstvy dokumentu.

2. krok: Vyberte Vrstva > Nově vyplnit vrstvu > Plná barva. Pojmenujte tuto vrstvu třeba „Zelené pozadí“ a klikněte na OK. Nyní si vyberte jakou barvu chcete, v našem případě jsme použili odstín zelené (H: 110; S: 40; B: 70).

Photoshop Elements 113. krok: Vyberte si nástroj Vlastní tvar a ve spodní části okna se vám poté zobrazí možnosti. Nyní klikněte na první tvar hned napravo nahoře. Poté zvolte aktuálně vybraný tvar a zobrazí se vám další alternativy ve vyskakovacím panelu. Z horního menu tohoto panelu vyberte Příroda nebo Květiny a zvolte květinu zvanou Flower24. Nyní podržte klávesu Shift a poté přesuňte kurzor napříč vaším plátnem úhlopříčně z pravé horní části. Tím, že stisknete Shift, zajistíte, že poměr výšky a šířky zvoleného tvaru zůstane stejný. Natáhněte objekt tak, aby byl téměř tak velký jak celý obrázek, a potom si z vyskakovacího menu výběru barev zvolte novou barvu tohoto objektu. V našem případě jsme si vybrali pastelově zeleno-žlutou. Nakonec musíte objekt vycentrovat. Vyberte nástroj Přesunout (V). Poté už jen v menu Vybrat > Vybrat vše, a z ukotvovacích možností dole na stránce si zvolte vertikální i horizontální vycentrování objektu.

4. krok: Zvolte si nástroj Text. Poté se vám v dolní části obrazovky opět objeví možnosti. Vyberte si nějaké bezpatkové lehké písmo, my jsme si vybrali Helvetica Neue Ultralight o velikosti 30 bodů, bílé a se zarovnáním na střed. Klikněte doprostřed obrázku a napište SPRING (jaro). Poté vložení textu potvrďte. V dolní části obrazovky se vám teď opět zobrazují možnosti ukotvení. Takže stejný postup jako v předchozím kroku: Vybrat > Vše a pak zvolte horizontální i vertikální vycentrování. Nakonec tuto vrstvu uzamkněte, abyste ji při další práci náhodou neposunuli nebo jinak nezměnili. V menu Vrstvy vyberte vrstvu textu, klikněte na ni (pokud ji už nemáte vybranou) a poté klikněte na ikonu zámku umístěnou nahoře.

Photoshop Elements 11

5. krok: Vaše další dva rámečky budou založeny na prvním souboru vrstev. V menu Vrstvy stiskněte Shift a poté myší klikněte na všechny tři dosavadní vrstvy. Jakmile máte všechny vrstvy vybrány, zvolíte Vrstvy > Duplikovat vrstvy. Otevře se vám nové okno, které nemusíte nijak řešit – potvrďte jej kliknutím na OK. Stejný proces zopakujte ještě jednou. Nyní byste měli mít tři kopie vašeho textu, květinového vzoru a barvy pozadí.

6. krok: Vyberte nástroj Přesunout (Move) a klikněte na květinu. Nyní byste měli mít tento tvar ohraničený čtvercem a pod ním uprostřed by se měl nacházet maličký kruh. Klikněte na něj. Ve spodní části obrazovky se objeví několik možností transformace. Pod možností Úhel napište 20 pro otočení tvaru o 20 stupňů. Klikněte na zelené potvrzovací tlačítko u tvaru pro přijetí změny.

7. krok: V menu Vrstvy klikněte na ikonu oka pro tři nejvyšší vrstvy, čímž je zneviditelníte. Proces otáčení z kroku šest pak zopakujte pro květinu v prostřední vrstvě, tentokrát ji však otočte pouze o 10 stupňů. Jakmile rotaci dokončíte, opět aktivujte tři deaktivované vrstvy.

Photoshop Elements 11

8. krok: Nyní musíte sloučit každou z květin s jejím zeleným pozadím, čímž vytvoříte tři různé snímky výsledného GIFu. (V tomto bodu vám doporučujeme vaše dílo uložit, pokud by se v dalších krocích něco pokazilo.) Pomocí Shiftu a kliknutí vyberte tři nejvyšší vrstvy a vyberte Vrstva > Sloučit vrstvu. To samé opakujte pro zbývající dvě sady vrstev.

9. krok: Je čas zapnout váš GIF! Vyberte Soubor > Uložit pro web. Zcela napravo okénka pro uložení teď vidíte několik možností. Vyberte z nich GIF 32 No Dither (tj. bez ditheringu) a zaškrtněte políčko u možnosti Animovat. Téměř vpravo dole uvidíte možnosti animace. Smyčka by měla být nastavena na nekonečnou, prodleva mezi políčky pak na 0,2 sekundy. Klikněte na Uložit.

10. krok: Váš GIF si nyní otevřete v okně webového prohlížeče, kde jej můžete obdivovat v akci.

Jakmile se s tímto procesem dobře seznámíte, můžete pro plynulejší animaci vytvářet GIFy s více rámečky. Zapamatujte si, že když zvýšíte počet rámečků, můžete snížit prodlevu mezi nimi, čímž zvýšíte snímkovou frekvenci.

prace_s_linuxem_tip

 

Ve čtvrté a poslední části se podíváme na alternativní postup tvorby GIFu.

'; document.getElementById('preroll-iframe').onload = function () { setupIframe(); } prerollContainer = document.getElementsByClassName('preroll-container-iframe')[0]; } function setupIframe() { prerollDocument = document.getElementById('preroll-iframe').contentWindow.document; let el = prerollDocument.createElement('style'); prerollDocument.head.appendChild(el); el.innerText = "#adContainer>div:nth-of-type(1),#adContainer>div:nth-of-type(1) > iframe { width: 99% !important;height: 99% !important;max-width: 100%;}#videoContent,body{ width:100vw;height:100vh}body{ font-family:'Helvetica Neue',Arial,sans-serif}#videoContent{ overflow:hidden;background:#000}#adMuteBtn{ width:35px;height:35px;border:0;background:0 0;display:none;position:absolute;fill:rgba(230,230,230,1);bottom:20px;right:25px}"; videoContent = prerollDocument.getElementById('contentElement'); videoContent.style.display = 'none'; videoContent.volume = 1; videoContent.muted = false; const playPromise = videoContent.play(); if (playPromise !== undefined) { playPromise.then(function () { console.log('PREROLL sound allowed'); // setUpIMA(true); videoContent.volume = 1; videoContent.muted = false; setUpIMA(); }).catch(function () { console.log('PREROLL sound forbidden'); videoContent.volume = 0; videoContent.muted = true; setUpIMA(); }); } } function setupDimensions() { prerollWidth = Math.min(iinfoPrerollPosition.offsetWidth, 480); prerollHeight = Math.min(iinfoPrerollPosition.offsetHeight, 320); } function setUpIMA() { google.ima.settings.setDisableCustomPlaybackForIOS10Plus(true); google.ima.settings.setLocale('cs'); google.ima.settings.setNumRedirects(10); // Create the ad display container. createAdDisplayContainer(); // Create ads loader. adsLoader = new google.ima.AdsLoader(adDisplayContainer); // Listen and respond to ads loaded and error events. adsLoader.addEventListener( google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, onAdsManagerLoaded, false); adsLoader.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, onAdError, false); // An event listener to tell the SDK that our content video // is completed so the SDK can play any post-roll ads. const contentEndedListener = function () { adsLoader.contentComplete(); }; videoContent.onended = contentEndedListener; // Request video ads. const adsRequest = new google.ima.AdsRequest(); adsRequest.adTagUrl = iinfoVastUrls[iinfoVastUrlIndex]; console.log('Preroll advert: ' + iinfoVastUrls[iinfoVastUrlIndex]); videoContent.muted = false; videoContent.volume = 1; // Specify the linear and nonlinear slot sizes. This helps the SDK to // select the correct creative if multiple are returned. // adsRequest.linearAdSlotWidth = prerollWidth; // adsRequest.linearAdSlotHeight = prerollHeight; adsRequest.nonLinearAdSlotWidth = 0; adsRequest.nonLinearAdSlotHeight = 0; adsLoader.requestAds(adsRequest); } function createAdDisplayContainer() { // We assume the adContainer is the DOM id of the element that will house // the ads. prerollDocument.getElementById('videoContent').style.display = 'none'; adDisplayContainer = new google.ima.AdDisplayContainer( prerollDocument.getElementById('adContainer'), videoContent); } function unmutePrerollAdvert() { adVolume = !adVolume; if (adVolume) { adsManager.setVolume(0.3); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } else { adsManager.setVolume(0); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } } function onAdsManagerLoaded(adsManagerLoadedEvent) { // Get the ads manager. const adsRenderingSettings = new google.ima.AdsRenderingSettings(); adsRenderingSettings.restoreCustomPlaybackStateOnAdBreakComplete = true; adsRenderingSettings.loadVideoTimeout = 12000; // videoContent should be set to the content video element. adsManager = adsManagerLoadedEvent.getAdsManager(videoContent, adsRenderingSettings); // Add listeners to the required events. adsManager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, onAdError); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED, onContentPauseRequested); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED, onContentResumeRequested); adsManager.addEventListener( google.ima.AdEvent.Type.ALL_ADS_COMPLETED, onAdEvent); // Listen to any additional events, if necessary. adsManager.addEventListener(google.ima.AdEvent.Type.LOADED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.STARTED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.COMPLETE, onAdEvent); playAds(); } function playAds() { // Initialize the container. Must be done through a user action on mobile // devices. videoContent.load(); adDisplayContainer.initialize(); // setupDimensions(); try { // Initialize the ads manager. Ad rules playlist will start at this time. adsManager.init(1920, 1080, google.ima.ViewMode.NORMAL); // Call play to start showing the ad. Single video and overlay ads will // start at this time; the call will be ignored for ad rules. adsManager.start(); // window.addEventListener('resize', function (event) { // if (adsManager) { // setupDimensions(); // adsManager.resize(prerollWidth, prerollHeight, google.ima.ViewMode.NORMAL); // } // }); } catch (adError) { // An error may be thrown if there was a problem with the VAST response. // videoContent.play(); } } function onAdEvent(adEvent) { const ad = adEvent.getAd(); console.log('Preroll event: ' + adEvent.type); switch (adEvent.type) { case google.ima.AdEvent.Type.LOADED: if (!ad.isLinear()) { videoContent.play(); } prerollDocument.getElementById('adContainer').style.width = '100%'; prerollDocument.getElementById('adContainer').style.maxWidth = '640px'; prerollDocument.getElementById('adContainer').style.height = '360px'; break; case google.ima.AdEvent.Type.STARTED: window.addEventListener('scroll', onActiveView); if (ad.isLinear()) { intervalTimer = setInterval( function () { // Example: const remainingTime = adsManager.getRemainingTime(); // adsManager.pause(); }, 300); // every 300ms } prerollDocument.getElementById('adMuteBtn').style.display = 'block'; break; case google.ima.AdEvent.Type.ALL_ADS_COMPLETED: if (ad.isLinear()) { clearInterval(intervalTimer); } if (prerollLastError === 303) { playYtVideo(); } break; case google.ima.AdEvent.Type.COMPLETE: if (ad.isLinear()) { clearInterval(intervalTimer); } playYtVideo(); break; } } function onAdError(adErrorEvent) { console.log(adErrorEvent.getError()); prerollLastError = adErrorEvent.getError().getErrorCode(); if (!loadNext()) { playYtVideo(); } } function loadNext() { iinfoVastUrlIndex++; if (iinfoVastUrlIndex < iinfoVastUrls.length) { iinfoPrerollPosition.remove(); playPrerollAd(); } else { return false; } adVolume = 1; return true; } function onContentPauseRequested() { videoContent.pause(); } function onContentResumeRequested() { videoContent.play(); } function onActiveView() { if (prerollContainer) { const containerOffset = prerollContainer.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight/1 && containerOffset.bottom > 0.0) { if (prerollPaused) { adsManager.resume(); prerollPaused = false; } return true; } else { if (!prerollPaused) { adsManager.pause(); prerollPaused = true; } } } return false; } function playYtVideo() { iinfoPrerollPosition.remove(); youtubeIframe.style.display = 'block'; youtubeIframe.src += '&autoplay=1&mute=1'; } }