2014-04-03 6 views
10

Ich versuche, einen Würfel mit CSS3 3D zu bauen Transformation ..CSS3 3D-Transformieren nicht auf IE11 funktioniert

ich für dieses Beispiel habe nur zwei Gesichter:

<section id="header-cube-container"> 
    <div id="header-cube"> 
     <figure></figure> 
     <figure></figure> 
    </div> 
</section> 

mit jedem anderen Browser Ich bekomme ein gutes Ergebnis, aber es ist seltsam mit IE 11.

Ich habe eine gute 3D übersetzen und drehen auf dem grünen Gesicht (1), aber das rote Gesicht (2) senkrecht zeigt nicht in 3D. Es ist nur die Projektion des roten Gesichts auf dem grünen Gesicht.

Result on Chrome and IE

Sie können auf dieser fiddle das Ergebnis sehen.

PS: Ich mache eine Drehung von 100 Grad und nicht 90, um die Projektion des roten Gesichtes auf dem grünen Gesicht zu sehen (wenn der Winkel 90 war, ist die Projektion nicht sichtbar).

Danke euch allen!

Antwort

16

IE unterstützt transform-style: preserve-3d noch nicht.

Sie müssen die Transformation von #header-cube entfernen und sie auf jeden der figure Kinder anwenden. Leider verwendet IE bereits die Eigenschaften ohne Präfix, so dass Sie entweder transform-3d überhaupt nicht verwenden können oder die Präfixeigenschaften zuletzt definieren müssen.

Vom IE transforms documentation:

Zu diesem Zeitpunkt Internet Explorer 10 nicht das preserve-3d Schlüsselwort nicht unterstützt. Sie können dies umgehen, indem Sie die Transformation des übergeordneten Elements manuell auf jedes untergeordnete Element anwenden, zusätzlich zur normalen Transformation des untergeordneten Elements .

JSFiddle: http://jsfiddle.net/TTDH7/17/

#header-cube { 
    transform-style: preserve-3d; 
    transform: rotateX(43deg) rotateZ(130deg); 
} 
figure:nth-child(1) { 
    transform: translateZ(-16px); 
} 
figure:nth-child(2) { 
    transform: rotateY(-100deg) translateZ(-16px); 
} 

wird:

#header-cube { 
    transform-style: preserve-3d; 
    -ms-transform-style: none; 
    transform: rotateX(43deg) rotateZ(130deg); 
    -ms-transform: none; 
} 
figure:nth-child(1) { 
    transform: translateZ(-16px); 
    -ms-transform: rotateX(43deg) rotateZ(130deg) 
        translateZ(-16px); 
} 
figure:nth-child(2) { 
    transform: rotateY(-100deg) translateZ(-16px); 
    -ms-transform: rotateX(43deg) rotateZ(130deg) 
        rotateY(-100deg) translateZ(-16px); 
} 
+0

Ho Gott es Ihnen danken! Das ist eine gute Antwort = D – Arthur

+2

preserve-3d ist derzeit in Entwicklung. Um den Status zu verfolgen, siehe https://status.modern.ie/csstransformspreserve3d?term=preserve –

+4

Zwei Jahre später ... Das ist immer noch wahr. Vielen Dank für diese Antwort, die mir eine Menge Zeit erspart hat. ;) +1 –