 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
+ t7 G0 t* `5 n) z0 a1 S
- R' J' Y" v, g* K) f0 a: [0 o2 z# x
2 I9 ?3 p8 L: r# G; G4 a2 ?! z p8 f7 A
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。3 a. T; o" z3 t# z7 q+ K- k# o9 E
8 `- }9 D$ P7 D# M& G# _
为什么要开发这个程序? . W$ I% a. {0 Q' P. t
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
2 ]% o& k2 ^/ n. |6 z0 o+ }7 A1 V
# b9 f1 A! v' M" Z$ c$ |如何使用
8 `5 X: n, J1 U- }2 y* U1 Y和标准 Windows 绘图程序一样。
: R( U% ?4 N; p
' u5 M' Q2 P" m, N+ X1 q3 o能保存吗? & B/ N% }8 b. B1 n% m$ o$ e C. h* C
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
8 h8 ^' B8 R# S1 i: _9 V9 P( p1 y6 a" P# L7 X2 k
浏览器本身的右键菜单影响使用 }- K9 _6 |1 R" V7 ~
可以在浏览器的设置中禁用右键菜单。
+ r( K9 F( V/ b+ ]% ?# \0 m# a+ m/ A
: Z6 F6 [. A! \% b) O8 v) H为什么有些功能不能用? ' g( i" X" O t. q; g
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
9 v% X* `! g+ {# l+ I6 A0 {2 Q+ \( x
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 3 r# [5 e3 u; X0 b" L# M$ C
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。; ^* S$ m& z t# C
, {- x! e' `$ G3 t8 J" A
技术细节 6 l5 l4 R7 _ v7 E& c
程序中使用了 5 个 Canvas 对象。- x1 M) v0 ~; m; p
; l( W0 V" B, H1 T一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
`) d. c2 B! \8 c" N其他人的 HTML5 Canvas 实验
0 u+ `2 Z" T* F0 e) `/ VCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)4 h. L) J8 L/ w. K6 n
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )2 L, K7 ?/ n( b
Image reflections (用 HTML5 Canvas 实现图像倒影)
- x' X$ z- q" t0 x {4 B/ m# a6 dCanvas Painter (一个更为简单的 Canvas 画图程序)0 \; _* N, z/ k/ r( `0 t
0 m8 ?5 T5 t3 b真正令人赞叹的 HTML 画图程序 2 z- }& Z7 y( N) X- O
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|