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

HTMLCanvas

問題発生

 状態:-  閲覧数:1,059  投稿日: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 navタグで定義している部分だけCSSが効かない【html5】 33
2 positionプロパティのrelative指定は、デフォルトではない 29
3 rssページが正しく表示されない/Google Chrome 28
4 Firefoxで画像が表示されない 27
5 Chromeデバッグする際CSSが()で表示される 27
6 textareaを手動リサイズできない時は、ブラウザを落としてみる 27
7 レイアウトがどうしても崩れるときは、div marginへマイナス値が設定されていないか、確かめる 26
8 Braveインストールしてみたけれども、全ての広告を必ず非表示に出来るわけではないみたい 26
9 bootstrap3で意図せず横スクロールバーが表示される場合は、containerクラスの入れ子を疑う 26
10 box-sizingは危険なCSS / レイアウトや位置がどうしても意図した通り設定できない場合は、box-sizingを疑う 25
11 Chrome プロファイルが壊れている、と毎回表示されるが、英語なのでどうしたら良いか分からない 24
12 サムネイル画像にpadding指定してはいけない。特に文字列を埋め込んだ画像では 24
13 トリミングする際、範囲を決定する入力ボックスが表示されなかったら 24
14 divタグがdisplay:block;とかしても、ブロック要素にならないときは、 24
15 SVG表示サイズ 24
16 指定兄弟要素(h1~h5タグ何れか)のmarginを取得して、指定要素に適用させたい 24
17 ドロワーメニューが表示されない理由 24
18 HTML5では、inputタグの閉じタグを付与しない 24
19 HTMLで「1つのタグにidを複数指定」は出来ない! 24
20 「z-index」が効かない時は「-1」を指定してみる 23
2021/8/06 1:36 更新
週間人気ページランキング / 7-30 → 8-5
順位 ページタイトル抜粋 アクセス数
1 RGB ⇔ Lab | 色変換(色) 39
2 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 27
3 RGBの種類 / ビットカラー | RGB(色) 23
4 血の色 / #b30000 / #360800 / #ff0000 | 色 22
5 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 21
6 Design 0 17
7 HSLとHSVの違い | 色変換(色) 16
8 「属性」「プロパティ」「アトリビュート」の違い | CSS 13
9 HTML5では、「input 要素」「button 要素」を「フォームタグ」の外で直接記述しても良い | HTML5(HTML) 12
9 使用していないCSSをチェックする、標準的な方法を知りたい | CSS 12
9 コズミックブルーが何色か分からない | 色 12
10 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 11
10 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 11
10 「bgcolor」「background-color」「background」の違い | CSS 11
10 アドベンチャーゲーム系の素材をどうやって用意するの? | イラスト素材(デザイン) 11
11 16進数カラーコード / 2進数 9
12 画面キャプチャ | Chrome 拡張機能(ブラウザ) 8
13 キャラクター無料作成ジェネレーター / FLASH / オンラインサービス | イラスト参考(デザイン) 7
13 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 7
13 「line-height」効果を打ち消すスタイルシートは、「line-height:normal; 7
2021/8/6 1:03 更新