Menü
Bedava
kayıt
ev  /  Multimedya/ Saf css'de duyarlı bir kaydırıcı. Yaratıcı efektli duyarlı CSS kaydırıcı

Saf css'de duyarlı bir kaydırıcı. Yaratıcı efektli duyarlı CSS kaydırıcı

Size JS kullanmadan, CSS animasyonu kullanarak kaydırıcı oluşturmanın basit bir yolunu anlatmak istiyorum.

1) İlk olarak HTML yazalım, kaydırıcıda 4 resmin birbirinin yerini alacağını varsayalım.


2) Ardından, bloğun boyutunu ayarlayacağız ve birkaç ayar daha ayarlayacağız, konum: göreceli bir biçimlendirme bağlamı oluşturmak için gereklidir, o zaman neden açık olacaktır.

Kaydırıcı (genişlik: 500 piksel; yükseklik: 300 piksel; kenar boşluğu: otomatik; kenar boşluğu: 25 piksel; kenarlık: 1 piksel düz siyah; konum: göreli; taşma: gizli;)
3) Ayrıca slaytların bazı özelliklerini de tanımlayalım:

Slayt (genişlik: 500 piksel; yükseklik: 300 piksel; konum: mutlak; üst: 0; sol: 0;)
CSS'den de görebileceğiniz gibi, tüm slaytları kaydırıcının sol üst köşesine yerleştiriyoruz, böylece aynı başlangıç ​​​​pozisyonunu veriyoruz.

1. Slayt, kullanıcıya gösterilen orijinal konumunda

2. Slayt, tamamen kaydırıcının sınırlarının ötesine geçene kadar sola doğru hareket eder (yukarıda belirtildiği gibi kaydırıcıda taşma vardır: gizli, böylece slayt çevreleyen nesnelerin üzerinden geçmez).

5. Kaydırıcı ile slayt bir seviye aşağı iner

6. Slayt orijinal konumuna hareket eder.
Yani (şimdilik çerçeveleri yukarıdaki listedeki sayılara göre isimlendireceğim):

@keyframes slayt ('den (üst: 0; sol: 0;) 1 (dönüştür: çevir (0px, 0px);) 2 (dönüştür: çevir (-500px, 0);) 3 (dönüştür: çevir (-500px, 300px) );) 4 (dönüştür: çevir (500 piksel, 300 piksel);) 5 (dönüştür: çevir (500 piksel, 0);) - (dönüştür: (0 piksel, 0 piksel);))
5) Böylece slaydın yolunun nasıl göründüğü netleşti. Her slayt, kabının - kaydırıcının - etrafında "dolaşır" ve orijinaline döner. Bu şekilde, herhangi bir sayıda slaydı sonsuza kadar döndürebiliriz. Ancak bu şemada en önemli olan bir nüans var - zaman. Herkesin aynı anda canlandırmak için acele etmemesi için animasyon film şeridini doğru zamanlamanız ve her slayt için doğru gecikmeyi ayarlamanız gerekir. Gecikmenin nasıl doğru ayarlanacağını ve animasyon süresinin nasıl hesaplanacağını anlamak için aşağıda anlatılan yolu takip ettim.

Önceki paragraftan adım atamalarını alalım ve her adımda ne olduğunu anlayalım. Temel olarak 1, 2 ve 6 numaralı adımlar, slaydın görünür alana girdiği adımlardır. Slaytların ayrılmaz bir şekilde hareket etmesi ve sanki birbirini sürgüden dışarı itmesi gerçeğinden, 2. ve 6. adımların süresinin eşit olması gerektiği sonucuna varabiliriz. Bu tasarımla ancak ilk adımın süresinin de 2. ve 6. adımın süresine eşit olması şartıyla başarılı bir şekilde çalışabildiğime dair hemen bir rezervasyon yapacağım. 3,4 ve 5 numaralı adımlarda olanlar, esasen teknik bir ihtiyaçtır ve basitlik adına, bu üç adımı 1'de birleştirelim.

Sadeleştirmeden sonra elimizde:

1. Adım - kaydırıcı orijinalde gösterilir
2. Adım - kaydırıcı sağa hareket eder
3. Adım - kaydırıcı teknik hareketler yapar
4. Adım - kaydırıcı sola hareket ederek orijinal konumuna döner

Sorunsuz bir slayt gösterisi sağlamak için slayt 2. adıma geçtiği anda, sonraki slayt 4. adıma geçmelidir.

Tüm animasyonun daire başına süresi t ise;
Slayt sayısı - n;
3 adımın süresi - y;
Adım 1, 2 ve 4 - x'in süresi;
n-slayt için animasyon gecikme adımı z'dir;
O:

Y = (100 * n - 150) / n;
x = (100 - y) / 3;
x ve y yüzdelere dönüştürülmeli ve ardından:
z = 2 * x * t;

Yukarıdaki örnekte olduğu gibi n = 4 olduğu durumda şunu elde ederiz:

3. adım - %62.5, 1., 2. ve 4. - her biri %12.5. Sonraki her slayt için animasyon gecikme adımı %25'tir.

Üçüncü adımda aşamalar arasında hangi aralıkların olacağı önemli değildir.

6) Artık her şeyi hesapladığımıza ve tüm değerleri bildiğimize göre, son kodu verebiliriz.

Animasyon:

@keyframes slayt ((üstte: 0; sol: 0;) %12,5 ​​(dönüştür: çevir (0px, 0px);) %25 (dönüştür: çevir (-500 piksel, 0);) %36 (dönüştür: çevir (- 500px, 300px);) %37 (dönüştür: çevir (500px, 300px);) %87,5 (dönüştür: çevir (500px, 0);) (dönüştür: (0px, 0px);))
Slaytlar:

Slide1 (arka plan: url (1.jpg); animasyon gecikmesi: 7.5s;) .slide2 (arka plan: url (2.jpg); animasyon gecikmesi: 5s;) .slide3 (arka plan: url (3.jpg); animasyon gecikmesi: 2.5s;) .slide4 (arka plan: url (4.jpg); animasyon gecikmesi: 0s;)
Tüm slaytlar için genel CSS:

Slayt (genişlik: 500 piksel; yükseklik: 300 piksel; konum: mutlak; üst: 0; sol: 0; animasyon adı: slayt; animasyon süresi: 10 sn; animasyon zamanlama işlevi: doğrusal; animasyon yineleme sayısı: sonsuz; )
Aslında hepsi bu! Sonuna kadar okuyan herkese teşekkürler.

3 Mart 2015, 18:15

İlginç ama basit, saf bir CSS3 kaydırıcısı

  • Web sitesi geliştirme,
  • CSS,
  • HTML

Amerika'yı kimseye açmayacağım, yeni bir numara ile seyirciyi şaşırtmayacağım ve CSS3'te dalgıç gibi yüzenlerin aklını başından almayacağım. Javascript'e ihtiyaç duymadan basit CSS3 işlevlerini kullanarak bir kaydırıcı oluşturmanın kolay bir yolu.

1. Temeli düzenleyin

Kaydırıcıyı uygulamak için, kaydırıcı öğelerinden sorumlu olacak oldukça basit bir etiket kümesine ihtiyacımız var.


Burada, genel "sarmalayıcı" bloğunun, içine slaytta yer alacak herhangi bir html kodunu yerleştirebileceğiniz 5 slaytlı bir "kaydırıcı" bloğu içerdiğini görüyoruz. Genel bloğun önünde, "kontroller" bloğundaki etiketlerin bize yardımcı olacağı kendi slayt gezinme çubuklarını oluşturmak için daha sonra gizlenecek olan radyo düğmeleri vardır.

2. Kaydırıcıyı tasarlayın

Burada duracağız ve css'ye biraz bakacağız. Tüm modern tarayıcıların bunları anlayabilmesi için bazı özelliklerin önüne tarayıcılar arası önekler eklendiğini unutmayın.

* (kenar boşluğu: 0; dolgu: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box ;) gövde (arka plan resmi: url (http://habrastorage.org/files/996/d76/d04/996d76d0410d422fa54cc433ce7ead2a.png);)
Arka plan tasarımı ve genel stiller ile her şey açıktır.

Sarıcı (yükseklik: 350 piksel; kenar boşluğu: 100 piksel otomatik 0; konum: göreli; genişlik: 700 piksel;) .slider (arka plan rengi: #ddd; yükseklik: devral; taşma: gizli; konum: göreli; genişlik: devral; -webkit- kutu gölgesi: 0 0 20px rgba (0, 0, 0, .5); -moz-box-shadow: 0 0 20px rgba (0, 0, 0, .5); -o-box-shadow: 0 0 20px rgba (0, 0, 0, .5); kutu gölgesi: 0 0 20px rgba (0, 0, 0, .5);)
Paylaşılan kutu ve kaydırıcı kutu, kaydırıcının sayfadaki konumunun mükemmel kontrolü için aynı boyuttadır. Kaydırak yokken, kaydırıcıyı geçici olarak açık gri renge boyadık.

Wrapper> girişi (ekran: yok;)
Radyo düğmelerini gizleyin. Onlara daha sonra ihtiyacımız olacak.

Sonuç şu ançok:

3. Slaytları tasarlama

Burada slaytlar ve her slayt için ayrı ayrı genel stiller yazacağız:

Slaytlar (yükseklik: devral; konum: mutlak; genişlik: devral;) .slide1 (arka plan resmi: url (http://habrastorage.org/files/3f2/628/bd5/3f2628bd58c8452db516195cb0c9bfc9.jpg);) .slide2 (arka plan -image: url (http://habrastorage.org/files/3e1/95d/c7f/3e195dc7f5a64469807f49a14f97ba0e.jpg);) .slide3 (arka plan resmi: url (http://habrastorage.org/files/663/6b1/) d4f /.jpg);) .slide4 (arka plan resmi: url (http://habrastorage.org/files/e59/424/c04/e59424c046be4dab897d84ab015c87eaground.jpg);) 53c/ff6/c1c/53cff6c1caf842368c70b8ef892d8402.jpg);)
Görünüm efektleriyle oynayabilmemiz için tüm slaytlar için mutlak konumlandırma belirledik. Slaytların boyutları, kaydırıcının boyutundan alınır, böylece bunları birkaç yere yazmanıza gerek kalmaz.

4. Slayt gezintisi yapma

Radyo butonları gizli olduğundan ve onlara anahtar olarak ihtiyacımız olduğundan, hazırlanan etiketleri tasarlıyoruz:

Sarmalayıcı .kontrolleri (sol: %50; kenar-sol: -98 piksel; konum: mutlak;) .wrapper etiketi (imleç: işaretçi; görüntü: satır içi blok; yükseklik: 8 piksel; kenar boşluğu: 25 piksel 12 piksel 0 16 piksel; konum: göreli; genişlik: 8px; -webkit-border-radius: %50; -moz-border-radius: %50; -o-border-radius: %50; border-radius: %50;) .wrapper etiketi: after (border: 2px katı #ddd; içerik: ""; ekran: blok; yükseklik: 12 piksel; sol: -4 piksel; konum: mutlak; üst: -4 piksel; genişlik: 12 piksel; -webkit-border-yarıçapı: %50; -moz-border -yarıçap: %50; -o-sınır-yarıçap: %50; sınır-yarıçap: %50;)
Navigasyonu klasik hale getiriyoruz. Her düğme, içinde slayt etkin olduğunda boş alanın kısmen renklendirileceği daire şeklinde bir alanı temsil eder. Bu arada, aşağıdaki sonucu aldık:

5. Düğmelere basmayı öğrenmek

Belirli bir düğmeyi tıklayarak kaydırıcıya slaytları değiştirmeyi öğretmenin zamanı geldi:

Sarıcı etiket (imleç: işaretçi; görüntü: satır içi blok; yükseklik: 8 piksel; kenar boşluğu: 25 piksel 12 piksel 0 16 piksel; konum: göreli; genişlik: 8 piksel; -webkit-border-yarıçapı: %50; -moz-border-radius: 50 %; -o-border-radius: %50; border-radius: %50; -webkit-transition: arka planda kolay giriş-çıkış .5s; -moz-geçiş: arka planda kolaylık-in-çıkışı .5s; -o- geçiş: arka plan kolaylığı .5s; geçiş: arka plan kolaylığı .5s;) .wrapper etiketi: fareyle üzerine gelin, # slayt1: işaretli ~ .kontroller etiketi: türün ilki (1), # slayt2: kontrol edilen ~ .controls etiketi: nth-of-tür (2), # slide3: kontrol edilen ~ .controls etiketi: nth-of-type (3), # slide4: kontrol edilen ~ .controls etiketi: nth-of-tür (4) , # slide5: işaretli ~ .controls etiketi: nth-of-type (5) (arka plan: #ddd;)
Süslenmiş gezinme düğmelerinde, içlerine yumuşak bir renklendirme ekleyin. Ayrıca, etkin düğmenin ve imlecin üzerine geldiği düğmenin düzgün bir şekilde renklendirileceği koşullar da ekliyoruz. Kendi radyo düğmelerimiz hazır:

6. Kaydırıcıyı canlandırma

Şimdi, slaytların sonunda değişmesi için yapıyoruz:

Slaytlar (yükseklik: devral; opaklık: 0; konum: mutlak; genişlik: devral; z-endeksi: 0; -webkit-dönüşümü: ölçek (1.5); -moz-dönüşümü: ölçek (1.5); -o-dönüşümü: ölçek (1.5); dönüştürme: ölçek (1.5); -webkit-geçişi: dönüştürme kolaylığı .5s, opaklık girme kolaylığı .5s; -moz-geçişi: dönüştürme kolaylığı .5s, opaklık kolaylığı -in-out .5s; -o-geçiş: dönüştürme kolaylığı .5s, opaklık içeri-dışarı kolaylığı .5s; geçiş: dönüştürme kolaylığı .5s, opaklık .5s; ) # slayt1: işaretlendi ~ .slider> .slide1, # slayt2: işaretlendi ~ .slider> .slide2, # slayt3: işaretlendi ~ .slider> .slide3, # slayt4: işaretlendi ~ .slider> .slide4, # slayt5: işaretlendi ~ .slider> .slide5 (opaklık: 1; z-endeksi: 1; -webkit-transform: ölçek (1); -moz-transform: ölçek (1); -o-dönüşüm: ölçek (1); dönüşüm: ölçek ( 1); )
Genel slayt stillerinde, tüm slaytları görünmez yapan ve arka planda kaybolan özellikler ekleriz. Ayrıca kaydırıcıda ilginç bir görünüm vermek için slaytlara görünmezken küçük bir artış ekledik.

Sonuç burada görüntülenebilir.













Merhaba sevgili acemi web yöneticileri.

İşte dünyanın en basit saf CSS kaydırıcısı.

Böyle bir kaydırıcının avantajları, hafiflik ve güvenliğin yanı sıra en acemi web yöneticisinin bile kendi sitesinde yapıp kurabilmesidir.

Dezavantajı ise sadece CSS kullanarak döngüyü tekrar edememenizdir.

Ancak sekiz resmin 30 saniyeden fazla kaydırıldığını düşünürsek, bu süre bir ziyaretçinin sayfayı görüntülemesi için oldukça yeterlidir.

Ve kaydırıcı sitenin başlığına kuruluysa, kimse onu yarım dakika dikkate almaz.

Görüntülerin efektleri beğeninize ve CSS3'ün yeteneklerine göre değiştirilebilir. Bunun nerede ve nasıl yapılabileceğini görelim.





CSS kaydırıcısı














И на всякий случай — чтобы появилась возможность прокрутить слайдер ещё раз можно добавить следующий код:

При этом под слайдером появится кнопка которую можно назвать как Вам угодно и оформить в CSS.

P.S. Если постараться и подогнать интервалы показа картинок в @keyframes, то карусель можно сделать непрерывной.

У меня получилось. Можно посмотреть вот . Текст в баннерах прокручивается свойствами анимации без скрипта.

Правда получилось сделать только с тремя картинками.

P.P.S. Теперь подобные баннеры и на этом сайте под шапкой сайта.

Желаю творческих успехов.

1. Превосходное jQuery слайд-шоу

Большое эффектное слайд-шоу с использованием jQuery технологий.

2. jQuery плагин «Scale Carousel»

Масштабируемое слайд-шоу с использованием jQuery. Вы сможете задать размеры для слайд-шоу, которые вам больше всего подходят.

3. jQuery плагин «slideJS»

Слайдер изображений с текстовым описанием.

4. Плагин «JSliderNews»

5. CSS3 jQuery слайдер

При наведении курсора на стрелки навигации появляется круглая миниатюра следующего слайда.

6. Симпатичный jQuery слайдер «Presentation Cycle»

jQuery слайдер с индикатором загрузки изображений. Предусмотрена автоматическая смена слайдов.

7. jQuery плагин «Parallax Slider»

Слайдер с объемным фоновым эффектом. Изюминка этого слайдера в движение фона, который состоит из нескольких слоев, каждый из которых прокручивается с различной скоростью. В итоге получается имитация объемного эффекта. Выглядит очень красиво, вы можете сами в этом убедиться. Более плавно эффект отображается в таких браузерах как: Opera, Google Chrome, IE.

8. Свежий, легкий jQuery слайдер «bxSlider 3.0»

На демонстрационной странице в разделе «examples» вы сможете найти ссылки на все возможные варианты использования этого плагина.

9. jQuery слайдер изображений, плагин «slideJS»

Стильный jQuery слайдер, безусловно сможет украсить ваш проект.

10. jQuery плагин слайд-шоу «Easy Slides» v1.1

Простой в использовании JQuery плагин для создания слайд-шоу.

11. Плагин «jQuery Slidy»

Легкий jQuery плагин в различном исполнении. Предусмотрена автоматическая смена слайдов.

12. jQuery CSS галерея с автоматической сменой слайдов

Если посетитель в течении определенного времени не нажмет на стрелки «Вперед» или «Назад», то галерея начнет прокручиваться автоматически.

13. jQuery слайдер «Nivo Slider»

Очень профессиональный качественный легкий плагин с валидным кодом. Предусмотрено много различных эффектов смены слайдов.

14. jQuery слайдер «MobilySlider»

Свежий слайдер. jQuery слайдер с различными эффектами смены изображений.

15. jQuery Плагин «Slider²»

Легкий слайдер с автоматической сменой слайдов.

16. Свежий javascript слайдер

Слайдер с автоматической сменой изображений.

Плагин для реализации слайд-шоу с автоматической сменой слайдов. Есть возможность управлять показом с помощью миниатюр изображений.

jQuery CSS слайдер изображений с использованием плагина NivoSlider .

19. jQuery слайдер«jShowOff»

Плагин для ротации содержимого. Три варианта использования: без навигации (с автоматической сменой в формате слайд-шоу), с навигацией в виде кнопок, с навигацией в виде миниатюр изображений.

20. Плагин «Shutter Effect Portfolio»

Свежий jQuery плагин для оформления портфолио фотографа. В галерее реализован интересный эффект смены изображений. Фотографии сменяют друг друга с эффектом похожим на работу затвора объектива.

21. Легкий javascript CSS слайдер «TinySlider 2»

Реализация слайдера изображений с использованием javascript и CSS.

22. Обалденный слайдер «Tinycircleslider»

Стильный круглый слайдер. Переход между изображениями осуществляется с помощью перетаскивания по окружности ползунка в виде красного круга. Отлично впишется в ваш сайт, если вы в дизайне используете круглые элементы.

23. Слайдер изображений на jQuery

Легкий слайдер «Slider Kit». Слайдер представлен в различном исполнении: вертикальный и горизонтальный. Также реализованы различные виды навигации между изображениями: с помощью кнопок «Вперед» и «Назад», с помощью колеса мыши, с помощью клика мыши по слайду.

24. Галерея с миниатюрами «Slider Kit»

Галерея «Slider Kit». Прокрутка миниатюр осуществляется как в вертикальном так и горизонтальном направлении. Переход между изображениями осуществляется с помощью: колеса мыши, щелчка мыши или наведения курсора на миниатюру.

25. jQuery слайдер содержимого «Slider Kit»

Вертикальный и горизонтальный слайдер контента на jQuery.

26. jQuery слайд-шоу «Slider Kit»

Слайд-шоу с автоматической сменой слайдов.

27. Легкий профессиональный javascript CSS3 слайдер

Аккуратный слайдер на jQuery и CSS3, созданный в 2011 году.

jQuery слайд-шоу с миниатюрами.

29. Простое jQuery слайд-шоу

Слайд-шоу с кнопками навигации.

30. Потрясное слайд-шоу jQuery «Skitter»

jQuery плагин «Skitter» для создания потрясающего слайд-шоу. Плагин поддерживает 22 (!) вида различных анимационных эффектов при смене изображений. Может работать с двумя вариантами навигации по слайдам: с помощью номеров слайдов и с помощью миниатюр. Обязательно посмотрите демонстрацию, очень качественная находка. Используемые технологии: CSS, HTML, jQuery, PHP.

31. Слайд-шоу «Awkward»

Функциональное слайд-шоу. В виде слайдов могут выступать: простые изображения, изображения с подписями, изображения с всплывающими подсказками, видео-ролики. Для навигации можно использовать стрелки, ссылки на номера слайдов и клавиши вправо/влево на клавиатуре. Слайд-шоу выполнено в нескольких вариантах: с миниатюрами и без них. Для просмотра всех вариантов пройдитесь по ссылкам Demo #1 - Demo #6 расположенным сверху на демонстрационной странице.

Очень оригинальное оформление слайдера изображений, напоминающее веер. Анимированная смена слайдов. Навигация между изображениями осуществляется с помощью стрелок. Предусмотрена также автоматическая смена, которую можно включать и выключать с помощью кнопки Play/Pause, расположенной сверху.

Анимированный jQuery слайдер. Фоновые изображения автоматически масштабируются при изменении размеров окна браузера. Для каждого изображения выплывает блок с описанием.

34. «Flux Slider» слайдер на jQuery и CSS3

Новый jQuery слайдер. Несколько классных анимированных эффектов при смене слайдов.

35. jQuery плагин «jSwitch»

Анимированная jQuery галерея.

Легкое слайд-шоу на jQuery c автоматической сменой слайдов.

37. Новая версия плагина «SlideDeck 1.2.2»

Профессиональный слайдер контента. Возможны варианты с автоматической сменой слайдо, а также вариант с использованием колеса мыши для перехода между слайдами.

38. jQuery слайдер «Sudo Slider»

Легкий сладер изображений на jQuery. Очень много вариантов реализации: горизонтальная и вертикальная смена изображений, со ссылками на номер слайда и без них, с подписями изображений и без, различные эффекты смены изображений. Есть функция автоматической смены слайдов. Ссылки на все примеры реализации можно найти на демонстрационной странице .

39. jQuery CSS3 слайд-шоу

Слайд-шоу с миниатюрами поддерживает режим автоматической смены слайдов.

40. jQuery cлайдер «Flux Slider»

Слайдер с множеством эффектов смены изображений.

41. Простой jQuery слайдер

Стильный слайдер изображений на jQuery.

Слайдер на CSS имеет ряд преимуществ над слайдерами на jQuery. Мы отказываемся от громоздких плагинов, благодаря чему повышается скорость загрузки сайта, а использование CSS анимации делает смену слайдов более плавной. Именно поэтому я хочу вас научить как сделать слайдер на CSS3.

Для работы с этим уроком вам нужно иметь общее представление о CSS3 переходах и анимации по ключевым кадрам. Используя эту простую концепцию, мы увидим как сделать слайдер изображений. Пожалуйста, обратите внимание, что эти свойства будут работать только в современных браузерах (в частности IE10+).

Слайдер на CSS3

Базовые концепции CSS переходов

Обычно, когда вы измените значение CSS, изменение происходит мгновенно. Теперь, благодаря универсальному CSS3 свойству transition , мы можем легко анимировать от старого к новому состоянию.

Мы можем использовать четыре свойства перехода:

  1. transition-property - определяет CSS свойства, к которым должны быть применены переходы.
  2. transition-duration - определяет длительность переходов.
  3. transition-timing-function - определяет, как рассчитываются промежуточные значения перехода. Эффекты от функции времени задержки обычно называют реверсивными функциями.
  4. transition-delay - определяет когда начинается переход.

Поскольку технология все еще относительно новая, потребуется использовать префиксы для браузеров. Мы будем опускать их в примерах кода в этой статье, но не забудьте включить их в своем коде чтобы ваш слайдер на CSS работал должным образом. Давайте посмотрим, как применить простой переход к ссылке:

A { color: #000; transition-property: color; transition-duration: 0.7s; transition-timing-function: ease-in; transition-delay: 0.3s; } a:hover { color: #fff; }

При назначении анимации к элементу вы также можете использовать сокращенную запись:

A { color: #000; transition: color 0.7s ease-in 0.3s; } a:hover { color: #fff; }

Давайте посмотрим как применять простую анимацию в div .

/* К этим элементам также применяем анимацию */ div { animation-name: move; animation-duration: 1s; animation-timing-function: ease-in-out; animation-delay: 0.5s; animation-iteration-count: 2; animation-direction: alternate; } /* Это код анимации */ @keyframes move { from { transform: translateX(0); } to { transform: translateX(100px); } }

Но мы можем использовать сокращенную запись записав все свойства анимации сразу:

Div { animation: move 1s ease-in-out 0.5s 2 alternate; }

Ключевые кадры для CSS слайдера

Ключевые кадры определяют то, как анимация выглядит на каждом этапе временной шкалы. Ключевые кадры используют процентное значение для определения времени: 0% это начало анимации, а 100% конец. Вы можете также добавить ключевые кадры для промежуточной анимации.

/* Анимация от 0% до 100% */ @keyframes move { 0% { transform: translateX(0); } 100% { transform: translateX(100px); } } /* Анимация с промежуточными ключевыми кадрами */ @keyframes move { 0% { transform: translateX(0); } 50% { transform: translateX(20px); } 100% { transform: translateX(100px); } }

Структура CSS-слайдера

Теперь, когда мы знаем как работают переходы и анимации, давайте посмотрим как создать наш слайдер, используя только CSS3. Этот рисунок показывает как анимация должна работать:

Как функционирует анимация слайдера

Как видите, наш слайдер - это контейнер, внутри которого отображаются изображения. Анимация здесь очень простая: изображение следует по предварительно определенному пути путем анимации свойства top и меняя свойства z-index и opacity когда изображение возвращается в исходное состояние. Давайте погрузимся в HTML-разметку для создания слайдера.

  • Пума

  • ...
  • Солнечные ванны

HTML-разметка очень проста и SEO дружелюбна. Рассмотрим в деталях, как все работает:

  • div id="slider"

    Это главный контейнер слайдера. Он не имеет определенной функции, но мы должны приостановить его анимацию.

  • div id="mask"

    Мы будем использовать маску для CSS слайдера, чтобы скрыть все, что происходит за его пределами.

  • li id="first" class="firstanimation"

    Каждый элемент списка имеет идентификатор и класс. Идентификатор отвечает за подсказку, а класс привязан к анимации, которая должена произойти.

  • div class="tooltip"

    Блок для отображения названия изображения. Вы можете изменить его под свои нужды, например, сделав его интерактивными, и добавив краткое описание.

  • div class="progress-bar"

    Он содержит функцию, которая показывает ход анимации.

Теперь пришло время для CSS стилей.

CSS стили слайдера

Давайте создадим базовую структуру слайдера. Он будет иметь тот же размер, что и изображение. CSS cвойство border будет полезно для создания рамки вокруг изображения.

/* Структура слайдера */ .slider { background: #000; border: 5px solid #eaeaea; box-shadow: 1px 1px 5px rgba(0,0,0,0.7); height: 320px; width: 680px; margin: 40px auto 0; overflow: visible; position: relative; }

Блок mask скроет все элементы, которые лежат за пределами слайдера; его высота должна быть равна высоте слайдера.

/* Спрячем все */ .mask { overflow: hidden; height: 320px; }

Наконец, чтобы отсортировать список изображений, мы зададим position: absolute и top: -325px , так что все изображения будут расположены за пределами слайдера.

/* Список изображений */ .slider ul { margin: 0; padding: 0; position: relative; } .slider li { width: 680px; /* Ширина изображения */ height: 320px; /* Длина изображения */ position: absolute; top: -325px; /* Исходное положение - вне слайдера */ list-style: none; }

С помощью этих нескольких строк кода мы создали наш слайдер без javascript, осталось только добавить анимацию.

Ключевые кадры CSS анимации

Анимация изображения для слайдера

Прежде чем мы начнем работать с анимацией, мы должны указать некоторые параметры для того, чтобы получить правильный вид анимации. Oбщая продолжительность нашей анимации - 25 секунд, но мы должны знать, сколько ключевых кадров равны 1 секунде. Итак, давайте рассмотрим серию операций, которые дадут нам точное число ключевых кадров на основе анимируемых изображений. Вот расчеты:

  1. Общее количество изображений в слайдере - 5
  2. Продолжительность анимации для каждого изображения - 5 секунд
  3. Общая продолжительность анимации - 5 изображений × 5 секунд = 25 секунд
  4. Подсчитаем сколько ключевых кадров равны одной секунде, для этого разделим общее количество ключевых кадров на общую продолжительность анимации: 100 ключ. кадров / 25 сек. = 4 ключ. кадра

Теперь мы можем применить CSS анимацию к слайдеру. Мы сможем поставить анимацию на бесконечный цикл, потому что у каждого изображения своя собственная анимация.

Firstanimation { animation: cycle 25s linear infinite; } .secondanimation { animation: cycletwo 25s linear infinite; } .thirdanimation { animation: cyclethree 25s linear infinite; } .fourthanimation { animation: cyclefour 25s linear infinite; } .fifthanimation { animation: cyclefive 25s linear infinite; }

После того, как свойства анимации назначены, мы должны использовать ключевые кадры для настройки анимации движения. Также я добавил свойства opacity и z-index , чтобы сделать переход от одного изображения к другому более плавным. Первая анимация имеет больше ключевых кадров, чем последняя. Причина этого в том, что когда последнее изображение завершило свою анимацию, первое изображение должно иметь дополнительные ключевые кадры для того, чтобы пользователь не видел перерыва между циклами анимации.

/* Анимация на примере первых двух изображений */ @keyframes cycle { 0% { top: 0px; } /* При запуске слайда первое изображение уже видно */ 4% { top: 0px; } /* Исходное положение */ 16% { top: 0px; opacity:1; z-index:0; } /* От 4% до 16% = изображение видно 3 секунды */ 20% { top: 325px; opacity: 0; z-index: 0; } /* От 16% до 20% = 1 секунда на уход изображения */ 21% { top: -325px; opacity: 0; z-index: -1; } /* Вернуться в исходную позицию */ 92% { top: -325px; opacity: 0; z-index: 0; } 96% { top: -325px; opacity: 0; } /* От 96% до 100% = 1 секунда на появление изображения */ 100%{ top: 0px; opacity: 1; } } @keyframes cycletwo { 0% { top: -325px; opacity: 0; } /* Исходное положение */ 16% { top: -325px; opacity: 0; }/* Начинает двигаться на эту позицию после 16% */ 20% { top: 0px; opacity: 1; } 24% { top: 0px; opacity: 1; } /* От 20% до 24% = 1 секунда на появление изображения */ 36% { top: 0px; opacity: 1; z-index: 0; } / * От 24% до 36% = изображение видно 3 секунды * / 40% { top: 325px; opacity: 0; z-index: 0; } /* От 36% до 40% = 1 секунда на уход изображения */ 41% { top: -325px; opacity: 0; z-index: -1; } /* Вернуться в исходную позицию */ 100%{ top: -325px; opacity: 0; z-index: -1; } }

Создав анимацию, мы должны добавить прогресс бар для отображения продолжительности каждой анимации.

Индикатор прогресса (прогресс-бар)

Процесс создания анимации индикатора такой же, как и у слайдера. Во-первых, мы создаем сам индикатор:

/* Индикатор прогресса слайдера */ .progress-bar { position: relative; top: -5px; width: 680px; height: 5px; background: #000; animation: fullexpand 25s ease-out infinite; }

Не бойтесь синтаксиса, описанного ниже: он также задает состояние "from" и "to".

/* CSS3 анимация индикатора прогресса слайдера */ @keyframes fullexpand { /* В этих ключевых кадрах индикатор находится в неподвижном состоянии */ 0%, 20%, 40%, 60%, 80%, 100% { width: 0%; opacity: 0; } /* В этих ключевых кадрах прогресс-бар начинает оживать */ 4%, 24%, 44%, 64%, 84% { width: 0%; opacity: 0.3; } /* В этих ключевых кадрах индикатор движется вперед в течение 3 секунд */ 16%, 36%, 56%, 76%, 96% { width: 100%; opacity: 0.7; } /* В этих ключевых кадрах прогресс-бар закончил свой путь */ 17%, 37%, 57%, 77%, 97% { width: 100%; opacity: 0.3; } /* В этих ключевых кадрах прогресс-бар исчезнет, а затем цикл возобновится */ 18%, 38%, 58%, 78%, 98% { width: 100%; opacity: 0; } }

CSS3 анимация подсказки слайдера

Слайдер уже почти готов, но давайте добавим несколько деталей, чтобы сделать его более функциональным. Мы добавим подсказки для названий изображений, которые будут видны при наведении.

Вот CSS для всплывающих подсказок:

Tooltip { background: rgba(0,0,0,0.7); width: 300px; height: 60px; position: relative; bottom: 75px; left: -320px; } .tooltip h1 { color: #fff; font-size: 24px; font-weight: 300; line-height: 60px; padding: 0 0 0 10px; }

Здесь мы сделали так, что показываются только заголовки изображений, но вы можете сделать то же самое с пользовательским контентом, ссылками и пр.

Анимация подсказки при наведении

Мы видели, как применить CSS3 переходы элементов; Теперь давайте сделаем это в подсказках.

Tooltip { … transition: all 0.3s ease-in-out; } .slider li:hover .tooltip { left: 0px; }

Пауза и продолжение анимации слайдера

Остановка анимации при наведении курсора мыши

Давайте разрешим пользователям сделать паузу, чтобы прочитать подсказку или рассмотреть изображения. Для этого мы должны остановить анимацию при наведении курсора мыши на изображение (мы также должны остановить анимацию индикатора прогресса).

Slider: hover li, .slider:hover .progress-bar { animation-play-state: paused; }

Заключение и бонусный CSS3 слайдер)

Наконец, мы достигли конца урока. CSS3 слайдер теперь готов на 100%! Взгляните на демонстрационный пример CSS слайдера без Javascript . Он работает в Firefox 5+, Safari 4+, IE10+ и Google Chrome, а также iPhone и IPad..

Эффект впечатляет, но по общему признанию, это слайдер не очень гибкий. Например, чтобы добавить больше изображений, вам придется редактировать все ключевые кадры. CSS3 имеет большой потенциал, но иногда лучше воспользоваться JavaScript, чем заморачиваться с ключевыми кадрами. А теперь, бонусный слайдер на CSS3 , как я и обещал.