 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
1 D0 |% Z, ^9 f) j! s
8 t7 t' C3 M8 s* C% m4 f( ]3 H }) i7 q, F( c5 l4 Y7 F
! Z% `: O1 l3 L' i
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。$ }7 T( {7 U/ ?5 r) I
' f2 j6 h1 k Y6 |5 n6 z为什么要开发这个程序? # L, s' t: ~" ^" m2 d
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。6 E7 |# c$ M( c
, O3 Z( `6 w6 }% ^" L1 N5 ~" Q
如何使用 ) G! P! T8 J7 K( L, e' {
和标准 Windows 绘图程序一样。2 y; i& |- p* r' A: P9 v: E
, l* {. n7 J! @: g/ r2 P- C能保存吗? 7 a% N9 |7 I2 L8 ]6 \
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。- ?' O6 m1 s. ]9 a
+ p1 A" W. Q2 c9 \7 r/ B& Y4 J
浏览器本身的右键菜单影响使用
r' x4 F/ K% F0 I+ ^% H* X) x可以在浏览器的设置中禁用右键菜单。. H1 K; H' l ^' m3 e4 }' k
6 M; f6 B: l0 L7 A4 d为什么有些功能不能用?
2 ~/ {! B# s* r1 t: }一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
/ |, Q( Q' }; i U; ~8 l& Q# K! v+ |, h0 I3 w: i6 B
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 6 x/ U$ N& _0 z8 }; H
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。2 R" P5 q1 Y/ c. H3 ?9 g
) G1 }0 Y0 S5 m& ?7 N" i' L技术细节 ; ~, k9 y; |7 a g: I1 d. z8 D
程序中使用了 5 个 Canvas 对象。
9 W; I) Z3 L+ y% g W7 U; v- Y1 p4 w$ B1 \
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
0 i9 N; h4 B; V7 P! W/ G其他人的 HTML5 Canvas 实验
9 ~3 x7 k( Z8 Q" v9 V. j' QCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)9 ?2 }4 [ X! t& i9 x
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
& J" ?5 L+ b( y& G% y. KImage reflections (用 HTML5 Canvas 实现图像倒影)
4 L. e4 J K& ^Canvas Painter (一个更为简单的 Canvas 画图程序)
3 [; M) N8 f1 S$ O7 H2 x' h6 Z2 i4 V1 e$ J2 t- q
真正令人赞叹的 HTML 画图程序 " N2 N v& e9 T# p" t+ [, @
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|