 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。% u* R3 a* O0 a8 x+ B$ t
# C, e2 I5 }" t( w& L9 x+ G
* C" s P6 w3 j1 D3 z# _4 F& {; U) H: q7 ?
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
7 z3 @9 t6 x2 m( l. g9 g4 J2 E3 u, W9 I. e" K
为什么要开发这个程序?
% Q& e/ p% V, ?' @2 g* ^, N) b目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
o/ F+ ]4 t1 x/ l' A2 s
8 D% `/ q* F+ q. y, b如何使用
+ w3 [' j- V/ [; W* }1 f; X和标准 Windows 绘图程序一样。4 w" D& ?$ t7 a$ _" b8 O
. L8 C: m# s4 Q* `+ M+ c
能保存吗? ! y7 o& y$ L' m1 `, I6 x
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
. p4 B: |0 g; u/ d5 U
: K" [2 O/ h9 S5 V( U: J浏览器本身的右键菜单影响使用 : m; w. y/ }/ a/ J( u& I
可以在浏览器的设置中禁用右键菜单。3 y" n0 n# q" O
|4 F7 x2 R' a# ]! J为什么有些功能不能用?
4 t$ l5 q/ B, a/ R( B; _$ z一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
1 ?" u% {4 E, S6 x+ C5 O. i0 D: ~$ V
& _4 V$ ~! G7 R1 P& g3 KColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
; _( Z0 X% J4 i; E" E/ T0 S对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。: }7 O* w( Y; l' m( T
, y, ^( K4 ~( ^. B* B2 E- X% y技术细节 * m5 N2 [6 Q' w6 y1 I" A
程序中使用了 5 个 Canvas 对象。
; }+ B7 L& v* J) V" x6 L6 G& x% f8 c8 n0 ]
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
1 e$ ~3 z- X+ z Q3 H( v! d其他人的 HTML5 Canvas 实验
$ o/ b& N' G( |/ L& H0 ?Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)5 ?% |8 }/ ^5 W
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
: P1 S6 ^/ U D0 d/ ^7 e' gImage reflections (用 HTML5 Canvas 实现图像倒影)
0 {# `' k6 ?6 d" g4 J: [# FCanvas Painter (一个更为简单的 Canvas 画图程序)
9 J# u: s; ^' {2 S- Q; o7 H
7 q9 T5 N9 P/ J5 R真正令人赞叹的 HTML 画图程序 2 |$ } f0 t! t7 y9 K: A
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|