 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
, S7 L, A2 N% V6 l. F2 D y
4 }* ]) y" d! T1 |! p2 B4 b: d; ]6 x& u+ v: S, d
6 G5 [: t7 E. T0 a( ]+ o+ B9 H
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
5 C1 F+ F5 n% y: R2 O2 \* f6 D
2 ?* i1 B: V0 C1 k% E4 H( H' t8 |为什么要开发这个程序? / P8 J* m, N8 O& I- ]: u3 F
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
% a) H$ O3 t/ {7 }
% O7 M) y7 G9 i9 D$ u4 V3 o+ r如何使用
* f+ ~: {$ | }& S2 b, ?" k9 ?和标准 Windows 绘图程序一样。3 A+ a7 g& T) v
s3 L8 ^3 f: {( W: u5 g能保存吗?
. C7 S- K& c3 F' m8 { o是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
: y- a5 J& a1 s/ L6 a9 o: T6 ~8 F4 U- m
浏览器本身的右键菜单影响使用
; s" L! M5 A0 i! K w: S# S可以在浏览器的设置中禁用右键菜单。1 \6 t' B# {9 i8 V
. E0 J1 c: N, S; O( Y为什么有些功能不能用?
( s" N" M9 n0 _1 e' C6 B: T* F) c- V一些功能支持特定版本的浏览器(译者注:这是就2006年而言):# R5 X6 j8 M9 K, A4 m# v
. c# W; S, g" L. N; F2 W8 ~$ qColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
7 ], h) L3 `- f' K; Z对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。( S- `' Q$ n( k0 q2 r' N
# H* Z! ]) s0 R6 ?2 F
技术细节
: W" B2 \! q8 B3 j" _$ w程序中使用了 5 个 Canvas 对象。
% n1 P% u+ J/ x0 V. i
4 s& \- S- Q" g" f% i }一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。6 g( Y& }. Y. M& [6 a* L8 Q
其他人的 HTML5 Canvas 实验
3 a6 U" ?# _, R b% G- @' gCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
3 c3 f4 p+ e: [$ }CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
. Q; H0 [8 `4 V3 m2 EImage reflections (用 HTML5 Canvas 实现图像倒影)& m) j, g1 } w: _: r- O$ _" m( o
Canvas Painter (一个更为简单的 Canvas 画图程序)+ o- c' X/ X* ] m! E1 W
) p8 f/ }4 `+ n; O4 A* h" n; Q真正令人赞叹的 HTML 画图程序 7 V( p+ N3 }$ p: L6 G) S( @& A
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|