Menu
Jest wolny
rejestracja
Dom  /  Multimedia/ Responsywny suwak w czystym css. Responsywny suwak CSS z kreatywnym efektem

Responsywny suwak w czystym css. Responsywny suwak CSS z kreatywnym efektem

Chcę wam opowiedzieć prosty sposób na stworzenie slidera, bez użycia JS, przy użyciu animacji CSS.

1) Najpierw napiszmy HTML, załóżmy, że 4 obrazy zastąpią się nawzajem w suwaku.


2) Następnie ustalimy rozmiar bloku i kilka innych ustawień, pozycja: względna jest niezbędna do stworzenia kontekstu formatowania, wtedy będzie jasne, dlaczego.

Suwak (szerokość: 500px; wysokość: 300px; margines: auto; górny margines: 25px; obramowanie: 1px jednolita czerń; pozycja: względna; przepełnienie: ukryte;)
3) Zdefiniujmy również niektóre właściwości samych slajdów:

Slajd (szerokość: 500px; wysokość: 300px; pozycja: bezwzględna; góra: 0; lewa: 0;)
Jak widać z CSS, wszystkie slajdy umieszczamy w lewym górnym rogu suwaka, dając tym samym tę samą pozycję początkową.

1. Slajd znajduje się w pierwotnej pozycji, pokazanej użytkownikowi

2. Zjeżdżalnia przesuwa się w lewo, aż całkowicie wyjdzie poza granicę suwaka (suwak, jak wspomniano powyżej, ma przelew: ukryty, dzięki czemu zjeżdżalnia nie przejeżdża po otaczających obiektach).

5. Zjeżdżalnia schodzi o jeden poziom za pomocą suwaka

6. Slajd przesunie się do swojej pierwotnej pozycji.
Innymi słowy (na razie będę nazywał ramki według numerów z powyższej listy):

@keyframes slide (od (góra: 0; lewa: 0;) 1 (transform: translate (0px, 0px);) 2 (transform: translate (-500px, 0);) 3 (transform: translate (-500px, 300px );) 4 (przekształć: przetłumacz (500px, 300px);) 5 (przekształć: przetłumacz (500px, 0);) na (przekształć: (0px, 0px);))
5) Tak więc stało się jasne, jak wygląda ścieżka zjeżdżalni. Każdy slajd „krąży” wokół swojego pojemnika – suwaka – i powraca do pierwotnego. W ten sposób możemy w nieskończoność obracać dowolną liczbę slajdów. Ale jest jeden niuans, który jest w tym schemacie najważniejszy - czas. Musisz prawidłowo zaplanować animację w scenorysie i ustawić prawidłowe opóźnienie dla każdego slajdu, aby nie wszyscy spieszyli się z animacją w tym samym czasie. Aby zrozumieć, jak poprawnie ustawić opóźnienie i obliczyć czas animacji, poszedłem ścieżką opisaną poniżej.

Weźmy oznaczenia kroków z poprzedniego akapitu i zastanówmy się, co dzieje się w każdym kroku. Zasadniczo kroki 1, 2 i 6 to kroki, w których slajd wchodzi w widoczny obszar. Z tego, że slajdy powinny poruszać się nierozłącznie i niejako wypychać się z suwaka, możemy wnioskować, że czas trwania kroków 2 i 6 powinien być równy. Od razu zastrzegam, że udało mi się z powodzeniem pracować z tym projektem tylko pod warunkiem, że czas trwania pierwszego kroku jest równy czasowi trwania drugiego i szóstego. To, co dzieje się podczas kroków 3, 4 i 5, jest zasadniczo potrzebą techniczną i dla uproszczenia połączmy te trzy kroki w 1.

Po uproszczeniu mamy:

1. Krok - na oryginale widoczny jest suwak
2. Krok - suwak przesuwa się w prawo
3. Krok - slider wykonuje ruchy techniczne
4. Krok - suwak przesuwa się w lewo, wracając do pierwotnej pozycji

Aby zapewnić płynny pokaz slajdów, w momencie, gdy slajd przejdzie do kroku 2, następny slajd musi przejść do kroku 4.

Jeśli czas na okrąg całej animacji wynosi t;
Liczba slajdów - n;
Czas trwania 3 kroków - y;
Czas trwania kroków 1, 2 i 4 - x;
Krok opóźnienia animacji dla n-slajdu wynosi z;
To:

Y = (100 * n - 150) / n;
x = (100 - y) / 3;
x i y należy przeliczyć na wartości procentowe, a następnie:
z = 2 * x * t;

Dla przypadku, gdy n = 4, jak w powyższym przykładzie, otrzymujemy:

3 stopień - 62,5%, 1, 2 i 4 - po 12,5%. Krok opóźnienia animacji dla każdego kolejnego slajdu wynosi 25%.

Nie ma znaczenia, jakie będą odstępy między etapami w ramach trzeciego kroku.

6) Teraz, gdy już wszystko obliczyliśmy i znamy wszystkie wartości, możemy podać ostateczny kod.

Animacja:

slajd @keyframes (od (góra: 0; lewy: 0;) 12,5% (przekształć: przetłumacz (0px, 0px);) 25% (przekształć: przetłumacz (-500px, 0);) 36% (przekształć: przetłumacz (- 500px, 300px);) 37% (transform: translate (500px, 300px);) 87,5% (transform: translate (500px, 0);) do (transform: (0px, 0px);))
Slajdy:

Slide1 (tło: url (1.jpg); opóźnienie animacji: 7,5s;) .slide2 (tło: url (2.jpg); opóźnienie animacji: 5s;) .slide3 (tło: url (3.jpg); opóźnienie animacji: 2.5s;) .slide4 (tło: url (4.jpg); opóźnienie animacji: 0s;)
Ogólne CSS dla wszystkich slajdów:

Slajd (szerokość: 500 pikseli; wysokość: 300 pikseli; pozycja: bezwzględna; góra: 0; lewy: 0; nazwa animacji: slid; czas trwania animacji: 10 s; funkcja czasu animacji: liniowa; liczba iteracji animacji: nieskończona; )
Właściwie to wszystko! Dziękuję wszystkim, którzy przeczytali do końca.

3 marca 2015 o 18:15

Ciekawy, ale prosty czysty suwak CSS3

  • Tworzenie stron internetowych,
  • CSS,
  • HTML

Nie otworzę Ameryki dla nikogo, nie zaskoczę publiczności nową sztuczką i nie rozwalę umysłu tych, którzy pływają jak płetwonurek w CSS3. Oto prosty sposób na stworzenie slidera przy użyciu prostych funkcji CSS3 bez potrzeby używania javascriptu.

1. Układ podstawy

Aby zaimplementować slider, potrzebujemy dość prostego zestawu tagów, które z kolei będą odpowiadały za elementy slidera.


Tutaj widzimy, że ogólny blok „opakowania” zawiera blok „suwaka” z 5 slajdami, wewnątrz którego można umieścić dowolny kod html, który będzie się znajdował na slajdzie. Przed blokiem ogólnym znajdują się przyciski opcji, które później zostaną ukryte w celu stworzenia dla nich własnego paska nawigacji po slajdach, w czym pomogą nam etykiety w bloku „sterowanie”.

2. Zaprojektuj suwak

Tutaj zatrzymamy się i przyjrzymy się css. Zwróć uwagę, że niektóre właściwości są poprzedzone prefiksami dla różnych przeglądarek, aby wszystkie nowoczesne przeglądarki mogły je zrozumieć.

* (margines: 0; padding: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box ;) body (obraz w tle: url (http://habrastorage.org/files/996/d76/d04/996d76d0410d422fa54cc433ce7ead2a.png);)
Dzięki projektowi tła i ogólnym stylom wszystko jest jasne.

Wrapper (wysokość: 350px; margines: 100px auto 0; pozycja: względne; szerokość: 700px;) .slider (kolor tła: #ddd; wysokość: dziedziczenie; przepełnienie: ukryte; pozycja: względne; szerokość: dziedziczenie; -webkit- box-shadow: 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); cień pudełka: 0 0 20px rgba (0, 0, 0, .5);)
Wspólne pole i pole suwaka mają ten sam rozmiar, co zapewnia doskonałą kontrolę nad położeniem suwaka na stronie. Chociaż nie ma slajdów, tymczasowo pomalowaliśmy suwak na jasnoszary kolor.

Wrapper> wejście (wyświetlanie: brak;)
Ukryj przyciski opcji. Będziemy ich potrzebować później.

Wynik na ten moment taki:

3. Projektowanie slajdów

Tutaj napiszemy ogólne style dla slajdów i każdego slajdu osobno:

Slajdy (wysokość: dziedziczenie; pozycja: bezwzględna; szerokość: dziedziczenie;) .slide1 (obraz tła: url (http://habrastorage.org/files/3f2/628/bd5/3f2628bd58c8452db516195cb0c9bfc9.jpg);) .slide2 (tło -image: url (http://habrastorage.org/files/3e1/95d/c7f/3e195dc7f5a64469807f49a14f97ba0e.jpg);) .slide3 (background-image: url (http://habrastorage.org/files/663/6b1/ d4f /.jpg);) .slide4 (obraz tła: url (http://habrastorage.org/files/e59/424/c04/e59424c046be4dab897d84ab015c87ea.jpg/org);/hasbackground. 53c/ff6/c1c/53cff6c1caf842368c70b8ef892d8402.jpg);)
Dla wszystkich slajdów określiliśmy pozycjonowanie bezwzględne, abyśmy mogli bawić się efektami wyglądu. Wymiary slajdów brane są z rozmiaru samego slidera, dzięki czemu nie trzeba ich pisać w kilku miejscach.

4. Tworzenie nawigacji po slajdach

Ponieważ przyciski radiowe są ukryte i potrzebujemy ich jako przełączników, projektujemy przygotowane etykiety:

Wrapper .controls (left: 50%; margin-left: -98px; pozycja: bezwzględna;) .wrapper label (kursor: wskaźnik; display: inline-block; wysokość: 8px; margines: 25px 12px 0 16px; pozycja: względna; szerokość: 8px; -webkit-border-radius: 50%; -moz-border-radius: 50%; -o-border-radius: 50%; border-radius: 50%;) .wrapper label: after (border: 2px solid #ddd; content: ""; display: block; height: 12px; left: -4px; position: absolute; top: -4px; width: 12px; -webkit-border-radius: 50%; -moz-border -radius: 50%; -o-border-radius: 50%; border-radius: 50%;)
Sprawiamy, że nawigacja jest klasyczna. Każdy przycisk reprezentuje obszar w formie koła, wewnątrz którego, gdy slajd jest aktywny, pusty obszar będzie częściowo pokolorowany. W międzyczasie mamy następujący wynik:

5. Nauka wciskania przycisków

Czas nauczyć suwak przełączania slajdów, klikając określony przycisk:

Etykieta opakowania (kursor: wskaźnik; display: inline-block; wysokość: 8px; margines: 25px 12px 0 16px; pozycja: względna; szerokość: 8px; -webkit-border-radius: 50%; -moz-border-radius: 50 %; -o-border-radius: 50%; border-radius: 50%; -webkit-transition: luz w tle .5s; -moz-transition: luz w tle .5s; -o- przejście: luz w tle .5s; przejście: luz w tle .5s;) .wrapper label: hover, # slide1: zaznaczone ~ .controls etykieta: n-ty-typ (1), # slide2: zaznaczone ~ .controls etykieta: n-ty-typ (2), # slide3: sprawdzone ~ .controls etykieta: n-ty-typ (3), # slide4: sprawdzone ~ .controls etykieta: n-ty-typ (4) , # slide5: zaznaczone ~ .controls etykieta: nth-of-type (5) (tło: #ddd;)
W zdobionych przyciskach nawigacyjnych dodaj płynną kolorystykę w ich wnętrzu. Dodajemy również warunki, w których aktywny przycisk i przycisk, nad którym najeżdżał kursor, będą płynnie pokolorowane. Nasze własne przyciski radiowe są gotowe:

6. Animowanie suwaka

Cóż, teraz robimy to tak, aby slajdy w końcu się zmieniły:

Slajdy (wysokość: dziedziczenie; krycie: 0; pozycja: bezwzględna; szerokość: dziedziczenie; indeks z: 0; -webkit-transform: skala (1,5); -moz-transform: skala (1,5); -o-transform: skala (1.5); transform: skala (1.5); -webkit-transition: przekształć łatwość-zamknij 0,5s, zmniejsz nieprzezroczystość 0,5s; -moz-transition: przekształć łatwo-zamknij 0,5s, łatwość krycia -in-out 0,5s; -o-transition: przekształcenie złagodzenie na zewnątrz 0,5s, zmniejszenie krycia na zewnątrz 0,5s; przejście: przekształcenie złagodzenie na zewnątrz 0,5s, zmniejszenie krycia 0,5s; ) # slide1: zaznaczone ~ .slider> .slide1, # slide2: zaznaczone ~ .slider> .slide2, # slide3: zaznaczone ~ .slider> .slide3, # slide4: zaznaczone ~ .slider> .slide4, # slide5: zaznaczone ~ .slider> .slide5 (przezroczystość: 1; indeks z: 1; -webkit-transform: skala (1); -moz-transform: skala (1); -o-transform: skala (1); transform: skala ( 1)); )
W ogólnych stylach slajdów dodajemy właściwości, dzięki którym wszystkie slajdy są niewidoczne i znikają w tle. Dodaliśmy również nieznaczne podwyższenie slajdów, gdy są one niewidoczne, aby nadać suwakowi ciekawy wygląd.

Wynik można zobaczyć tutaj.













Witam drodzy początkujący webmasterzy.

Oto najprostszy na świecie czysty suwak CSS.

Zaletami takiego slidera są lekkość i bezpieczeństwo, a także to, że nawet najbardziej początkujący webmaster może go wykonać i zainstalować na swojej stronie.

Wadą jest to, że nie możesz powtórzyć pętli używając samego CSS.

Ale jeśli weźmiemy pod uwagę, że osiem obrazów jest przewijanych przez ponad 30 sekund, to ten czas jest wystarczający, aby odwiedzający mógł wyświetlić stronę.

A jeśli suwak jest zainstalowany w nagłówku witryny, nikt nie rozważy tego przez pół minuty.

Efekty obrazów można zmieniać według własnych upodobań i zgodnie z możliwościami CSS3. Zobaczmy, gdzie i jak można to zrobić.





suwak CSS














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

При этом под слайдером появится кнопка которую можно назвать как Вам угодно и оформить в 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 , как я и обещал.