Креативные эффекты для создания загрузчика сайта

Никаких изображений, только чистый CSS и немного фантазии. 
Внимание! Здесь вам всего лишь представлены CSS анимации и только. Для реального использования вам необходимо будет самим писать скрипт для обработки загрузки страницы. 

Но так же мы хотим показать, как сделали один из эффектов: раскрытие загрузки из центра страницы:

Код
.la-anim-7 {
  position: fixed;
  top: 50%;
  bottom: 0;
  left: 50%;
  z-index: -1;
  width: 0;
  height: 100%;
  background: rgba(0,0,0,0.1);
  transform: translateX(-50%) translateY(-50%);
  pointer-events: none;
}

.la-anim-7.la-animate {
  z-index: 100;
  width: 100%;
  opacity: 0;
  transition: width 5s ease-in, opacity 1s 5s;
}

Так же напишем скрипт который будет обрабатывать наши клики по кнопка для вызова самой анимации

Код
var loader = document.getElementById('la-anim-6-loader')
, border = document.getElementById('la-anim-6-border')
, α = 0
, π = Math.PI
, t = 15

, tdraw;

function PieDraw() {
α++;
α %= 360;
var r = ( α * π / 180 )
, x = Math.sin( r ) * 250
, y = Math.cos( r ) * - 250
, mid = ( α > 180 ) ? 1 : 0
, anim = 'M 0 0 v -250 A 250 250 1 '  
+ mid + ' 1 '  
+ x + ' '  
+ y + ' z';

loader.setAttribute( 'd', anim );
border.setAttribute( 'd', anim );
if( α != 0 )
tdraw = setTimeout(PieDraw, t); // Redraw
}

function PieReset() {
clearTimeout(tdraw);
var anim = 'M 0 0 v -250 A 250 250 1 0 1 0 -250 z';
loader.setAttribute( 'd', anim );
border.setAttribute( 'd', anim );
}

var inProgress = false;

Array.prototype.slice.call( document.querySelectorAll( '#la-buttons > button' ) ).forEach( function( el, i ) {
var anim = el.getAttribute( 'data-anim' ),
animEl = document.querySelector( '.' + anim );

el.addEventListener( 'click', function() {
if( inProgress ) return false;
inProgress = true;
classie.add( animEl, 'la-animate' );

if( anim === 'la-anim-6' ) {
PieDraw();
}

setTimeout( function() {
classie.remove( animEl, 'la-animate' );

if( anim === 'la-anim-6' ) {
PieReset();
}

inProgress = false;
}, 6000 );
} );
} );

Некоторые браузеры не поддерживают анимацию, так что данный эффект не будет работать везде. Так же вам потребует поддержка CSS 3D трансформаций.

Если у кого буду какие варианты применения таких эффектов, просьба отписать об этом в комментариях.

  • FalleN

  • 3541

  • 1

  • 229

Ссылки на статью:

Похожие статьи: