「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > キャンバス画像が描画されないのはなぜですか?非同期画像読み込みの重要性。

キャンバス画像が描画されないのはなぜですか?非同期画像読み込みの重要性。

2024 年 11 月 8 日に公開
ブラウズ:168

Why Does My Canvas Image Not Draw? The Importance of Asynchronous Image Loading.

描画前に画像のロードを待機しています

画像をキャンバスに追加しようとするときは、画像を描画する前に画像がロードされていることを確認することが重要です。それを描こうとしている。コードで発生した問題は、イメージ読み込みの非同期的な性質が原因です。

この問題を解決するには、イメージの onload イベントにコールバック関数を追加する必要があります。このコールバック関数は、画像の読み込みが完了したときに実行され、描画を試行する前に画像データが利用可能であることが確認されます。

以下の修正されたコードは、画像がロードされるのを待ってからキャンバスに描画します。 :

var canvas = document.getElementById('viewport'),
    context = canvas.getContext('2d');

make_base();

function make_base() {
  base_image = new Image();
  base_image.src = 'img/base.png';
  base_image.onload = function() {
    context.drawImage(base_image, 100, 100);
  };
}
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3