編集:この質問には、許可された 2 日間で、評判 500 の報奨金が与えられます。それまでに回答があれば、最初に投稿された修正の作成者にできるだけ早く評判が与えられます。
iOS5.1 と比較して、iOS6 では CSS3 変換のパフォーマンスが大幅に低下しているようです。一般性を失うことなく、iOS6 での次の例のパフォーマンスを iOS5.1 と同等に戻す修正を提供できれば、私の苦労して得た評判を得ることができます。この例は、iOS5.1 (iPhone 4 と 4S の両方) で問題なく動作します。iOS Chrome アプリには UIWebView が埋め込まれているため、このテストを実行するのに適しています。
現在、これらの要素はハードウェア アクセラレーションされているようですが、Apple の低レベル パイプラインにバグがあり、パフォーマンスが低下しているようです。ハードウェア アクセラレーションのいくつかの回避策を試しましたが、iOS5.1 で GPU を呼び出すと、iOS6 で大幅な速度低下が発生するようです。
animate 関数を次のように変更しても、バグは解決しません。
function animate(node) {
node.style.webkitAnimation = 'sample 5s infinite';
node.style.webkitPerspective = 1000;
node.style.webkitBackfaceVisibility = 'hidden';
}
iOS6 の専制政治と戦い、今ではひどく壊れたアプリケーションをリリースするのを手伝ってください。
<!DOCTYPE html>
<html>
<head>
<title>Animation Playground</title>
<style>
@-webkit-keyframes sample {
0% { -webkit-transform: translate3d(0px, 0px, 0px); }
10% { -webkit-transform: translate3d(0px, 0px, 0px); }
20% { -webkit-transform: translate3d(10px, 0px, 0px); }
40% { -webkit-transform: translate3d(10px, 10px, 0px); }
50% { -webkit-transform: translate3d(10px, 20px, 0px); }
80% { -webkit-transform: translate3d(20px, 20px, 0px); }
100% { -webkit-transform: translate3d(0px, 0px, 0px); }
}
</style>
<script type="text/javascript">
function fib(node, a, b) {
node.innerHTML = a;
setTimeout(function() {
fib(node, a + b, b);
}, 0);
}
function animate(node) {
node.style.webkitAnimation = 'sample 5s infinite';
}
function createNode(row, column) {
var node = document.createElement('div');
node.style.width = '7px';
node.style.height = '7px';
node.style.position = 'absolute';
node.style.top = 30 + (row * 9) + 'px';
node.style.left = (column * 9) + 'px';
node.style.background = 'green';
return node;
}
function run() {
for (var row = 0; row < 20; ++row) {
for (var column = 0; column < 20; ++column) {
var node = createNode(row, column);
document.body.appendChild(node);
animate(node);
}
}
var output = document.getElementById('output');
fib(output, 0, 1);
}
</script>
</head>
<body onload="run()">
<div id="output" style="font-size: 40px; position: absolute; left: 220px;"></div>
</body>
</html>