 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
5 E4 I$ M! J5 z
0 ^& Y- ?- s, d# @- {( q
5 o& P' [, P& e5 L1 L o
9 }3 n4 \3 I9 U3 z. QCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。* r! V3 R- K# r3 P J9 h. Z
: `/ d; W" h8 A- m3 j6 a2 x
为什么要开发这个程序? : U, n# Z( T; g1 B! l
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。# _0 M+ ~9 j+ t( }7 _, j
& R4 y2 v2 J1 ~" n( q如何使用
4 {) Y K) f) f2 E- \* j# Y和标准 Windows 绘图程序一样。
* ]( M- ^" G" n( W; }- O3 k, P
' s/ `7 Y* k/ Z& p: f5 [8 i能保存吗? " A8 w! W4 d( d. {0 E
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。5 h/ T! q2 B4 |( I! w
& U7 X5 v* ]7 e g$ `( M浏览器本身的右键菜单影响使用 * J$ y; s4 ^' y2 S
可以在浏览器的设置中禁用右键菜单。1 w3 P4 [9 t8 i& D! i: ]7 }8 B' G
# M3 h, t) Q- O9 r' c1 v
为什么有些功能不能用?
b+ J" b2 n. O& Y6 @% h% t一些功能支持特定版本的浏览器(译者注:这是就2006年而言):8 w5 i6 H" x4 N* M3 U F& a0 u
" Y8 }. C! D$ iColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? ' i- K1 U' Z g4 t
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。3 K V: x! w1 @! H3 U0 g$ o0 Q+ B
8 s: s- Y$ T( x, v x& `! u
技术细节
3 ^; q) J e! F! Z9 v/ n: ?" e4 u9 ^程序中使用了 5 个 Canvas 对象。2 Q5 p5 b! X/ Z( y
/ I9 y! x/ w4 @' O9 w6 b一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
1 d& r: [9 P; T4 `0 E3 x2 {+ T) n, C其他人的 HTML5 Canvas 实验 3 C+ b% l1 E$ X# N+ b) I
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
( A8 F t& s3 _% y% ?CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
4 ?/ Y; @$ h1 Y3 f8 h% i7 P, i4 kImage reflections (用 HTML5 Canvas 实现图像倒影)
3 Z) f- r9 k+ Z* gCanvas Painter (一个更为简单的 Canvas 画图程序)$ D6 v* D7 ] v
6 v" h6 O% x- z' K1 ?真正令人赞叹的 HTML 画图程序
; |, ]/ M4 s- e0 F如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|