 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。3 t& z' `; N7 P! B3 i- f# z
# Z! K: X. D+ j( j$ `6 W
" l) q/ h0 m r! ]) ^5 c: z1 a
5 g. A4 ~! }: B; S
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
, k, A9 L& H4 d6 S1 E( U
- _& {( [ I, |为什么要开发这个程序? " }' V' u ?& {* G) d- N3 T- t$ @" ^
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。- r: W* X/ M2 w
" V' [' K. w5 B如何使用
/ T3 }. u% {+ q& Q3 u和标准 Windows 绘图程序一样。 ?! q9 `! ?: U: Q+ X+ u, A H7 k
; D" I# l! B8 o能保存吗? # f7 o# h" x, l0 }; n
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
# y9 J. a* E7 |! o1 r* A! V; K
- s- S! s' k6 D. Z# Y; |1 J. o, z浏览器本身的右键菜单影响使用
& P3 m% a3 b2 p4 ^可以在浏览器的设置中禁用右键菜单。. a" a( b1 l4 p" K
, c; @+ K i' z+ W- E为什么有些功能不能用?
" h* V0 N( v, \" {& C0 H一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
8 y: L( A2 M9 y
0 }+ m8 W L! T5 G) O- s U9 fColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? " I& N7 a3 z" N# g. ~
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
3 l2 P* J$ E9 r Q! @% V8 G2 F, Z( D5 |- R r2 C- f; N2 [0 o/ n
技术细节
% M9 H6 y3 ]1 z( Q* E# S程序中使用了 5 个 Canvas 对象。
2 k" R$ @& v% R2 u6 d, X
* D% T0 O- f' E' ]# |/ p8 f2 z一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。/ B! z2 q. }* I$ |
其他人的 HTML5 Canvas 实验 I, S5 h; J, a1 @9 R `- I. P# Y
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)4 \1 g& @1 [8 K8 q/ j5 D$ h1 S
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
2 Y1 H6 E# h: ` MImage reflections (用 HTML5 Canvas 实现图像倒影)8 t, @" V+ I2 [+ H- H, k' C
Canvas Painter (一个更为简单的 Canvas 画图程序)
) h& Y1 j* [. _ f. f# w
$ M0 r& x6 K0 K9 k( f$ S真正令人赞叹的 HTML 画图程序
9 x/ S1 c+ f; T8 O u如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|