Webkit 3D перспективные ошибки - PullRequest
1 голос
/ 15 января 2012

В последнее время я играю с браузерами, и теперь я борюсь с 3D.WebGL - это круто, и я тоже могу делать 3D в CSS3?Даже лучше!Итак, мое видение состояло в том, чтобы создать плавающие 3D-объекты, используя вложенные преобразования (с preserve-3d).

HTML

<div class="scene">
    <div class="box">
        <div class="side_1"></div>
        <div class="side_2"></div>
        <div class="side_3"></div>
        <div class="side_4"></div>
        <div class="side_5"></div>
        <div class="side_6"></div>
    </div>
    <div class="box">
        <div class="side_1"></div>
        <div class="side_2"></div>
        <div class="side_3"></div>
        <div class="side_4"></div>
        <div class="side_5"></div>
        <div class="side_6"></div>
    </div>
    <div class="box">
        <div class="side_1"></div>
        <div class="side_2"></div>
        <div class="side_3"></div>
        <div class="side_4"></div>
        <div class="side_5"></div>
        <div class="side_6"></div>
    </div>
    <div class="box">
        <div class="side_1"></div>
        <div class="side_2"></div>
        <div class="side_3"></div>
        <div class="side_4"></div>
        <div class="side_5"></div>
        <div class="side_6"></div>
    </div>
</div>

CSS (я использую префикс без)

.scene {
    perspective: 3500;
    perspective-origin: 25% 100%;
    animation: spin 15s infinite linear;
    transform-style: preserve-3d;
    width: 960px;
    height: 350px;
    margin: 80px auto;
}

.box {
    width: 150px;
    height: 180px; 
    position: absolute;
    transform-style: preserve-3d;  
    top: 40px;  
}
.box div {
    width: 150px;
    height: 180px;
    opacity: 0.75;
    background-color: #bada55;
    position: absolute;    
}
.box .side_1   { 
    transform: rotateY(   0deg ) translateZ( 75px );     
    background-color: #FF0;
}
.box .side_2   { 
    transform: rotateX( 180deg ) translateZ( 75px ); 
    background-color: #F00;
}
.box .side_3   { 
    transform: rotateY(  90deg ) translateZ( 75px );    
    background-color: #CCC; }
.box .side_4   {
    transform: rotateY( -90deg ) translateZ( 75px ); 
    background-color: #000;
}
.box .side_5   { 
    height: 150px;
    width: 150px;
    background-color: #00a2ff;
    transform: rotateX(  90deg ) translateZ( 75px ); }
.box .side_6   { 
    height: 150px;
    background-color: #00a2ff;
    width: 150px;
    transform: rotateX( -90deg ) translateZ( 105px ); }
.box:first-child {
    position: absolute;
    top: 40px;
}
.box:last-child {
    right: 0;
}
.box:nth-child(2) {
    background: url(../img/dot.jpg) repeat-y center center transparent;
    transform: translateZ( -600px );
    left: 480px;
}
.box:nth-child(3) {
    background: url(../img/dot.jpg) repeat-y center center transparent;
    transform: translateZ( 600px );
    left: 480px;
}

@keyframes spin {
    0%   { transform: rotateY(0); }    
    100%   { transform: rotateY(360deg); }
}

Все настроено и работает.Но подождите, что происходит?Почему дальний объект больше близкого?Я не понимаюЭто ошибка WebKit, или я что-то упустил?

http://stretchbox.org/projects/Nextgen/floaters.php - здесь у вас есть пример.

1 Ответ

2 голосов
/ 15 января 2012

.scene также вращается, поэтому вам необходимо применить перспективу и источник-перспективу к его родителю, который в вашем случае будет body.1005 *

http://jsfiddle.net/dw58P/embedded/result/

Отличный проект, кстати!

...