Menú
Está libre
registro
hogar  /  Multimedia/ Un control deslizante receptivo en CSS puro. Control deslizante CSS sensible con efecto creativo

Un control deslizante sensible en css puro. Control deslizante CSS sensible con efecto creativo

Quiero contarles una forma sencilla de crear un control deslizante, sin usar JS, usando animación CSS.

1) Primero, escribamos HTML, supongamos que 4 imágenes se reemplazarán entre sí en el control deslizante.


2) A continuación, organizaremos el tamaño del bloque y algunas configuraciones más, la posición: relativa es necesaria para crear un contexto de formato, entonces quedará claro por qué.

Control deslizante (ancho: 500 px; alto: 300 px; margen: automático; margen superior: 25 px; borde: 1 px negro sólido; posición: relativa; desbordamiento: oculto;)
3) También definamos algunas propiedades para las diapositivas en sí mismas:

Diapositiva (ancho: 500px; alto: 300px; posición: absoluta; arriba: 0; izquierda: 0;)
Como puede ver en el CSS, estamos colocando todas las diapositivas en la esquina superior izquierda del control deslizante, dando así la misma posición inicial.

1. La diapositiva está en su posición original, mostrada al usuario.

2. La diapositiva se mueve hacia la izquierda hasta que sobrepasa completamente el borde del control deslizante (el control deslizante, como se mencionó anteriormente, tiene un desbordamiento: oculto, por lo que la diapositiva no pasa sobre los objetos circundantes).

5. El tobogán baja un nivel con el control deslizante.

6. La diapositiva se mueve a su posición original.
En otras palabras (por ahora nombraré los marcos de acuerdo con los números de la lista anterior):

@keyframes slide (from (top: 0; left: 0;) 1 (transform: translate (0px, 0px);) 2 (transform: translate (-500px, 0);) 3 (transform: translate (-500px, 300px );) 4 (transformar: traducir (500px, 300px);) 5 (transformar: traducir (500px, 0);) a (transformar: (0px, 0px);))
5) Entonces, quedó claro cómo se ve el camino del tobogán. Cada diapositiva "da vueltas" alrededor de su contenedor, el control deslizante, y vuelve al original. De esta manera podemos rotar infinitamente cualquier número de diapositivas. Pero hay un matiz que es más importante en este esquema: el tiempo. Debe cronometrar el guión gráfico de la animación correctamente y establecer el retraso correcto para cada diapositiva para que no todos se apresuren a animar al mismo tiempo. Para comprender cómo configurar correctamente el retraso y calcular el tiempo de animación, seguí el camino que se describe a continuación.

Tomemos las designaciones de los pasos del párrafo anterior y descubramos qué sucede en cada paso. Básicamente, los pasos 1, 2 y 6 son los pasos en los que la diapositiva ingresa al área visible. Del hecho de que las diapositivas deben moverse inseparablemente y, por así decirlo, empujarse unas a otras fuera del control deslizante, podemos concluir que la duración de los pasos 2 y 6 debe ser igual. Haré una reserva de inmediato de que logré trabajar con éxito con este diseño solo con la condición de que la duración del primer paso también sea igual a la duración del segundo y sexto. Lo que sucede durante los pasos 3, 4 y 5 es esencialmente una necesidad técnica y, en aras de la simplicidad, combinemos estos tres pasos en 1.

Después de la simplificación, tenemos:

1. Paso: el control deslizante se muestra en el original.
2. Paso: el control deslizante se mueve hacia la derecha.
3. Paso: el control deslizante realiza movimientos técnicos.
4. Paso: el control deslizante se mueve hacia la izquierda y vuelve a su posición original.

Para garantizar una presentación de diapositivas perfecta, en el momento en que la diapositiva pasa al paso 2, la siguiente diapositiva debe continuar con el paso 4.

Si el tiempo por círculo de toda la animación es t;
Número de portaobjetos - n;
Duración de 3 pasos - y;
Duración de los pasos 1, 2 y 4 - x;
El paso de retardo de la animación para n-slide es z;
Ese:

Y = (100 * n - 150) / n;
x = (100 - y) / 3;
xey deben convertirse a porcentajes, y luego:
z = 2 * x * t;

Para el caso en el que n = 4, como en el ejemplo anterior, obtenemos:

3er paso - 62,5%, 1º, 2º y 4º - 12,5% cada uno. El paso de retraso de la animación para cada diapositiva posterior es del 25%.

No importa qué intervalos habrá entre las etapas dentro del tercer paso.

6) Ahora que hemos calculado todo y conocemos todos los valores, podemos dar el código final.

Animación:

@keyframes slide (from (top: 0; left: 0;) 12.5% ​​(transform: translate (0px, 0px);) 25% (transform: translate (-500px, 0);) 36% (transform: translate (- 500px, 300px);) 37% (transform: translate (500px, 300px);) 87.5% (transform: translate (500px, 0);) to (transform: (0px, 0px);))
Diapositivas:

Slide1 (background: url (1.jpg); animation-delay: 7.5s;) .slide2 (background: url (2.jpg); animation-delay: 5s;) .slide3 (background: url (3.jpg); animation-delay: 2.5s;) .slide4 (background: url (4.jpg); animation-delay: 0s;)
CSS general para todas las diapositivas:

Diapositiva (ancho: 500px; alto: 300px; posición: absoluta; arriba: 0; izquierda: 0; nombre-animación: deslizamiento; duración-animación: 10s; función-tiempo-animación: lineal; recuento-iteración-animación: infinito; )
¡Eso es todo, en realidad! Gracias a todos los que leyeron hasta el final.

3 de marzo de 2015 a las 06:15 PM

Un control deslizante CSS3 puro interesante pero simple

  • Desarrollo de sitios web,
  • CSS,
  • HTML

No abriré América a nadie, no sorprenderé a la audiencia con un nuevo truco y no dejaré boquiabiertos a quienes nadan como un buzo en CSS3. Aquí hay una manera fácil de crear un control deslizante utilizando funciones simples de CSS3 sin la necesidad de javascript.

1. Diseña la base

Para implementar el control deslizante, necesitamos un conjunto de etiquetas bastante simple, que a su vez será responsable de los elementos del control deslizante.


Aquí vemos que el bloque general "contenedor" contiene un bloque "deslizador" con 5 diapositivas, dentro del cual puede colocar cualquier código html que se ubicará en la diapositiva. Delante del bloque general hay botones de radio, que luego se ocultarán para crear su propia barra deslizante de navegación para ellos, con lo que nos ayudarán las etiquetas del bloque "controles".

2. Diseña el control deslizante

Aquí nos detendremos y echaremos un vistazo a css. Tenga en cuenta que algunas propiedades tienen prefijos de varios navegadores para que todos los navegadores modernos puedan entenderlas.

* (margen: 0; relleno: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; tamaño de la caja: border-box ;) cuerpo (imagen de fondo: url (http://habrastorage.org/files/996/d76/d04/996d76d0410d422fa54cc433ce7ead2a.png);)
Con el diseño de fondo y los estilos generales, todo está claro.

Envoltorio (altura: 350px; margen: 100px auto 0; posición: relativa; ancho: 700px;) .slider (color de fondo: #ddd; altura: heredar; desbordamiento: oculto; posición: relativa; ancho: heredar; -webkit- caja-sombra: 0 0 20px rgba (0, 0, 0, .5); -moz-caja-sombra: 0 0 20px rgba (0, 0, 0, .5); -o-caja-sombra: 0 0 20px rgba (0, 0, 0, .5); sombra de caja: 0 0 20px rgba (0, 0, 0, .5);)
El cuadro compartido y el cuadro deslizante son del mismo tamaño para un control perfecto de la posición del deslizador en la página. Si bien no hay diapositivas, pintamos temporalmente el control deslizante en un color gris claro.

Envoltorio> entrada (pantalla: ninguno;)
Ocultar los botones de opción. Los necesitaremos más tarde.

Resultado en este momento tal:

3. Diseño de diapositivas

Aquí escribiremos estilos generales para diapositivas y cada diapositiva por separado:

Diapositivas (altura: heredar; posición: absoluta; ancho: heredar;) .slide1 (background-image: url (http://habrastorage.org/files/3f2/628/bd5/3f2628bd58c8452db516195cb0c9bfc9.jpg);) .slide2 (background -imagen: url (http://habrastorage.org/files/3e1/95d/c7f/3e195dc7f5a64469807f49a14f97ba0e.jpg);) .slide3 (imagen de fondo: url (http://habrastorage.org/files/663/6b1/ d4f /.jpg);) .slide4 (imagen de fondo: url (http://habrastorage.org/files/e59/424/c04/e59424c046be4dab897d84ab015c87ea.jpg);) (fondo. //15c87ea.jpg);) 53c / ff6 / c1c /.jpg);)
Hemos especificado un posicionamiento absoluto para todas las diapositivas para que podamos jugar con los efectos de apariencia. Las dimensiones de las diapositivas se toman del tamaño del propio control deslizante, para que no tenga que escribirlas en varios lugares.

4. Hacer navegación por diapositivas

Dado que los botones de radio están ocultos y los necesitamos como interruptores, diseñamos las etiquetas preparadas:

Wrapper .controls (left: 50%; margin-left: -98px; position: absolute;) .wrapper label (cursor: pointer; display: inline-block; altura: 8px; margen: 25px 12px 0 16px; posición: relativa; width: 8px; -webkit-border-radius: 50%; -moz-border-radius: 50%; -o-border-radius: 50%; border-radius: 50%;) .etiqueta de envoltura: después (borde: 2px sólido #ddd; contenido: ""; display: block; height: 12px; left: -4px; position: absoluta; top: -4px; width: 12px; -webkit-border-radius: 50%; -moz-border -radio: 50%; -o-radio-borde: 50%; radio-borde: 50%;)
Hacemos de la navegación un clásico. Cada botón representa un área en forma de círculo, dentro del cual, cuando la diapositiva está activa, el área vacía se coloreará parcialmente. Mientras tanto, tenemos el siguiente resultado:

5. Aprendiendo a presionar botones

Es hora de enseñar al control deslizante a cambiar de diapositiva haciendo clic en un botón específico:

Etiqueta de envoltura (cursor: puntero; pantalla: bloque en línea; altura: 8px; margen: 25px 12px 0 16px; posición: relativa; ancho: 8px; -webkit-border-radius: 50%; -moz-border-radius: 50 %; -o-border-radius: 50%; border-radius: 50%; -webkit-transition: fondo con facilidad de entrada y salida .5s; -moz-transición: fondo con facilidad de entrada y salida .5s; -o- transición: facilidad de entrada-salida de fondo .5s; transición: facilidad de entrada-salida de fondo .5s;) .etiqueta de envoltura: hover, # diapositiva1: marcada ~ .controles etiqueta: n-ésimo de tipo (1), # diapositiva2: etiquetada ~ .controles: nth-of-type (2), # slide3: marcada ~ .controls etiqueta: nth-of-type (3), # slide4: marcada ~ .controls etiqueta: nth-of-type (4) , # slide5: marcada ~ .controls etiqueta: n-ésimo de tipo (5) (fondo: #ddd;)
En los botones de navegación decorados, agregue un color suave dentro de ellos. También agregamos condiciones bajo las cuales el botón activo y el botón sobre el que estaba pasando el cursor se colorearán suavemente. Nuestros propios botones de radio están listos:

6. Animar el control deslizante

Bueno, ahora lo hacemos para que las diapositivas finalmente cambien:

Diapositivas (altura: heredar; opacidad: 0; posición: absoluta; ancho: heredar; índice z: 0; -webkit-transform: scale (1.5); -moz-transform: scale (1.5); -o-transform: scale (1.5); transformar: escala (1.5); -webkit-transición: transformar facilidad-entrada-salida .5s, opacidad facilidad-entrada-salida .5s; -moz-transición: transformar facilidad-entrada-salida .5s, opacidad facilidad -in-out .5s; -o-transición: transforma facilidad-entrada-salida .5s, opacidad facilidad-entrada-salida .5s; transición: transforma facilidad-entrada-salida .5s, opacidad facilidad-entrada-salida .5s; ) # slide1: marcado ~ .lider> .slide1, # slide2: marcado ~ .slider> .slide2, # slide3: marcado ~ .slider> .slide3, # slide4: marcado ~ .slider> .slide4, # slide5: marcado ~ .slider> .slide5 (opacidad: 1; z-index: 1; -webkit-transform: scale (1); -moz-transform: scale (1); -o-transform: scale (1); transform: scale ( 1);)
En los estilos de diapositiva generales, agregamos propiedades que hacen que todas las diapositivas sean invisibles y se desvanezcan en el fondo. También agregamos un ligero aumento a las diapositivas mientras son invisibles para dar una apariencia interesante en el control deslizante.

El resultado se puede ver aquí.













Hola queridos webmasters novatos.

Aquí está el control deslizante CSS puro más simple del mundo.

Las ventajas de un control deslizante de este tipo incluyen ligereza y seguridad, así como el hecho de que incluso el webmaster más novato puede crearlo e instalarlo en su sitio.

La desventaja es que no puede repetir el ciclo usando solo CSS.

Pero si consideramos que ocho imágenes se desplazan durante más de 30 segundos, entonces este tiempo es suficiente para que un visitante vea la página.

Y si el control deslizante está instalado en el encabezado del sitio, nadie lo considerará durante medio minuto.

Los efectos de las imágenes se pueden cambiar a su gusto y de acuerdo con las capacidades de CSS3. Veamos dónde y cómo se puede hacer esto.





Control deslizante 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 , как я и обещал.