12下一页
返回列表 发新帖

canvas需要在标签里直接定义宽高

660.0k 15
swmozowtfl 发表于 2015-7-15 20:24:30|湖北 | 查看全部 阅读模式
以前用canvas画图时,都是直接在canvas标签里直接写上宽高,没有问题,但也没有探究过为什么宽高要直接写在canvas标签里,因为各个资料的例子上都是这么写的。今天王sir提出了一个问题:如果把宽高写在<style>里,看看会有什么不同。自己试了以下,果然有问题。, O2 F# X4 k, J0 w& |
先看一下代码:
( c4 j) |8 Q* G代码如下:# u3 a/ ^3 B! |6 H# ?  l8 n4 S
<!doctype html>5 k, W% b$ h" i& R: w( @
<html>; [0 r& q) {0 @; a: Y5 W
<head>
4 W9 t. L5 l/ |; p. n<meta charset=utf-8>
9 O5 q* Y. n4 `% e; n3 ]- m- M<title>canvas</title>
8 h/ t; e# X) S8 O<meta name=keywords content=>; c2 s8 Z& n# l: v
<meta name=author>' \5 K- H2 G- b8 B4 Q! r% H: c, j
<style type=text/css>9 Q7 d6 P$ N+ \0 H6 g7 D
body{margin:0;}2 j1 Y: o( O) z# ]& }! j
canvas{margin:20px;
$ I& ?, E6 U& B/*width: 400px;+ [6 [% w' w8 j' u
height: 300px;*/
/ l: B6 z% _: {; y, [# O" G# {}; z, }' }' ^/ r
</style>
) c3 h, k# R  R1 V' k+ H</head>
9 i: O' @; x( f1 s/ H5 S$ Q" R<body onload=draw()>$ K' w0 d! I& d
<canvas id=canvas width=400 height=300 style=border:1px solid #f00;></canvas>$ ?" F. `! a$ x
<script>
- [# M# G1 r& r& K8 G$ F; x0 q! afunction draw() {" a$ |) ~8 [8 q/ U2 L
var canvas=document.getelementbyid('canvas');
( J5 Y8 K3 `3 Z9 Q" `var context=canvas.getcontext('2d');
  K) G* @. h( A* s& J. f7 a2 `& Scontext.beginpath();8 n$ ]. r) M7 V& B$ N  a
context.moveto(20,20);/ O0 s" }2 V- J# v' R# O  N5 @$ {
context.lineto(200,100);
4 A8 g1 O& i) ]0 econtext.linewidth=5;
& E4 C0 U& P2 X) E* D7 B2 [context.stroke();/ H; l# m% c" N* s. q0 ^" M) f
}+ n2 J+ A7 e& Y# S) _3 z
</script>* n4 h' B$ _* D5 v
</body>6 y  _$ M5 }/ i
</html>1 _7 z8 v: }. W% w3 T$ \7 s% S
1.宽:400;高:300;直接写在<canvas>里的效果:
; Z5 c7 O/ H3 _9 v! w名单8 S  T" H# G$ W" c" @  s- F
2、删除<canvas>里的宽高,宽:400;高:300;写在<style>里的效果:) X" a/ _/ X6 s
名单1' x  U( y4 X  ^6 |7 f0 J
为什么两者的效果会不一样呢?
/ y4 q4 y4 ^; l3 w+ Bcanvas跟其他标签一样,也可以通过css来定义样式。但这里需要注意的是:canvas的默认宽高为300px * 150px,在css中为canvas定义宽高,实际上把宽高为300px * 150px的画布进行了拉伸,如果在这样的情况下进行canvas绘图,你得到的图形可能就是变形的效果。所以,在canvas绘图时,应该在canvas标签里直接定义宽高。
# |, P: i3 {( c) N2 d, F/ k. l1 _! y  t! v5 t$ E8 |' b" p/ ^
更多网页制作信息请查看: 网页制作

回复|共 15 个

wwzcdenleclv 发表于 2015-10-22 21:49:59|日本 | 查看全部
本人过去、现在以及将来都不认识楼主,且自古以来与楼主无利益关系。楼主表述之事与本人无关
mwxny 发表于 2015-10-22 21:50:37|亚太地区 | 查看全部
哈哈~` 好久没有笑喽~
seazvyt 发表于 2015-10-22 21:50:00|美国 | 查看全部
呵呵~~~~你怎么老这样说~~~
wwzcdenleclv 发表于 2015-10-22 21:49:44|法国 | 查看全部
兄弟....表给偶丢丢哦....
alapScady 发表于 2015-10-22 21:50:28|INNA | 查看全部
想骂你.却不知道从何骂起.
buingeEvineus 发表于 2015-12-9 18:04:48|INNA | 查看全部
成长可以说已经是很幸福的了。但在另一方面,作者也不是温室里的花*,只能作些鸳鸯蝴蝶 的文章。在前面我已经说过了,这篇文章比形散神聚更胜一筹。诸位见过大风沙没有
seazvyt 发表于 2015-12-9 18:05:40|印度 | 查看全部
这就是我斗胆的一点粗略分析,每天睡觉以前,我都会把您的帖子再三拜读,拜读。
bqtklouu 发表于 2015-12-9 18:05:28|拉美地区 | 查看全部
什么什么啊??
effoggikeftor 发表于 2015-12-9 18:05:28|韩国 | 查看全部
貌似我真的很笨????哎
alapScady 发表于 2015-12-9 18:04:34|乌克兰 | 查看全部
还没崇拜过谁呢,满足一下愿望吧,谢谢!
Mqokjdvq 发表于 2017-4-11 11:38:40|非洲 | 查看全部
为了不让帖子沉得太快!!!为了人人知道这个~!! 我不是原创~!!但是我要把他发扬广大~!!!
wwdu926a 发表于 2017-4-11 11:35:34|Reserved | 查看全部
呵呵 大家好奇嘛 来观看下~~~~
effoggikeftor 发表于 2017-4-11 11:37:59|泰国 | 查看全部
我也不知道了~~你把我问蒙了 呵呵
wwdu926a 发表于 2017-4-11 11:36:41|台湾 | 查看全部
朕在自己的寝宫~~~~

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台|Ai技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表