 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。8 O6 X4 [8 C) F9 r3 H+ b" D. z) K
* M5 n( y& _+ ]+ P( O+ G0 ^
6 {8 J' J! r' W2 s1 b! ^' T8 r, P5 o* _
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。* y, @8 K9 N0 j
( }3 J& L+ Q7 _
为什么要开发这个程序?
) a2 {( u$ E; ^ D# l7 |" A5 i目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
: g! R( K2 C" o( _) p: ]; N3 ^9 e- Z# X
如何使用
0 Z' X' N( h) \ R$ h! |和标准 Windows 绘图程序一样。$ L9 v( @9 r! v2 S* v6 j3 G) C d4 W
( |/ v. m& {5 z: p! p& M9 s; q
能保存吗? : b' y) s. b/ m3 @/ r# L8 B
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。6 G$ K$ I6 Y5 R1 m1 @! l
8 t1 E3 {9 C/ S0 K& s. O
浏览器本身的右键菜单影响使用
* l, x0 C- J" M: O/ y3 X可以在浏览器的设置中禁用右键菜单。 v4 Q! K5 s0 y/ w8 Q: w
. l2 l% I) E! Y1 ]3 D# q4 J" Y
为什么有些功能不能用?
2 |( E7 e+ w( }' h一些功能支持特定版本的浏览器(译者注:这是就2006年而言):) Y2 } ^$ x6 P. u* I5 v# V0 [
7 y I. y \' LColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? : Q/ x, A- t8 W& ?, C0 B
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。' Y B& \" X( V5 \1 s; s
: Q# P" r0 B. Z5 `+ }, g5 Q技术细节 2 w$ e( }* S( M3 V1 ? _5 U; Z/ Z
程序中使用了 5 个 Canvas 对象。' f, y6 n# M: |- e' N
6 J. f" S s/ C: l6 K8 M一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。8 H9 z3 ?) {3 O
其他人的 HTML5 Canvas 实验
, K0 R( _! I2 w2 }Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
+ T9 v& x; ~1 O; ]& O/ NCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )* {9 \. Z6 X2 o1 i [2 x5 N3 q7 B
Image reflections (用 HTML5 Canvas 实现图像倒影)
. d5 [# c; U9 K% B( ^; D- zCanvas Painter (一个更为简单的 Canvas 画图程序)- C+ _+ G* E, z/ _& V
' W6 J0 t; w' F: a) @ @# s
真正令人赞叹的 HTML 画图程序 4 P% E, D7 A* `4 ]
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|