Информация к новости
  • Просмотров: 714
  • Автор: sulicompany
  • Дата: 17-12-2012, 00:31
 (голосов: 0)
17-12-2012, 00:31

4 простых эффекта CSS для кнопок

Категория: Программирование » CSS


В данном уроке рассматриваются четыре очень простых кнопки CSS с эффектами анимации при наведении курсора мыши на них.

Общие установки

Прежде чем разбираться с кнопками, рассмотрим общие для всех них установки.

HTML

Для кнопок будет использоваться очень простой HTML код:

1 <ahref="#"id="button2"class="buttonText">Подписаться</a>

CSS

Также все кнопки будут иметь общие установки для текста надписи и отмену выделения ссылок:

1 .buttonText {
2   font18px/1.5HelveticaArialsans-serif;
3   color#fff;
4 }
5  
6 a {
7   color#fff;
8   text-decorationnone;
9 }

Увеличивающаяся кнопка

Увеличивающаяся кнопка

Обычно, пользователь ожидает достаточно мягкого эффекта при навдении курсора мыши на ссылку или кнопку. А  в нашем случае кнопка меняет размер - она увеличивается, показывая дополнительное сообщение.

Основной код CSS

Для начала нам нужно только задать кнопке форму и цвет. Определяем высоту 28px и ширину 115px, добавляем поля и отступы, а также задаем  кнопке светлую рамку.

01 #button1{
02   background#6292c2;
03   border2pxsolid#eee;
04   height28px;
05   width115px;
06   margin50px0050px;
07   padding0007px;
08   overflowhidden;
09   displayblock;
10 }

Эффекты CSS3

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

Округляем углы рамки и добавляем градиент. Здесь используется небольшой трюк с темным градиентом, который взаимодействует с любым цветом фона.

01 /*Скругленные углы*/
02 -webkit-border-radius: 15px;
03 -moz-border-radius: 15px;
04 border-radius: 15px;
05
06 /*Градиент*/
07 background-image: -webkit-linear-gradient(top, rgba(0000), rgba(0000.2));
08 background-image: -moz-linear-gradient(top, rgba(0000), rgba(0000.2));
09 background-image: -o-linear-gradient(top, rgba(0000), rgba(0000.2));
10 background-image: -ms-linear-gradient(top, rgba(0000), rgba(0000.2));
11 background-image: linear-gradient(top, rgba(0000), rgba(0000.2));

Анимация CSS

Теперь установим переход CSS. Анимация будет использоваться для любых изменений свойств и длиться полсекунды.

1 /*Переход*/
2 -webkit-transition: All 0.5s ease;
3 -moz-transition: All 0.5s ease;
4 -o-transition: All 0.5s ease;
5 -ms-transition: All 0.5s ease;
6 transition: All 0.5s ease;

Наведение курсора мыши

Осталось только добавить стиль для расширения кнопки при наведении курсора мыши на нее. Кнопка должна иметь ширину 230px для отображения всего сообщения.

1 #button1:hover {
2   width230px;
3 }

Простое изменение тональности цвета

Изменение тональности цвета кнопки

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

Основной код CSS

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

01 #button2{
02   background#d11717;
03   border2pxsolid#eee;
04   height38px;
05   width125px;
06   margin50px0050px;
07   overflowhidden;
08   displayblock;
09   text-aligncenter;
10   line-height38px;
11 }

Эффекты CSS3

Устанавливаем скругление углов, градиент для фона и дополнительную тень. С помощьюrgbaделаем тень черной и прозрачной.

01 /*Скругленные углы*/
02 -webkit-border-radius: 10px;
03 -moz-border-radius: 10px;
04 border-radius: 10px;
05
06 /*Градиент*/
07 background-image: -webkit-linear-gradient(top, rgba(0000), rgba(0000.2));
08 background-image: -moz-linear-gradient(top, rgba(0000), rgba(0000.2));
09 background-image: -o-linear-gradient(top, rgba(0000), rgba(0000.2));
10 background-image: -ms-linear-gradient(top, rgba(0000), rgba(0000.2));
11 background-image: linear-gradient(top, rgba(0000), rgba(0000.2));
12
13 /*Тень*/
14 -webkit-box-shadow: 0px3px1pxrgba(0000.2);
15 -moz-box-shadow: 0px3px1pxrgba(0000.2);
16 box-shadow: 0px3px1pxrgba(0000.2);

Анимация CSS

Анимация практически не отличается от предыдущего примера.

1 /*Переход*/
2 -webkit-transition: All 0.5s ease;
3 -moz-transition: All 0.5s ease;
4 -o-transition: All 0.5s ease;
5 -ms-transition: All 0.5s ease;
6 transition: All 0.5s ease;

Наведение курсора мыши

При наведении курсора мыши будет устанавливаться другой цвет фона. Попробуйте выбрать более светлый вариант цвета в Photoshop, чтобы получился отличный эффект.

1 #button2:hover {
2   background-color#ff3434;
3 }

Сдвиг фонового изображения

Сдвиг фонового изображения

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

Основной код CSS

Основная часть кода не отличается от предыдущих примеров. Обратите внимание на то, что мы используем фоновое изображение. Начальное положение фона установлено в "0 0". При наведении курсора положение сдвигается по вертикали.

01 #button3{
02   background#d11717url('bkg-1.jpg');
03   background-position00;
04   text-shadow0px2px0pxrgba(0000.3);
05   font-size22px;
06   height58px;
07   width155px;
08   margin50px0050px;
09   overflowhidden;
10   displayblock;
11   text-aligncenter;
12   line-height58px;
13 }

Эффекты CSS3

В данном примере нет ничего особенного - скругленные углы и тени.

1 /*Скругленные углы*/
2 -webkit-border-radius: 5px;
3 -moz-border-radius: 5px;
4 border-radius: 5px;
5
6 /*Тень*/
7 -webkit-box-shadow: 0px3px1pxrgba(0000.2);
8 -moz-box-shadow: 0px3px1pxrgba(0000.2);
9 box-shadow: 0px3px1pxrgba(0000.2);

Анимация CSS

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

1 /*Переход*/
2 -webkit-transition: All 0.8s ease;
3 -moz-transition: All 0.8s ease;
4 -o-transition: All 0.8s ease;
5 -ms-transition: All 0.8s ease;
6 transition: All 0.8s ease;

Наведение курсора мыши

Теперь пришла пора сдвигать фоновое изображение. Начальное положение было "0 0". Устанавливаем второй параметр в значение 150px. Для сдвига по горизонтали требуется изменить первый параметр.

1 #button3:hover {
2   background-position0px150px;
3 }

3D имитация нажатия кнопки

Имитация нажатия кнопки

Последний пример в нашем уроке посвящен популярному методу 3D имитации нажатия кнопки при наведении на нее курсора мыши. Анимация для данного случая настолько проста, что даже не требуется задавать переход CSS. Но конечный результат получается вполне впечатляющим.

Основной код CSS

Код CSS для нашей кнопки.

01 #button4{
02   background#5c5c5c;
03   text-shadow0px2px0pxrgba(0000.3);
04   font-size22px;
05   height58px;
06   width155px;
07   margin50px0050px;
08   overflowhidden;
09   displayblock;
10   text-aligncenter;
11   line-height58px;
12 }

Эффекты CSS3

В данном случае CSS3 перестает быть приятным опционом. Для получения эффекта требуются тени и градиент. Резкая тень создает видимость 3D кнопки.

01 /*Скругленные углы*/
02 -webkit-border-radius: 5px;
03 -moz-border-radius: 5px;
04 border-radius: 5px;
05
06 /*Тень*/
07 -webkit-box-shadow: 0px6px0pxrgba(0000.8);
08 -moz-box-shadow: 0px6px0pxrgba(0000.8);
09 box-shadow: 0px6px0pxrgba(0000.8);
10
11 /*Градиент*/
12 background-image: -webkit-linear-gradient(top, rgba(0000), rgba(0000.2));
13 background-image: -moz-linear-gradient(top, rgba(0000), rgba(0000.2));
14 background-image: -o-linear-gradient(top, rgba(0000), rgba(0000.2));
15 background-image: -ms-linear-gradient(top, rgba(0000), rgba(0000.2));
16 background-image: linear-gradient(top, rgba(0000), rgba(0000.2));

Наведение курсора мыши

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

01 #button4:hover {
02   margin-top52px;
03   
04   /*Тень*/
05   -webkit-box-shadow: 0px4px0pxrgba(0000.8);
06   -moz-box-shadow: 0px4px0pxrgba(0000.8);
07   box-shadow: 0px4px0pxrgba(0000.8);
08   
09   /*Градиент*/