Эффекты при наведении для фотографий с названиями и сопроводительным текстом.
Как реализовать интересные эффекты при наведении на изображения, так называемый hover-Effekt? В HTML5 для изображений и связанного с ними сопровождающего текста теперь можно создавать интересные эффекты.
Но обратите внимание, что эти методы работают только при использовании современных броузеров.
Для всех визуальных эффектов используется структура HTML5. В дополнение к “figure-Element” один класс “.hov” помещает текст в “p-Element“. Это позволяет реализовать эффекты для каждого изображения в CSS и анимировать текст, независимо от”figcaption“. И “figcaption-Element” может быть использован для дополнительных эффектов, таких как красивая рамка.
<figure class="hov1"> <img src="bilder660/Strand_bei_Portsalon.jpg" width="660" height="455" alt="Menschenleerer Strand"> <figcaption> <h4>Irland <span>2008</span></h4> <p> Menschenleerer Strand bei Portsalon auf der Halbinsel Fanad in Irland </p> <a href="../fotogalerie-Reisen/Irland2008" title="Sprung zu den Reisebildern aus Irland aus dem Jahr 2008"> Reisebildern aus Irland </a> </figcaption> </figure>
Затем следуют несколько базовых настроек для всех визуальных эффектов в CSS.
- Сначала расположим элемент “figure-Element“и всё, что находится в нём выравнивается по центру и текст отображается белым цветом и в верхнем регистре.
- Изображение полупрозрачно.
- Для содержимого “figcaption-Element” и ссылок выбран полный размер изображения .
- Кроме того, текст ссылки скрыт.
- В главе “H4” текст расположен по центру изображения и слегка смещен от верхней кромки, а также размер шрифта и тени вокруг заголовка фиксированы.
- И, наконец, “р“-элемент для сопроводительного текста по центру, но только с максимальной шириной 200 пикселей. И напоследок установлены цвет и размер шрифта, а также расстояние между отдельными буквами.
figure { position: relative; overflow: hidden; width: 41.25em; margin: 1em auto; text-align: center; color: #fff; text-transform: uppercase; border: 5px solid #eee; box-shadow: 1px 1px 5px 2px #777; } figure img { opacity: .5; } figcaption, figure a { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } figure a { z-index: 10; text-indent: 100%; white-space: nowrap; overflow: hidden; } figure h4 { margin: 0 auto; padding: 25% 3% 0 0; font-size: 2em; font-weight: 800; text-shadow: 2px 4px 2px #101010, 1px 1px 0 #505050; } figure h4 span { font-weight: 300; } figure p { max-width: 200px; margin: 0 auto; letter-spacing: .06em; font-size: .8em; color: #fff; }
Без эффектов, т.е. без дополнительного указания класса в “figure-Element“, изображение с заголовком и сопроводительным текстом будет выглядеть, как показано ниже.
Теперь добавим некоторые интересные эффекты.
В следующем примере, картинка отображается с размером 125%. При наведении мыши, изображение с помощью “hover-Effekt” сжимается за полсекунды до нормального размера, и остаётся только 10% прозрачности, в то же время отображается рамка и текст с изначальных 150% сбрасывается на 100% .
CSS для этого эффекта состоит в следующем и говорит сам за себя:
figure.hov1 img { transition: .5s; transform: scale(1.4); } figure.hov1:hover img { opacity: .9; transform: scale(1.15); } figure.hov1 figcaption:before { position: absolute; top: 30px; right: 30px; bottom: 30px; left: 30px; border: 1px solid #fff; content: ''; transform: scale(1.1); } figure.hov1 p { transform: scale(1.5); } figure.hov1 figcaption:before, figure.hov1 p { opacity: 0; transition: .5s; } figure.hov1:hover figcaption:before, figure.hov1:hover p { opacity: 1; transform: scale(1); }
Во втором примере, изображение сдвигается справа налево, панорамируясь. На экране рамка имеет закругленные углы и внутреннюю тень. Текст выравнивается по правому краю и сдвигается с правой стороны к середине.
CSS для этого эффекта не сильно отличается от первого примера:
figure.hov11 img { width: calc(100% + 200px); transform: translate3d(-200px,0,0); transition: opacity .5s, transform 3s; } figure.hov11:hover img { opacity: .9; transform: translate3d(0,0,0); } figure.hov11 figcaption:before { position: absolute; top: 30px; right: 30px; bottom: 30px; left: 30px; border: 1px solid #fff; border-radius: 50px; box-shadow: inset 0 0 10px 5px rgba(0, 0, 0, 0.5); content: ''; transform: scale(1.1); } figure.hov11 figcaption:before, figure.hov11 p { opacity: 0; transition: .5s; } figure.hov11 p { border-right: 1px solid #fff; text-align: right; transform: translate3d(100%,0,0) scale(1.2); } figure.hov11:hover figcaption:before, figure.hov11:hover p { opacity: 1; transform: translate3d(0,0,0) scale(1); }
В третьем примере, размер изображения остается тем же самым. При наведении указателем мыши, текст отображается с полосой. Текст и полоса поднимаются на 20px вверх, одновременно с чем описание движется вниз. Кроме того, рамка, созданная линиями в центре выделяет главный объект фотографии.
CSS для этого примера:
figure.hov2 img { transition: .5s; } figure.hov2:hover img { opacity: .9; } figure.hov2 figcaption:before { border-top: 1px solid #fff; border-bottom: 1px solid #fff; transform: scale(0,1); } figure.hov2 figcaption:after { border-right: 1px solid #fff; border-left: 1px solid #fff; transform: scale(1,0); } figure.hov2 figcaption:before, figure.hov2 figcaption:after { position: absolute; top: 240px; right: 30px; bottom: 20px; left: 30px; content: ''; opacity: 0; transition: .5s; } figure.hov2 h4 { padding-top: 10%; transition: .5s; transform: translate3d(0,-20px,0); } figure.hov2 p { max-width: 350px; text-transform: none; opacity: 0; transition: .5s; transform: translate3d(0,20px,0); } figure.hov2 p:after { position: absolute; top: -35%; left: 0; width: 100%; height: .25em; background: #fff; content: ''; } figure.hov2:hover figcaption:before, figure.hov2:hover figcaption:after { opacity: 1; transform: scale(1); } figure.hov2:hover h4, figure.hov2:hover p { opacity: 1; transform: translate3d(0,0,0); }
В последнем примере, изображение и название скользят вниз. Одновременно появляется рамка, чьи линии движутся сверху и справа, и отображается текст.
Особенностью этого примера является transform-origin: 0 0, при котором линии протягивается от левого верхнего края. При transform-origin: 100% 0 они появятся в верхнем правом и при transform-origin: 100% 100% они будут в правом нижнем углу.
Эти данные означают “установки центра вращения”. Значения этих двух данных: первое значение X или горизонтальная ось, а 0 слева. Второе значение является вертикальной или Y-ось и 0 сверху.
В этом примере CSS выглядит следующим образом:
figure.hov3 { height: 26.6em; } figure.hov3 figcaption:before, figure.hov3 figcaption:after { position: absolute; content: ''; opacity: 0; } figure.hov3 figcaption:before { top: 50px; right: 30px; bottom: 50px; left: 30px; border-top: 1px solid #fff; border-bottom: 1px solid #fff; transform: scale(0,1); transform-origin: 0 0; } figure.hov3 figcaption:after { top: 30px; right: 50px; bottom: 30px; left: 50px; border-right: 1px solid #fff; border-left: 1px solid #fff; transform: scale(1,0); transform-origin: 0 0; } figure.hov3 p { position: relative; overflow: hidden; max-width: 380px; opacity: 0; } figure.hov3 p:after { position: absolute; bottom: 30px; left: 0; top: 0; width: 100%; height: .2em; background: #fff; content: ''; transition: transform .5s; transform: translate3d(-100%,0,0); } figure.hov3 img, figure.hov3 h4 { transform: translate3d(0,-30px,0); } figure.hov3 img, figure.hov3 figcaption:before, figure.hov3 figcaption:after, figure.hov3 p, figure.hov3 h4 { transition: 1s; } figure.hov3:hover img { opacity: .9; transform: translate3d(0,0,0); } figure.hov3:hover figcaption:before, figure.hov3:hover figcaption:after { opacity: 1; transform: scale(1); } figure.hov3:hover h4, figure.hov3:hover p, figure.hov3:hover p:after { opacity: 1; transform: translate3d(0,0,0); }
Таким образом есть множество вариаций формы с крутыми эффектами. Как насчет, например, с фотографиями на стене, мимо которых можно прогуляться как в фотогалерее?
Получайте удовольствие от экспериментов!