 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
1 [, `/ X, g5 ^" {( H, k" S, A4 v% d" r7 `3 b
& Y6 W0 s7 D' P/ A' z: M
$ h4 f( P# f4 w& c! ]CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
" f* t0 A" W1 e1 Z# l4 E' q; x, t: K$ b" @3 m! y( A
为什么要开发这个程序?
) b- O: X" t; t) m$ w( D目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
. l6 |9 N6 Z. k9 H7 R0 A: D w9 G2 d& T4 o% D- U8 U3 [" D
如何使用
0 k( m* U! L4 `4 d) b9 G8 q4 J和标准 Windows 绘图程序一样。
9 _1 _' E8 x* H: t" b7 n: Q0 ]! a8 ~
能保存吗? - V! _( `/ F, v! ]! Q9 Y
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。: t6 U$ C5 X1 [
. i- N* f% n% c2 `. \8 R+ f: K+ _+ x0 ]
浏览器本身的右键菜单影响使用 3 `6 L9 _6 n) ?/ ~* l9 L
可以在浏览器的设置中禁用右键菜单。1 g$ L) n" T: @! r8 x/ y
0 J& o, @+ S) Q' r' h" V8 `
为什么有些功能不能用?
- a, D9 g% T% [/ K' s一些功能支持特定版本的浏览器(译者注:这是就2006年而言):$ L3 ]# d7 n# y2 u) X; m
* J4 \: b5 q: ` `+ U( TColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? ; f' l- f1 X1 d
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。, H' j' G$ @- r6 n6 `
7 F0 G, ]3 {2 }' g9 J技术细节 3 Y, m( u6 w& y% w# ^6 `1 K8 d
程序中使用了 5 个 Canvas 对象。4 a6 H: f6 O. ?* D" i, |
1 e4 k# W l X' c+ h
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
. S3 o, h. r# I7 `, n其他人的 HTML5 Canvas 实验 1 O! S1 S+ O2 `5 J" ?4 M( x, O
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
3 k* S$ g) B- Z/ dCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
" n5 I8 z) Q( cImage reflections (用 HTML5 Canvas 实现图像倒影)
7 Z9 T) c. j: h7 P6 E% ^ r5 XCanvas Painter (一个更为简单的 Canvas 画图程序)
/ n* [0 V- C4 L5 ~$ v1 j' q/ h( T1 w, y3 ~3 c
真正令人赞叹的 HTML 画图程序 , M+ i/ p! w7 t9 |5 v' x9 I
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|