 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
8 R" }2 ^1 C0 e( m$ o9 Y& W
) J( m7 x/ V- g8 |3 t1 I, O I6 N4 t% Q, W; Y' I
/ x. H8 D5 d5 G: z" c
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
# [+ D- l) y+ t# x* z; v6 P
- u8 }# l6 S6 }为什么要开发这个程序?
W1 {! _5 Y6 ~7 Z6 K2 q& K( w7 h% y目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
x7 v5 d; T0 f' a7 e2 z( Q3 N& h* Y0 F# h
如何使用 % O, x* N& r+ D
和标准 Windows 绘图程序一样。
- l" [" j2 E; S0 W- O
0 O0 H# V+ |3 V& P9 t- W' v能保存吗?
$ ?. S+ Q5 m6 R0 { s4 m0 [是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
4 h! |4 m" A' a( _, P& ^% Z0 _9 \; v3 O4 i) M M/ o
浏览器本身的右键菜单影响使用 & J9 H* d% v+ z! G( r" |5 f0 c7 G
可以在浏览器的设置中禁用右键菜单。
: C% W& \8 I h8 A1 J/ E# H9 ~: b& K q- o
为什么有些功能不能用?
6 @# `- \7 {+ G* p9 a+ f一些功能支持特定版本的浏览器(译者注:这是就2006年而言):0 z( @: k) l+ S8 l$ Z6 k
5 B( n2 S8 [7 K1 [. f. w( u
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
+ H5 ^. n4 }- Q! n7 g* y对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
1 A1 @/ k, p# e6 d; h( `& N- d* q% A; ?9 K
技术细节
7 h+ q$ G3 m" ~3 P' D程序中使用了 5 个 Canvas 对象。& _/ l( o1 W5 I+ X* M- W
- p2 l2 Y! m' w* m, s6 Z' G一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
/ T8 O+ f! Q) Z4 y0 s/ L. @其他人的 HTML5 Canvas 实验
1 Q- }3 i" ?6 {9 s" w P; f; ?8 ICanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)8 K0 f6 g0 M; R, ?1 U |. |
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
7 E9 S- ^$ p, ?+ R( J9 wImage reflections (用 HTML5 Canvas 实现图像倒影)3 l/ I; v6 D0 Z7 [$ g
Canvas Painter (一个更为简单的 Canvas 画图程序)
+ S3 L9 `4 ~1 k/ ~ `5 M
' ^7 _6 L. J8 t真正令人赞叹的 HTML 画图程序
% f7 ]4 X3 x. y4 \9 I5 c如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|