Canvas図形が指定サイズで表示されない時は、CSSではなくCanvasタグで指定

HTMLCanvas

問題発生

 状態:-  閲覧数:2,416  投稿日:2014-06-07  更新日:2014-06-07
謎の挙動
・下記コードを試したら、びっくりするぐらい謎の挙動を示して悩む
・以前のIEバグを連想するぐらい、指定サイズと表示サイズが異なる
・縦横比もおかしくなり、描画した図形が縦に伸びてしまう

・HTML
<canvas id="stage"></canvas>


・CSS
#stage{
 width:600px;
 height:600px;
}

 
・JavaScript
var canvas=document.getElementById("stage");
var ctx=canvas.getContext("2d");
ctx.fillStyle="yellow";
ctx.fillRect(0,0,50,50)



原因


・Canvasのwidth/heightを、CSSで指定したから


対策


・Canvas要素のwidth/heightは、CSSではなくCanvasタグで直接指定する
<canvas width="600" height="600" id="stage">



感想


・なめてんじゃねーよ、てくらい頭に来た
・何なのこの仕様?
・CSSバカにしてるの?
・HTML直書は避けようとするから、これ普通にハマるよね?

Canvas要素
・width … 初期値300
・height … 初期値150

・初期値云々の話ではない
・サイズだけではなく比率も変わってくる時点で、CSS指定は全く使えない

・これ調査するのにかかった3時間と、「何なのコレ?全然分からん」とブルーになる前の「土曜の朝のいい感じだった気持ち」を、誰か返してくれー


<canvas> 要素。width と height 属性を指定しなかった場合、(内容のいかんに関わらず)幅 300 ピクセル、高さ 150 ピクセルで表示される



類似度ページランキング
順位 ページタイトル抜粋
1 Canvas図形が指定サイズで表示されない時は、CSSではなくCanvasタグで指定 64
2 navタグで定義している部分だけCSSが効かない【html5】 33
3 「直後が A 要素 でない B 要素」を指定するCSSセレクタは、「A:not(:has(+ B)) {}」 29
4 positionプロパティのrelative指定は、デフォルトではない 29
5 rssページが正しく表示されない/Google Chrome 28
6 Firefoxで画像が表示されない 27
7 Chromeデバッグする際CSSが()で表示される 27
8 textareaを手動リサイズできない時は、ブラウザを落としてみる 27
9 レイアウトがどうしても崩れるときは、div marginへマイナス値が設定されていないか、確かめる 26
10 FontAwesomeでアイコンが□(四角)になって表示されない Forbidden  26
11 Braveインストールしてみたけれども、全ての広告を必ず非表示に出来るわけではないみたい 26
12 bootstrap3で意図せず横スクロールバーが表示される場合は、containerクラスの入れ子を疑う 26
13 box-sizingは危険なCSS / レイアウトや位置がどうしても意図した通り設定できない場合は、box-sizingを疑う 25
14 Chrome プロファイルが壊れている、と毎回表示されるが、英語なのでどうしたら良いか分からない 24
15 サムネイル画像にpadding指定してはいけない。特に文字列を埋め込んだ画像では 24
16 トリミングする際、範囲を決定する入力ボックスが表示されなかったら 24
17 divタグがdisplay:block;とかしても、ブロック要素にならないときは、 24
18 SVG表示サイズ 24
19 CSSで直前の要素を取得するセレクタはない。ので、直後の要素を取得してマイナス設定値を指定しました。 24
20 指定兄弟要素(h1~h5タグ何れか)のmarginを取得して、指定要素に適用させたい 24
2026/4/23 7:40 更新
週間人気ページランキング / 4-16 → 4-22
順位 ページタイトル抜粋 アクセス数
1 Design 0 25
1 「Default User」を削除したら、既存ブックマークが削除されてしまった! 25
2 Illustratorでaiファイルを保存する際、下位バージョンでも開けるよう保存する | Illustrator CS3(Illustrator) 17
2 「.aiファイル」を下位バージョンで保存するための操作手順 / OS 上で「.aiファイル」から「作成したIllustratorバージョン」を確認する方法 / 下位バージョンのIllustratorで開く方法 17
3 CSSだけで、任意の要素に配置した画像を画面一杯に表示することは、基本的には出来ない。「img src」「背景画像」「div要素」何れの場合でも。可能なのは、特殊な要件が重なった場合だけ | CSS 11
4 Material Design 2014 年 | Material Design(色) 9
4 Adobe Camera Raw 4.0 | Photoshop 9
5 RGBの種類 / ビットカラー | RGB(色) 7
6 「属性」「プロパティ」「アトリビュート」の違い | CSS 5
7 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 4
7 RGB → 色相H … 最小値基準 × 図形 の考え方 | 色変換(色) 4
7 アイコン | 3系(Bootstrap) 4
7 キャラクター無料作成ジェネレーター / FLASH / オンラインサービス | イラスト参考(デザイン) 4
7 「東京都」のカラーコード取得は難しい | カラーコード(色) 4
8 拡張機能が Chrome によって無効にされました / この拡張機能は破損している可能性があります。 | Chrome 拡張機能 3
8 一つの要素に対して「id 属性値」を複数指定することは出来ない | HTML 3
8 Chrome拡張を作る | Chrome 拡張機能 3
8 謎の現象 / 「Photoshop CS」と「Photoshop CCでは」では扱いが異なる /「PhotoShop CS3」で「Camera Raw 4.0」を起動するには? 3
8 Photoshop無料アクションファイル(atn)導入見送り | Photoshop 3
8 ログイン 3
2026/4/23 5:05 更新