 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。7 a; h' S9 ^6 `, D
0 ~ ]+ J( f/ c1 h8 ]! d! p E2 E
+ u3 Y5 e0 T7 x0 G# \% _+ T3 ]! B
) C0 t' [5 M2 f) o1 N3 ^CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
' a+ y7 W, L" b; g+ r, G% b9 l" @
为什么要开发这个程序?
; N4 Z8 q; K- m0 I, H5 w目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
# U% t' J" r+ i0 b& r% S; L4 t
如何使用
7 F. J5 m( d0 H9 `! ^和标准 Windows 绘图程序一样。
% _& J- D; ?& V0 I
& U# |1 \1 c- w/ k能保存吗? % P' [) Z2 ?/ K' o; e( `, I; U
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
( r; Y- C2 o- Z4 t. h1 M% L8 M: z! T) P7 P9 X0 A9 X) c' W( `
浏览器本身的右键菜单影响使用 9 r* i3 T: [7 E9 I D2 O
可以在浏览器的设置中禁用右键菜单。9 u: E9 O+ ~6 f5 k/ d
4 {# b( {' ?' f& Y# g6 s) o# c为什么有些功能不能用? ) `2 H, R- n1 f( n! I
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
3 A& b1 {6 ^5 Y* j+ c( H7 t7 x. ] [5 u3 E6 t# l4 y
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
% H. H# D" N' X: C对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
9 ]* C1 X, e8 L s2 d0 E2 f% N3 ?
& q2 C+ h- O! ~) `8 _- D6 G技术细节 6 K9 T1 V# j! P2 d S9 C1 m
程序中使用了 5 个 Canvas 对象。 o9 `" B2 V, T' H8 G) ^& n0 H2 ~
+ _/ i3 U F K+ E' r
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。1 ]/ T" h1 I1 m# X, N( \1 ~5 m$ |
其他人的 HTML5 Canvas 实验 ( `* W' |( x' `3 i8 |/ D$ _
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
3 f! n) z! O" j5 f; o% nCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
I$ L) o7 B, j4 L" C" y' SImage reflections (用 HTML5 Canvas 实现图像倒影)
* P! N7 S( S) p6 mCanvas Painter (一个更为简单的 Canvas 画图程序)
& @. ^/ V# P& o, V1 r& C9 @; K
2 c+ `' Q/ \4 E6 j" G; c* I+ ^2 h真正令人赞叹的 HTML 画图程序 + ?( G. {. |9 c: Q9 c, y( x! I3 w
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|