 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
: ]& w) J J$ I: S7 _4 V2 \0 _/ C
/ @" y& u: M. M7 Z
+ f% Z% I8 @" k: Y& `. m! q5 B8 V
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
. V9 J7 ?3 d2 Q- p& ]; C1 x
4 Q1 Z; |5 @1 g0 h5 x# j( T" I) c9 m5 K2 s为什么要开发这个程序? 9 ~8 g# h5 ~5 o& O
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
4 \# ]( x; L! I: G5 Z4 E
) u3 }6 [. M3 q/ p2 w. K如何使用 6 T1 @, {" u& j
和标准 Windows 绘图程序一样。
" J6 r, c; \0 Y9 l7 I- o. q- [1 ?3 Y2 G& ?% P7 \ i9 N4 w* E6 Y
能保存吗?
4 \7 T/ ~; k' z+ C" A; f; Y是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
' l* F0 C* b1 y2 x& P( u& d z
' u) `& I! w' n% H5 X0 I浏览器本身的右键菜单影响使用 ' O, J/ ~; h8 u( D2 j
可以在浏览器的设置中禁用右键菜单。
# p$ ^; [( }. J" D
9 ^6 O, @6 q+ [4 V }3 k8 S为什么有些功能不能用? 9 i6 y+ T0 r/ w( u7 S' o
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):8 x2 F, h! d/ f6 q3 _6 N/ M
+ R) T. K! B% v1 V5 R# B. N* i% {Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? ) e5 w( A9 \9 Y) c/ y
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。0 \" [6 a( y* J+ \
3 g" p! R# P) x, g% I+ x技术细节 % b# ?0 J0 N& F' B$ ~
程序中使用了 5 个 Canvas 对象。
y! ^1 W: j# F, E
, L/ b. U/ w, h. n一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
/ b. @% i; C* f; I9 _5 c其他人的 HTML5 Canvas 实验 / ]1 S! w+ x/ E1 F! }: W
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
9 ]* I' m8 i4 @' {+ I9 rCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )( U; v8 c$ ], b- i
Image reflections (用 HTML5 Canvas 实现图像倒影)
: h3 U9 m$ h9 g0 A* R; BCanvas Painter (一个更为简单的 Canvas 画图程序)
+ j3 y' Q' u; D5 c5 a; o
# a. y: q: L* y" U, I真正令人赞叹的 HTML 画图程序 & `$ D0 m! i4 a. l% A
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|