Как переместить fluid divs на правильное расстояние при включении / выключении экрана с помощью преобразований CSS3?

#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