Реализация перехода с помощью переворота с помощью CSS - PullRequest
0 голосов
/ 20 сентября 2018

Я пытался реализовать бумажный флип-переход с помощью css, поэтому, чтобы достичь того, что мне было нужно, были следующие задачи:

  1. Мне пришлось переместить div из текущей позиции влево,Я смог добиться этого с помощью свойства translate.
  2. Мне также пришлось перевернуть div.Я смог добиться этого, используя scaleX (-1)
  3. Наконец мне пришлось перевернуть его по кривой.

Как мне добиться финальной части?Вот ссылка на CSSDesk .Я попробовал флип-переход, используя hover .

1 Ответ

0 голосов
/ 20 сентября 2018

Я не знаю, искали ли вы это, но вот быстрый пример:

/* entire container, keeps perspective */
.flip-container {
	perspective: 1500px;
  margin: 0 auto;
  margin-top:100px;
}
	/* flip the pane when hovered */
	.flip-container:hover .flipper, .flip-container.hover .flipper {
		transform: rotateY(180deg);
	}

.flip-container, .front, .back {
	width: 320px;
	height: 480px;
}

/* flip speed goes here */
.flipper {
	transition: 0.6s;
	transform-style: preserve-3d;
  transform-origin: 100%;
	position: relative;
}

/* hide back of pane during swap */
.front, .back {
	backface-visibility: hidden;

	position: absolute;
	top: 0;
	left: 0;
}

/* front pane, placed above back */
.front {
  background-color:red;
	z-index: 2;
	/* for firefox 31 */
	transform: rotateY(0deg);
}

/* back, initially hidden pane */
.back {
  background-color:green;
	transform: rotateY(180deg);
}
<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
	<div class="flipper">
		<div class="front">
           <p>FRONT</p>
		</div>
		<div class="back">
           <p>BACK</p>
		</div>
	</div>
</div>

Ключом к достижению эффекта 3d является perspective: 1500px; Этот пример основан на этой удивительной статье , которая объясняет свойство

...