С учетом этой особенности работают операционные системы, они отображают окна не мгновенно, а с некоторой задержкой, которая приходится на анимацию. Такого рода анимация называется «разворачивание окна» и состоит обычно в том, что окно словно прячется за невидимыми шторками, которые раздвигаются в стороны, постепенно показывая содержимое окна. Разворачивание может происходить по горизонтали, вертикали или сразу в двух направлениях. Аналогично совершается и сворачивание окна, но в этом случае информация скрывается.
Описанные действия с окнами можно перенести и на слои, которые должны отображаться поверх веб-страницы. Такие слои могут применяться для отображения дополнительной информации, например, различных предупреждений.
Для получения подобного эффекта, вначале потребуется создать слой с абсолютным позиционированием (пример 1).
Пример 1. Создание слоя
<style type="text/css">
#window {
background: #fc0;
width: 300px;
height: 200px;
position: absolute;
left: 50%;
top: 50%;
margin-left: -150px;
margin-top: -100px;
clip: rect(auto 150 auto 150) /* Скрываем содержимое слоя */
}
#window P {
margin: 0px;
padding: 10px /* Поля вокруг текста */
}
#title {
background: #666;
padding: 5px;
font-weight: bold;
text-align: right /* Выравнивание по правому краю */
}
#title A {
color: white;
text-decoration: none /* Убираем подчеркивание у ссылок */
}
</style>
<div id=window>
<div id=title><a href="javascript: curtainOff()">Закрыть окно [X]</a></div>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis te feugifacilisi.</p>
</div>
Вид слоя управляется с помощью стилей, как показано в данном примере. Содержимое самого слоя первоначально скрыто с помощью параметра clip, который работает только для абсолютно позиционированных элементов. По этой причине для слоя обязательно требуется задать свойство position со значением absolute.
Сам эффект разворачивания основан на динамическом изменении значений параметра clip, поэтому вначале разберем, что он из себя представляет.
Атрибут clip определяет прямоугольную область элемента, в которой будет отображаться его содержимое. Все, что не помещается в эту область, будет обрезано и становится невидимым.
Синтаксис применения clip следующий:
clip: rect(y1 x1 y2 x2) | auto
Значение auto оставляет край без изменения, а положение остальных значений показано на рис. 1.
Рис. 1. Значения параметра clip
Если мы хотим разворачивать слой только по горизонтали, то нас интересуют только значения x1 и x2. Причем, значение x1 постепенно должно уменьшаться до нуля, а x2, наоборот, увеличиваться, пока не достигнет значения, равное ширине слоя. В примере 2 показано создание функции curtainOn(), которая изменяет требуемые значения координат.
Пример 2. Динамическое изменение значений атрибута clip
step = 10
width = 300
x1 = x2 = width/2
function curtainOn() {
if (x1 > 0) {
x1 -= step
x2 += step
clip = "auto " + x2 + " auto " + x1
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOn()", 30)
}
}
Пошаговое изменение координат атрибута clip происходит за счет использования встроенной функции setTimeout, в качестве ее аргумента указывается функция curtainOn, которую следует вызывать через определенный промежуток времени. Изменяя значение времени в большую или меньшую сторону, можно регулировать скорость раскрытия слоя. Также на скорость влияет величина шага приращения step, которая к тому же, управляет и плавностью движения.
Доступ к свойствам слоя осуществляется через функцию getElementById, которая в настоящее время является стандартным методом для получения и модификации свойств объектов. Современные браузеры в полной мере поддерживают getElementById.
Сворачивание слоя происходит аналогично, но теперь уже требуется увеличивать значение координаты x1 (которая после разворачивания равна нулю), а значение координаты x2 (равную ширине слоя) уменьшать.
Пример 3. Функция для сворачивания слоя
function curtainOff() {
if (x2 > (width/2)) {
x1 += step
x2 -= step
clip = "auto " + x2 + " auto " + x1
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOff()", 30)
}
}
Браузер Opera хотя корректно сворачивает и разворачивает содержимое слоя, но сам фон при этом не скрывается. Получается, что цветной прямоугольник будет висеть постоянно, закрывая основное содержание веб-страницы. Специально для этого браузера следует добавить свойство display со значением none, а затем для отображения слоя установить значение block. Окончательный код показан в примере 4.
Пример 4. Полный листинг для разворачивания и сворачивания слоя
<html>
<head>
<style type="text/css">
#window {
background: #fc0;
width: 300px; height: 200px;
position: absolute;
left: 50%; top: 50%;
margin-left: -150px; margin-top: -100px;
clip: rect(auto 150 auto 150)
}
#window P {
margin: 0px; padding: 10px
}
#title {
background: #666; padding: 5px; font-weight: bold; text-align: right
}
#title A {
color: white; text-decoration: none
}
</style>
<script language="JavaScript">
step = 10
width = 300
x1 = x2 = width/2
function curtainOn() {
if (Opera) document.getElementById("window").style.display = "block"
if (x1 > 0) {
x1 -= step
x2 += step
clip = "auto " + x2 + " auto " + x1
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOn()", 30)
}
}
function curtainOff() {
if (x2 > (width/2)) {
x1 += step
x2 -= step
clip = "auto " + x2 + " auto " + x1
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOff()", 30)
}
else if (Opera) document.getElementById("window").style.display = "none"
}
</script>
</head>
<body>
<div id=window>
<div id=title><a href="javascript: curtainOff()">Закрыть окно [X]</a></div>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem
nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat
volutpat. Ut wisis enim ad minim veniam, quis nostrud exerci tution
ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
Duis te feugifacilisi.</p>
</div>
<br><br>
<a href="javascript: curtainOn()">Развернуть окно</a>
<script language="JavaScript">
Opera = document.getElementById && window.opera
if (Opera) document.getElementById("window").style.display = "none"
</script>
</body>
</html>
Не обязательно делать разворачивание слоя по горизонтали, указанным способом можно разворачивать и по вертикали (пример 5) или одновременно в двух направлениях.
Пример 5. Разворачивание и сворачивание слоя по вертикали
<html>
<head>
<style type="text/css">
#window {
background: #fc0;
width: 300px; height: 200px;
position: absolute;
left: 50%; top: 50%;
margin-left: -150px; margin-top: -100px;
clip: rect(100 auto 100 auto)
}
#window P {
margin: 0px; padding: 10px
}
#title {
background: #666; padding: 5px; font-weight: bold; text-align: right
}
#title A {
color: white; text-decoration: none
}
</style>
<script language="JavaScript">
step = 10
height = 200
y1 = y2 = height/2
function curtainOn() {
if (Opera) document.getElementById("window").style.display = "block"
if (y1 > 0) {
y1 -= step
y2 += step
clip = y1 + " auto " + y2 + " auto"
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOn()", 30)
}
}
function curtainOff() {
if (y2 > (height/2)) {
y1 += step
y2 -= step
clip = y1 + " auto " + y2 + " auto"
document.getElementById("window").style.clip = "rect(" + clip + ")"
setTimeout("curtainOff()", 30)
}
else if (Opera) document.getElementById("window").style.display = "none"
}
</script>
</head>
<body>
<div id=window>
<div id=title><a href="javascript: curtainOff()">Закрыть окно [X]</a></div>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem
nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat
volutpat. Ut wisis enim ad minim veniam, quis nostrud exerci tution
ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
Duis te feugifacilisi.</p>
</div>
<br><br>
<a href="javascript: curtainOn()">Развернуть окно</a>
<script language="JavaScript">
Opera = document.getElementById && window.opera
if (Opera) document.getElementById("window").style.display = "none"
</script>
</body>
</html>