#css #position #transform #css-transitions #css-animations
#css #положение #преобразование #css-переходы #css-анимация
Вопрос:
У меня есть контейнер для жидкости, который содержит несколько абсолютно расположенных жидких элементов. Я хочу использовать преобразования CSS3 для перемещения их на страницу и за ее пределы. Проблема, с которой я сталкиваюсь, заключается в том, что при использовании преобразований вы либо используете точное количество пикселей, либо проценты от самого элемента.
Итак, вы можете увидеть пример того, о чем я говорю (это всего лишь тестовый пример) по адресу http://jsfiddle.net/K3uPY /
Это использует преобразование 1000% для перемещения их за пределы экрана, что, очевидно, не очень хорошо, так как если дисплей большой, он не будет работать, и это означает, что каждый div находится на разном расстоянии от края экрана, поэтому анимация может занять совсем другое время, чтобы комплектуется в зависимости от их первоначального размера.
Что я хочу сделать, так это переместить их все за пределы экрана в зависимости от ширины / высоты видового экрана (и соответствующего направления).
Это можно легко сделать, анимировав верхние / левые позиции, но это, очевидно, не оптимально на всех устройствах (см. http://paulirish.com/2012/why-moving-elements-with-translate-is-better-than-posabs-topleft /)
Есть ли способ сделать это с помощью преобразований CSS3 или даже ключевых кадров, или мне приходится анимировать позиции слева / сверху?
CSS из JSfiddle:
html, body {height:100%; width: 100%; padding:0; margin:0;}
#wrapper {width: 100%; height: 100%; overflow: hidden;}
#container {width:50%; height: 50%; margin: auto; position: relative;}
#container div {
background-color: red;
position: absolute;
height: 25%;
-webkit-box-sizing: border-box; /* Safari/Chrome, other WebKit */
-moz-box-sizing: border-box; /* Firefox, other Gecko */
box-sizing: border-box; /* Opera/IE 8 */
border: 2px solid #000000;
-webkit-transition-duration: 600ms;
-moz-transition-duration: 600ms;
-o-transition-duration: 600ms;
transition-duration: 600ms;
cursor: pointer;
}
.zoomleft {
-webkit-transform:translate(-1000%);
-moz-transform:translate(-1000%);
-ms-transform:translate(-1000%);
-o-transform:translate(-1000%);
transform:translate(-1000%);
}
.zoomright {
-webkit-transform:translate(1000%);
-moz-transform:translate(1000%);
-ms-transform:translate(1000%);
-o-transform:translate(1000%);
transform:translate(1000%);
}
.zoomtop {
-webkit-transform:translate(0, -1000%);
-moz-transform:translate(0, -1000%);
-ms-transform:translate(0, -1000%);
-o-transform:translate(0, -1000%);
transform:translate(0, -1000%);
}
.zoombottom {
-webkit-transform:translate(0, 1000%);
-moz-transform:translate(0, 1000%);
-ms-transform:translate(0, 1000%);
-o-transform:translate(0, 1000%);
transform:translate(0, 1000%);
}
div.d1 {
width: 50%;
top: 0;
left: 0;
}
div.d2 {
width: 50%;
top: 0;
left: 50%;
}
div.d3 {
width: 25%;
top: 25%;
left: 0;
}
div.d4 {
width: 25%;
top: 25%;
left: 25%;
}
div.d5 {
width: 25%;
top: 25%;
left: 50%;
}
div.d6 {
width: 25%;
top: 25%;
left: 75%;
}
div.d7 {
width: 50%;
top: 50%;
left: 0;
}
div.d8 {
width: 50%;
top: 50%;
left: 50%;
}
div.d9 {
width: 50%;
top: 75%;
left: 0;
}
div.d10 {
width: 50%;
top: 75%;
left: 50%;
}
Спасибо всем,
Дэйв
Ответ №1:
К счастью, поскольку все изменчиво в зависимости от области просмотра, вы все равно можете использовать проценты в преобразовании. Смотрите мою скрипку — http://jsfiddle.net/K3uPY/23 /
Одна вещь, которую мне пришлось изменить, это убедиться, что #container находится в абсолютном центре. Я также значительно упростил JS и перенес все позиционирование в CSS.
HTML
<div id="wrapper">
<button id="movebtn">Move</button>
<div id="container">
<div class="box d1 active">1</div>
<div class="box d2 active">2</div>
<div class="box d3 active">3</div>
<div class="box d4 active">4</div>
<div class="box d5 active">5</div>
<div class="box d6 active">6</div>
<div class="box d7 active">7</div>
<div class="box d8 active">8</div>
<div class="box d9 active">9</div>
<div class="box d10 active">10</div>
</div>
</div>
JAVASCRIPT
$( "#movebtn" ).on('click', function() {
$('.box').toggleClass('active');
});
CSS
html,
body {
height:100%;
margin:0;
overflow: hidden;
width: 100%;
}
#wrapper {
height: 100%;
overflow: hidden;
width: 100%;
}
#container {
width: 50%;
height: 50%;
margin: auto;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.box {
background-color: red;
border: 2px solid #000000;
box-sizing: border-box;
cursor: pointer;
height: 25%;
position: absolute;
transition-duration: 600ms;
}
.box.active {
transform: none;
}
.d1 {
width: 50%;
top: 0;
left: 0;
transform: translateY(-300%);
}
.d2 {
width: 50%;
top: 0;
left: 50%;
transform: translateY(-300%);
}
.d3 {
width: 25%;
top: 25%;
left: 0;
transform: translateX(-300%);
}
.d4 {
width: 25%;
top: 25%;
left: 25%;
transform: translateX(-400%);
}
.d5 {
width: 25%;
top: 25%;
left: 50%;
transform: translateX(400%);
}
.d6 {
width: 25%;
top: 25%;
left: 75%;
transform: translateX(300%);
}
.d7 {
width: 50%;
top: 50%;
left: 0;
transform: translateX(-200%);
}
.d8 {
width: 50%;
top: 50%;
left: 50%;
transform: translateX(200%);
}
.d9 {
width: 50%;
top: 75%;
left: 0;
transform: translateY(300%);
}
.d10 {
width: 50%;
top: 75%;
left: 50%;
transform: translateY(300%);
}
Комментарии:
1. Большое спасибо, Майкл, я понимаю вашу логику, когда она плавная / центрированная, как вы говорите, вы можете вычислить относительный% для их перемещения. Проблема в том (я должен был быть более ясным), что это всего лишь простой тестовый пример. На самом деле у меня гораздо более сложный макет сетки (разной высоты / ширины и т.д.), Который отображается в одном разделе fluid, размер которого варьируется относительно других элементов фиксированного размера (например, нижний колонтитул фиксированного размера, а высота сетки варьируется в зависимости от этого и области просмотра). Поэтому для высоты я не могу использовать%s для вычисления расстояния. Есть ли какой-нибудь способ сделать это, когда все не является жидким?
2. Нет, я так не думаю, вы должны объединить это с переходом непрозрачности, чтобы он все еще был вне поля зрения. Я не думаю, что вы сможете получить именно тот эффект, который вы хотите, хотя — jsfiddle.net/K3uPY/33