2016-12-19 36 views
14

Firefoxで3D変換がZ-インデックスに問題があるようです。レンダリングは3D Z位置を「無視」し、単にDOMのz-インデックスを使用しているようです。興味深いことに、目に見える部分が小さくなり、ホイールの一部だけが見えるようになると、他のアーティファクトが現れ始めるが、Zインデックスは突然正しい。3D変換z-indexがfirefoxで壊れていて、preserve-3dが保存されていない

Firefoxで2011年以降に盗まれたこの交差点のバグのデモンストレーションがありますが、私のサークルは交差していないので、何とかして可能だと思います。 http://jsfiddle.net/yNfQX/21/

Firefoxのバグトラッカー:それのhttps://bugzilla.mozilla.org/show_bug.cgi?id=689498

.perspective { 
 
    width: 400px; 
 
    height: 400px; 
 
    position: relative; 
 
    perspective: 3000px; 
 
    display: block; 
 
} 
 
.dcw { 
 
    width: 100%; 
 
    height: 100%; 
 
    position: absolute; 
 
    transform-style: preserve-3d; 
 
} 
 
.dc { 
 
    top: calc(50% - 44px); 
 
    left: calc(50% - 44px); 
 
    margin: auto; 
 
    border-radius: 50%; 
 
    position: absolute; 
 
    cursor: pointer; 
 
    transform-style: preserve-3d; 
 
    width: 88px; 
 
    height: 88px; 
 
    border: 1px solid black; 
 
}
<div class="perspective"> 
 
    <div class="dcw"> 
 
    <div class="dc" style="background-color: rgba(255,0,0,1);transform: rotateZ(0deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(251,4,4,1);transform: rotateZ(10deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(248,7,7,1);transform: rotateZ(20deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(244,11,11,1);transform: rotateZ(30deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(241,14,14,1);transform: rotateZ(40deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(237,18,18,1);transform: rotateZ(50deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(234,21,21,1);transform: rotateZ(60deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(230,25,25,1);transform: rotateZ(70deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(227,28,28,1);transform: rotateZ(80deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(223,32,32,1);transform: rotateZ(90deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(219,36,36,1);transform: rotateZ(100deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(216,39,39,1);transform: rotateZ(110deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(212,43,43,1);transform: rotateZ(120deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(209,46,46,1);transform: rotateZ(130deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(205,50,50,1);transform: rotateZ(140deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(202,53,53,1);transform: rotateZ(150deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(198,57,57,1);transform: rotateZ(160deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(195,60,60,1);transform: rotateZ(170deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(191,64,64,1);transform: rotateZ(180deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(187,68,68,1);transform: rotateZ(190deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(184,71,71,1);transform: rotateZ(200deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(180,75,75,1);transform: rotateZ(210deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(177,78,78,1);transform: rotateZ(220deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(173,82,82,1);transform: rotateZ(230deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(170,85,85,1);transform: rotateZ(240deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(166,89,89,1);transform: rotateZ(250deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(163,92,92,1);transform: rotateZ(260deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(159,96,96,1);transform: rotateZ(270deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(155,100,100,1);transform: rotateZ(280deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(152,103,103,1);transform: rotateZ(290deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(148,107,107,1);transform: rotateZ(300deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(145,110,110,1);transform: rotateZ(310deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(141,114,114,1);transform: rotateZ(320deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(138,117,117,1);transform: rotateZ(330deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(134,121,121,1);transform: rotateZ(340deg) translateX(125px) rotateX(-60deg); "></div> 
 
    <div class="dc" style="background-color: rgba(131,124,124,1);transform: rotateZ(350deg) translateX(125px) rotateX(-60deg); "></div> 
 
    </div> 
 
</div>

JSFiddle:それは(Chromeからのスクリーンショット)のようになりますどのように https://jsfiddle.net/gvquf0g6/

How it should look like (screenshot from Chrome):

のzインデックスの問題(Firefoxのからのスクリーンショット):

z-index issue (screenshot from Firefox)

アーティファクトの問題、そして部分的に目に見えるホイールで働いZインデックス(Firefoxのからのスクリーンショット): enter image description here enter image description here

移動お使いの成果物(欠けているブロック)の上にマウスを置くと、最初にレンダリングされたときのように表示されます。

+1

フム、部分的にしか動作しているようですChromeの私のために。 macOS 10.12.2、Chrome 55.0.2883.95(64ビット) [working](https://snag.gy/D8f9K0.jpg)と[not](https://snag.gy/6TdINf.jpg)です。 – Coder256

+1

Firefox 53では、[バグ1274673](https://bugzilla.mozilla.org/show_bug.cgi?id)のため、[このように]見える(https://i.stack.imgur.com/EE77F.png) = 1274673) – Oriol

+1

@Oriol - "解決済み"フラグが成立することを願っています。 2016年12月13日に[50.1.0](https://www.mozilla.org/en-US/firefox/50.1.0/releasenotes/)が最近リリースされて以来、どれくらいの期間、53歳になったのですか? –

答えて

6

残念ながら、Zオーダーは循環レイヤでうまく機能しません。 Firefoxが現在処理していない既知の問題です。これは古いFirefoxのバグで、ブラウザでバグを修正するまで修正できません。

2

私は解決策を見つけましたが、私が望むものではなく、どちらも完璧ではありません。アーティファクトが現れ、移行でアニメーション化すると多くの問題が生じます。しかし、静的な "イメージ"としてはうまくいくようです。

基本的に、円は青い半分に1回、緑色の半分に2回描画されますが、その半分が表示されます。

クロムでは、壊れている、解決することができました...しかし、私はfirefoxについてのみ気にしました。 (そしてこれは、コーディング本当に迅速かつ汚れていた、私はちょうど...再びその上に見て、二重の宣言された関数drawCircle2に気づい) https://jsfiddle.net/7w31uLsL/

$dcw = $(".dcw"); 
 
var newElement; 
 
var center = 300; 
 
var distance = 200, 
 
    color; 
 
for (var i = 0; i < 360; i = i + 10) { 
 
    color = 20 + Math.round((128/360) * i); 
 
    color2 = 220 - Math.round((128/360) * i); 
 
    
 
    $(drawCircle2(color,color2,i,distance)).appendTo($dcw); 
 
} 
 

 
function drawCircle2(color,color2,rotation,distance) { 
 
\t return '<div class="circle" style="transform: translate3d(0,0,0) rotateZ(' + rotation + 'deg) translateX('+distance+'px) rotateX(10deg);">' + 
 
    '<div style="background-color: rgba(' + color + ',0,0,1);"></div>' + 
 
    '<div style="background-color: rgba(' + color + ',0,0,1);"></div>' + 
 
'</div>'; 
 
} 
 

 
function drawCircle2(color,color2,rotation,distance) { 
 
\t return '<div class="circle2" style="background-color: rgba(' + color + ',0,0,1);transform: translate3d(0,0,0) rotateZ(' + rotation + 'deg) translateX('+distance+'px) rotateX(10deg);">' + 
 
'</div>'; 
 
}
.color-wheel { 
 
    width: 600px; 
 
    height: 600px; 
 
    position: relative; 
 
    perspective: 3000px; 
 
    display: block; 
 
} 
 

 
.dcw { 
 
    top: 0; 
 
    bottom:0; 
 
    height: 100%; 
 
    width: 50%; 
 
    position: absolute; 
 
    transform-style: preserve-3d; 
 
    overflow:hidden; 
 
} 
 
.dcw:first-child { 
 
    right:50%; 
 
    left:0; 
 
} 
 
.dcw:last-child { 
 
    right:0; 
 
    left:50%; 
 
} 
 

 
.dcw:first-child .circle2 { 
 
    left: calc(100% - 94px); 
 
} 
 
.dcw:last-child .circle2 { 
 
    left: calc(0% - 94px); 
 
} 
 

 
.circle2 { 
 
    top: calc(50% - 94px); 
 
    margin: auto; 
 
    position: absolute; 
 
    cursor: pointer; 
 
    transform-style: preserve-3d; 
 
    width: 188px; 
 
    height: 188px; 
 
    border-radius:50%; 
 
    border:1px solid black; 
 
} 
 
.circle { 
 
    top: calc(50% - 94px); 
 
    margin: auto; 
 
    position: absolute; 
 
    cursor: pointer; 
 
    transform-style: preserve-3d; 
 
    width: 188px; 
 
    height: 188px; 
 
    border-radius:50%; 
 
    border:1px solid black; 
 
} 
 
.circle div { 
 
    left:0; 
 
    right:0; 
 
    position: absolute; 
 
    transform-style: preserve-3d; 
 
    width: 100%; 
 
    height: 50%; 
 
} 
 
.circle div:first-child { 
 
    
 
    border-top-left-radius:1000px; 
 
    border-top-right-radius:1000px; 
 
    top: 0; 
 
    bottom:50% 
 
} 
 
.circle div:last-child { 
 
    border-bottom-left-radius:1000px; 
 
    border-bottom-right-radius:1000px; 
 
    bottom: 0; 
 
    top:50%; 
 
}
<script type="text/javascript" src="//code.jquery.com/jquery-git.js"></script> 
 
<div class="color-wheel"> 
 
    <div class="dcw" style="background-color:blue;"> 
 

 
    </div> 
 
    <div class="dcw" style="background-color:green;"> 
 

 
    </div> 
 
</div>

関連する問題