CSS 3D变换翻转上的图像交换

时间:2014-02-14 06:28:22

标签: html css css3 css-animations

http://jsfiddle.net/RtTPU/

我试图在悬停时将图像“Adam”交换为“Adam-flipped”,所以一旦图像悬停在它上面,它会在它翻转时交换,但它不起作用。是否可以在CSS中完全执行此操作?

<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
    <div class="flipper">
        <div class="front">
            <img src="http://adamginther.com/assets/img/adam.jpg" alt="Adam">
        </div>
        <div class="back">
            <img src="http://adamginther.com/assets/img/adam-flipped.jpg" alt="Adam" >
        </div>
    </div>
</div>


.self-portrait {
    border-radius: 400px;
    width: 50%;
}


/* entire container, keeps perspective */
.flip-container {
    perspective: 1000;
}
    /* 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;

    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 {
    z-index: 2;
}

/* back, initially hidden pane */
.back {
    transform: rotateY(180deg);
}

3 个答案:

答案 0 :(得分:1)

您的代码无效,因为它缺少transformbackface-visibility的前缀。另外,您必须告诉.flipper的孩子保留应用于它的三维变换并自动计算transform-style: preserve-3d的组合效果(也需要前缀)。

第二个问题:您必须在width.flip-container上设置明确的.flipper,以确保图片围绕中心y轴翻转。但是,将其保留在auto会导致不同屏幕大小的不同级别的怪异。

请注意,我的代码示例仅包含webkit前缀以简洁起见。希望这可以解决问题。

相关变化:

.flip-container {
  ...
  width: 400px;
  height: 400px;
}

.flip-container:hover .flipper {
  -webkit-transform: rotateY(180deg);
}

.flipper {
  ...
  -webkit-transform-style: preserve-3d;
  height: 100%;
  width: 100%;
}

.front, .back {
   ...
  -webkit-backface-visibility: hidden;
}

.back {
  -webkit-transform: rotateY(180deg);
}

查看小提琴固定版本的所有更改:http://jsfiddle.net/marionebl/RtTPU/6/

版本较少的详细标记和已消毒的CSS样式:http://jsfiddle.net/marionebl/6Je6r/1/

答案 1 :(得分:0)

我想这就是你想要的。 fiddle

.flip-container:hover .back{
    z-index : 10;
}
.back{
    z-index:0;
}

答案 2 :(得分:0)

您需要转换属性的前缀。

另外.flip-container.hover没用,透视需要单位:

/* entire container, keeps perspective */
.flip-container {
    -webkit-perspective: 1000px;
    perspective: 1000px;
}
/* flip the pane when hovered */
.flip-container:hover .flipper {
    transform: rotateY(180deg);
    -webkit-transform: rotateY(180deg);
}

corrected fiddle