ChromeとFirefoxについて静的キャンバスと動的キャンバスの要素に違いはありませんでした。主にdrawImage()のピクセル数によって、現在のglobalCompositeOperation(コピー、ソースオーバーが最も速い)が遅くなります。しかし、ブラウザはフルページをレンダリングしなければならないので、キャンバスの下に伸ばした(背景の)イメージを置くことは悪い考えです。
キャンバスの属性width/heightとそのスタイルの幅/高さの属性には違いがあります。スタイルサイズを100%に設定した300×200ピクセルのキャンバスを使用できます。それでは、内部描画速度はブラウザーウィンドウのサイズと同じです。もちろん、表示品質が問題です。
blitting(drawImage)から描画(線、ボックス、円弧など)を分離して、アプリケーションで時間を消費するものを見つけることができます。長い間、複数のキャンバス(画像処理、ブレンドビデオなど)は必要ありませんdrawImage()を避けてください。要素ではなくあなたのコードは、組織的な目的に対処するのに役立ちます。
1024x600ピクセルの1 GHZ Netbookのフルスクリーン描画イメージ()は約10msecかかります。これを2回行うと、50Hzの表示レートを達成する方法がないことを意味します。 iPhoneやAndroidスマートフォンをターゲットにすると状況が悪化します。
キャンバスで古き良きダブルバッファリングを行う必要はありません。既に実装されています。必要なときにキャンバス要素の関連する(汚い)部分のみを自由に更新し、必要なmsecを得ることができます。
複数のキャンバスを使用する代わりに、異なるセクションの巨大なオブジェクトに対してすべての不可視操作を実行するオプションがあります。drawImage()はターゲットを指定し、ソースは同じです。デバッグ中に何が起きているのかを確認するのは簡単です。
詳細な回答ありがとうございます!私はいくつかの実験が順番に行われていると思いますが、新しい(ish)機能がたくさんあります。 – Illianthe