 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
( T+ W) U9 U* z( g
7 f+ _5 ?/ ^1 L, G* B9 L% J! R' R/ E2 j/ A2 Q: q7 [3 T
. ?( u$ C e: N! R' x: {2 pCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。' H6 l8 k( x1 @/ |! p! f2 x
1 G6 M5 T# E; B1 ~为什么要开发这个程序?
3 J% A, L! q/ F6 [' f目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
8 r7 Q: {) j: c0 q8 n# q0 |) O0 ^# S3 ?) H' X
如何使用 # Q! I& j1 K6 u
和标准 Windows 绘图程序一样。
# e- i* o; Y0 B2 @: a* j% V; ]7 {, C# \* O, S% F
能保存吗? 8 Q: B# `" N; A: @- b
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
) h% \4 w6 ^) `& m) C6 M
6 {8 a; y# C7 K% o3 i; |% H浏览器本身的右键菜单影响使用 ) z% a z" x; ^$ r1 U1 T' Z- P
可以在浏览器的设置中禁用右键菜单。1 C" M+ o6 w) t; [+ P* @. p; W
; u* `3 h0 E8 p/ m/ B' r
为什么有些功能不能用? 0 b5 s: P8 Z' d; \3 ^
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
+ ^) H2 E. v8 }
! @' |- Y3 J) W4 q1 A: ]# @Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
3 y) a( `7 J! |; I& |5 L2 n对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。& n$ e, s' b& a2 o9 G
5 f' S$ {, M9 n( Z2 A技术细节 6 `) k$ D, p Z5 P" ^8 G p1 ^
程序中使用了 5 个 Canvas 对象。. Z0 E! I( y- ~% y5 h C
6 y9 ]9 q, k p% i一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
8 U( B6 N% s; }3 O3 T" h其他人的 HTML5 Canvas 实验
9 k; X1 O6 q" o" I: DCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)9 J/ s; U: I3 B
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
7 L3 A% t. X. Z# g: ~ mImage reflections (用 HTML5 Canvas 实现图像倒影)
- A# M7 w1 f1 sCanvas Painter (一个更为简单的 Canvas 画图程序)9 N `1 V R( C9 T# l' Q
7 }9 Y6 F! i3 {2 j: ?+ f/ p7 O9 k
真正令人赞叹的 HTML 画图程序 ' g" z: U6 g4 x2 c* y$ e' V
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|