12下一页
返回列表 发新帖

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

660.0k 15
swmozowtfl 发表于 2015-7-15 20:24:30|湖北 | 查看全部 阅读模式
以前用canvas画图时,都是直接在canvas标签里直接写上宽高,没有问题,但也没有探究过为什么宽高要直接写在canvas标签里,因为各个资料的例子上都是这么写的。今天王sir提出了一个问题:如果把宽高写在<style>里,看看会有什么不同。自己试了以下,果然有问题。
0 W2 N( B0 Y* Z1 l5 P0 X先看一下代码:1 u0 Y* a! R3 |% p6 X
代码如下:7 ^% M5 m1 v& I
<!doctype html>  ]6 K! [: B) P  M" P' n/ o9 n8 H4 n! ]
<html>
2 t0 U% n1 y% j3 [% b5 l<head>% `- E; p( k$ k! F
<meta charset=utf-8>& v, m6 l! S: V- a' L
<title>canvas</title>4 V6 Z! K, P3 X9 m! E8 |. E. g
<meta name=keywords content=>8 F% }4 @& ?& C) O
<meta name=author>- T* X6 m) K$ I' \
<style type=text/css>
; @; P4 \2 i4 f$ `6 Qbody{margin:0;}9 s2 D3 C0 P$ ^7 C; S- d) O
canvas{margin:20px;
  ~, I5 V$ m% D, G/*width: 400px;; @5 h4 |  S  |$ ]
height: 300px;*/: e1 S4 Z: t$ \4 Y$ K& T
}& i& {( @' i' G2 z+ B* s
</style>9 t+ K# n  W& X  T
</head>: }" \/ [- B" j& k- U( U( @- T
<body onload=draw()>4 a/ H7 C* x8 c* V+ F
<canvas id=canvas width=400 height=300 style=border:1px solid #f00;></canvas>, G8 g4 }2 S, O4 T( }* U. S
<script>
' i* V" j# A5 s& u" Q" w) @function draw() {' O" m% F! E6 L3 K6 w% z
var canvas=document.getelementbyid('canvas');
  R! l. I( N2 s9 w7 d, mvar context=canvas.getcontext('2d');, T' |8 c. ~5 A/ Z
context.beginpath();6 v) j' Y2 z3 \% `' T
context.moveto(20,20);
/ e6 Y- t! o8 O  t, P5 Y# m6 L' }0 lcontext.lineto(200,100);
1 E3 @$ A0 w' i# tcontext.linewidth=5;
6 d& E3 c, L# d; M3 h: F. m. rcontext.stroke();
+ Y2 l9 I1 Y5 }" ^0 }) Y, c9 e2 s: C}$ r( P9 |% C( W/ a" u  }/ X
</script>) S( ^7 P3 {- W8 P' n9 J4 j
</body>
3 j( d& m  i' A, y) H/ \3 L& h! E</html>% q; B+ u4 R" M; j: _
1.宽:400;高:300;直接写在<canvas>里的效果:- J/ }1 t' Y1 G# T$ @  Y8 v1 Y
名单
) E) e" u: F; d& x! I2、删除<canvas>里的宽高,宽:400;高:300;写在<style>里的效果:
( C- Q+ a7 g9 V4 ]) p7 b名单1
, t: ~9 Z0 J+ g& j) @# L  K8 P- ?! u为什么两者的效果会不一样呢?
& L0 }" J8 w+ j; h# lcanvas跟其他标签一样,也可以通过css来定义样式。但这里需要注意的是:canvas的默认宽高为300px * 150px,在css中为canvas定义宽高,实际上把宽高为300px * 150px的画布进行了拉伸,如果在这样的情况下进行canvas绘图,你得到的图形可能就是变形的效果。所以,在canvas绘图时,应该在canvas标签里直接定义宽高。6 J" i) K" f) v0 r& H+ C* c( J

& i$ G/ `! P' d0 y更多网页制作信息请查看: 网页制作

回复|共 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客服 返回顶部
快速回复 返回顶部 返回列表