JavaScript. Подробное руководство, 6-е издание
Шрифт:
if (!time) time = 500;
if (!distance) distance = 5;
var originalStyle = e.style.cssText; // Сохранить оригинальный стиль e
e.style.position = "relative"; // Сделать относит, позиционируемым
var start = (new Date).getTime; // Запомнить момент начала анимации ;
animate // Запустить анимацию
// Эта функция проверяет прошедшее время и изменяет координаты е.
// Если анимацию пора завершать, восстанавливает первоначальное состояние
// элемента е. Иначе изменяет координаты е и планирует следующий свой вызов,
function animate {
var now = (new Date).getTime; // Получить текущее время
var elapsed = now-start; // Сколько прошло времени с начала?
var fraction = elapsed/time; // Доля от требуемого времени?
if (fraction < 1) { // Если рано завершать анимацию
// Вычислить координату х элемента е как функцию от доли общего
// времени анимации. Здесь используется синусоидальная функция,
// а доля общего времени воспроизведения умножается на 4pi,
// поэтому перемещение взад и вперед выполняется дважды,
var x = distance * Math.sin(fraction*4*Math.PI);
e.style.left = x + "px";
// Попробовать вызвать себя через 25 мсек или в конце запланированного
// отрезка общего времени воспроизведения. Мы стремимся сделать
// анимацию гладкой, воспроизводя ее со скоростью 40 кадров/сек.
setTimeout(animate, Math.min(25, time-elapsed));
}
else { // Иначе анимацию пора завершать
e.style.cssText = originalStyle // Восстановить первонач. стиль
if (oncomplete) oncomplete(e); // Вызвать ф-цию обратного вызова
}
}
}
// Растворяет е от состояния полной непрозрачности до состояния полной прозрачности
// за указанное количество миллисекунд. Предполагается, что, когда вызывается
// эта функция, е полностью непрозрачен, oncomplete - необязательная функция,
// которая будет вызвана с элементом е в виде аргумента по завершении анимации.
// Если аргумент time не задан, устанавливается интервал 500 мсек.
// Эта функция не работает в IE, но ее можно модифицировать так, чтобы
// в дополнение к свойству opacity она использовала нестандартное
// свойство filter, реализованное в IE.
function fadeOut(e, oncomplete, time) {
if (typeof e === "string") e = document.getElementByld(e);
if (!time) time = 500;
// В качестве простой "функции перехода", чтобы сделать анимацию немного
// нелинейной, используется Math.sqrt: сначала растворение идет быстро,
// а затем несколько замедляется,
var ease = Math.sqrt;
var start = (new Date).getTime; // Запомнить момент начала анимации
animate; // И запустить анимацию
function animate {
var elapsed = (new Date).getTime-start; // Прошедшее время
var fraction = elapsed/time; // Доля от общего времени
if (fraction < 1) { // Если не пора завершать
var opacity = 1 - ease(fraction); // Вычислить непрозрачн.
e.style.opacity = String(opacity); // Установить ее в e
setTimeout(animate, // Запланировать очередной
Math.min(25, time-elapsed)); // кадр
}
Поделиться:
Популярные книги
За Горизонтом
8. Фронтир
Фантастика:
боевая фантастика
космическая фантастика
космоопера
5.00
рейтинг книги
Статьи
Документальная литература:
публицистика
5.00
рейтинг книги
Княжья Русь
6. Варяг
Приключения:
исторические приключения
9.04
рейтинг книги
Звезда Чёрного Дракона
2. Нежеланная невеста
Любовные романы:
любовно-фантастические романы
4.40
рейтинг книги
Осколки маски
7. Унесенный ветром
Фантастика:
боевая фантастика
альтернативная история
6.71
рейтинг книги
Жизнь, которой не было
1. Жизнь, которой не было
Фантастика:
городское фэнтези
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Принц Ардена
Любовные романы:
исторические любовные романы
5.00
рейтинг книги
По осколкам твоего сердца
2. Хулиган и новенькая
Любовные романы:
современные любовные романы
5.56
рейтинг книги
Богам – божье, людям – людское
6. Отрок
Приключения:
исторические приключения
8.83
рейтинг книги
Кодекс Охотника. Книга XXVII
27. Кодекс Охотника
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Законы Рода. Том 3
3. Граф Берестьев
Фантастика:
фэнтези
аниме
5.00
рейтинг книги
Брак по-драконьи
Фантастика:
фэнтези
8.60
рейтинг книги
Древесный маг Орловского княжества 3
3. Орловское княжество
Фантастика:
аниме
сказочная фантастика
фэнтези
попаданцы
гаремник
5.00
рейтинг книги
Метатель
1. Метатель
Фантастика:
боевая фантастика
попаданцы
рпг
фэнтези
фантастика: прочее
постапокалипсис
5.00