AMP

Öğeleri canlandırma

Bir sayfadaki öğelere animasyon girişleri uygulayarak bir Web Hikayesini daha da geliştirebilirsiniz. Örneğin, başlığınızın soldan içeri girmesini sayfaya düşmesini ya da belirmesini vb. sağlayabilirsiniz. AMP hikaye çerçevesi, bir Web Hikayesinde kullanılmak üzere aşağıdaki önceden ayarlanmış animasyonları sağlar:

Animasyon ön ayarı Varsayılan süre (msn) Varsayılan gecikme (msn)
drop 1600 0
fade-in 500 0
fly-in-bottom 500 0
fly-in-left 500 0
fly-in-right 500 0
fly-in-top 500 0
pulse 500 0
rotate-in-left 700 0
rotate-in-right 700 0
twirl-in 1000 0
whoosh-in-left 500 0
whoosh-in-right 500 0
pan-left 1000 0
pan-right 1000 0
pan-down 1000 0
pan-up 1000 0
zoom-in 1000 0
zoom-out 1000 0

Bir öğeye animasyon girişi uygulamak için animasyon ön ayar değerlerinden biriyle animate-in="<animation preset>" özniteliğini ayarlamalısınız. Örneğin, sayfaya bir metnin düşmesini sağlamak için metin öğesine animate-in="drop" özniteliğini ekleyin:

<amp-story-page id="page3">
  ...
  <amp-story-grid-layer template="vertical">
    <p animate-in="drop">Drop this text into the page</p>
</amp-story-page>

Hikaye sayfalarınızdaki öğelere animate-in="<animation preset>" özniteliğini ekleyerek farklı animasyon efektlerini keşfedin.

Animasyon zamanlaması

Her animasyon ön ayarının aşağıdakiler için kurulu bir varsayılan zaman değeri vardır:

  • gecikme: Animasyonun başlamasını geciktirmek için geçen süredir. Örneğin, 0,3 saniye gecikme, animasyonun sayfaya 0,3 saniye sonra gireceği anlamına gelir. 0 saniyelik bir gecikme animasyonu hemen başlatır.
  • süre : Animasyonun gerçekleştiği süredir. Örneğin, baştan sona belirme animasyonu 500 ms sürer.

animate-in-delay ve animate-in-duration öznitelikleri aracılığıyla gecikmeyi veya süreyi değiştirerek bir animasyonun zamanlamasını özelleştirebilirsiniz. Aşağıdaki örnekte, my-element, sayfanın solundan 0,3 saniye sonra uçararak girer ve 0,5 saniye boyunca uçuşu tamamen gerçekleştirir:

<amp-story-page id="my-page">
  ...
  <p
    class="my-element"
    animate-in="fly-in-left"
    animate-in-delay="0.3s"
    animate-in-duration="0.5s"
  >
    I'm going to fly into the page from the left!
  </p>
</amp-story-page>

Son sayfamızı canlandırma

Son Web Hikayesi sayfamız iki katmandan oluşur: ilk katman, hayvan resimlerinden oluşan bir kolaj ve ikinci katman bazı başlık metinlerini görüntüler. Bu sayfayı oluşturmak için, aşağıdaki kodu önceki hikaye sayfanızın hemen sonrasına ekleyin:

<amp-story-page id="page5">
  <amp-story-grid-layer template="vertical" class="noedge">
    <div class="wrapper">
      <amp-img
        src="assets/cat.jpg"
        width="720"
        height="1280"
        layout="responsive"
      >
      </amp-img>
      <amp-img
        src="assets/dog.jpg"
        width="720"
        height="1280"
        layout="responsive"
      >
      </amp-img>
      <amp-img
        src="assets/bird.jpg"
        width="720"
        height="1280"
        layout="responsive"
      >
      </amp-img>
      <amp-img
        src="assets/rabbit.jpg"
        width="720"
        height="1280"
        layout="responsive"
      >
      </amp-img>
    </div>
  </amp-story-grid-layer>
  <amp-story-grid-layer template="vertical" class="center-text">
    <p class="banner-text">Pets can lower your stress levels!</p>
  </amp-story-grid-layer>
</amp-story-page>

Tarayıcınızda AMP hikayesini yeniden yükleyin ve sayfanın doğru şekilde oluşturulduğunu ve şuna benzediğini doğrulayın:

Harika görünüyor ama her şey statik! Haydi canlandıralım!

Banner metninin girişini canlandırarak başlayacağız ve sayfanın sağından "çığlık atacağız". animate-in="whoosh-in-right" öğesini <p> öğesine şu şekilde ekleyin:

<p class="banner-text" animate-in="whoosh-in-right">
  Pets can lower your stress levels!
</p>

Hikaye sayfanızı tarayıcınıza yeniden yükleyin ve başlığın hızla içeri girebildiğini doğrulayın.

Şimdi tüm resimlerin belirmesini sağlayalım. Her bir amp-img öğesine animate-in="fade-in" özniteliği ekleyin ve kodun şöyle görünmesini sağlayın:

<amp-img
  src="assets/cat.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
>
</amp-img>
<amp-img
  src="assets/dog.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
>
</amp-img>
<amp-img
  src="assets/bird.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
>
</amp-img>
<amp-img
  src="assets/rabbit.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
>
</amp-img>

Sayfayı yeniler ve yeniden yüklerseniz, görsellerin her biri belirerek gelir. Bu harika, ancak etkiyi zar zor fark edebilirsiniz çünkü tüm görüntüler aynı anda belirir! Bu animasyonların zamanlamasını değiştirerek görsel efekti iyileştirebiliriz.

İlk resmin girişini geciktirelim, böylelikle metin başlığı girişini tamamladığında yaklaşsın, 0,4 saniye diyelim. Kalan üç görüntü, önceki görüntünün girişinden 0,2 saniye sonra gelebilir. amp-img öğelerinin her biri için, uygun süre gecikmesi değeriyle animate-in-delay="" özniteliğini ekleyin. Kodunuz şöyle görünmelidir:

<amp-img
  src="assets/cat.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
  animate-in-delay="0.4s"
>
</amp-img>
<amp-img
  src="assets/dog.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
  animate-in-delay="0.6s"
>
</amp-img>
<amp-img
  src="assets/bird.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
  animate-in-delay=".8s"
>
</amp-img>
<amp-img
  src="assets/rabbit.jpg"
  width="720"
  height="1280"
  layout="responsive"
  animate-in="fade-in"
  animate-in-delay="1s"
>
</amp-img>

Hikayenizi yenileyin ve yeniden yükleyin. Son sayfanız şöyle görünmelidir:

Web Hikayelerinde animasyonlarla ilgili birçok olasılık vardır (örneğin, animasyonları birleştirmek, animasyonları zincirlemek gibi) ve bu öğretici sadece yüzeyde gezinmektedir. Animasyonlar hakkında daha fazla bilgi edinmek için amp-story referans belgelerine bakın.