 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。- h& j. g+ _- M y* l: K9 g3 T
+ ~2 d6 O8 L0 }# f; b1 w
# i9 N, J0 [$ a8 j( T6 u
) v0 Y+ \/ d9 z! Y
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
2 o2 J- A- l8 J: M8 p8 s
2 x2 P) B5 T; e" Z& O7 g为什么要开发这个程序?
! e' l4 W8 K6 O% ~0 w0 w目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。# Z; G# n- i: |. N0 S/ R3 r4 x
+ k+ P! i. v' S; q$ U
如何使用 % c, ?% A) r x; u$ w
和标准 Windows 绘图程序一样。0 o, T; R: ~0 f+ d
, m& \9 h8 u' W1 x/ t
能保存吗? . P( c% o7 U3 T& [7 i9 M( y& J
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
# _( i% g+ C8 ]7 l/ t
' ^2 e, B9 y0 Q% z! T' u$ W! l- k/ Q0 U浏览器本身的右键菜单影响使用
; K8 Z% h9 K+ b5 e可以在浏览器的设置中禁用右键菜单。
& R% {+ Q. l% p& J7 u
, X) O, T T( _2 J- q0 i$ B为什么有些功能不能用? 5 Z- u F0 p$ A \) @
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
! c& o: t& H5 G/ l- ~$ c8 ~. m9 Y
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? # ?5 F5 I6 h& I- j; @% z
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
1 v+ b1 f5 \0 I4 L; }* a: k0 Q
! ]% ]# Q1 E+ u9 W( [技术细节 . o2 x5 C; v/ A2 R3 ?/ Q, d2 }" X q
程序中使用了 5 个 Canvas 对象。 C3 V6 d- Z U" t% ?# i# l/ A9 A6 V
/ I% g6 M) y9 r* }' N8 A
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。/ l. \6 D+ R: Y( N: m9 ?$ q
其他人的 HTML5 Canvas 实验 0 N! Z: p5 v7 U0 B: L# C- o
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏): y9 ?5 o& F. B/ ]: P& @, S$ d
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )* n* _" M. W! N+ i# ?
Image reflections (用 HTML5 Canvas 实现图像倒影)
2 c# W! z3 x8 L8 uCanvas Painter (一个更为简单的 Canvas 画图程序)
3 P( ^# V: w& |1 Y8 t/ Y6 C, ~* d4 h" R
真正令人赞叹的 HTML 画图程序 ' c1 e& Q2 o) Y6 }0 U2 C! ^7 g2 a
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|