2014-02-14 57 views
0

http://jsfiddle.net/RtTPU/影像交换3D转换翻转

我想交换图像“亚当”到“亚当 - 翻转”上悬停,但它不是加工。是否有可能完全在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); 
} 
+0

是你能解决你提供的答案之一的问题? – marionebl

回答

0

我想这里是你想要的。 fiddle

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

您需要transform属性的前缀。

而且.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

1

您的代码不起作用,因为它缺乏为transformbackface-visibility前缀。另外,您必须告诉.flipper的孩子保留应用于其上的3d变形并通过transform-style: preserve-3d(需要前缀)自动计算组合效果。

第二个问题:您必须在.flip-container.flipper上设置明确的width以确保图像围绕中心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/