 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
) a `- p) d1 Q+ L6 D0 a8 j, g: ~$ x3 Q+ |1 M
0 R7 u6 I" ^- ]0 g9 \7 O% r5 y' m, y9 w% A' r, B( F/ J
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。' z+ E9 v# ^' _$ n$ V
/ F8 Q, f; J: K% |为什么要开发这个程序?
! I' `3 x2 ^9 |0 M _% T$ g) I目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
9 k+ L7 t" j; I% S% @
# c: I8 v* X) Z2 Y如何使用
( [4 t7 E2 U! { k和标准 Windows 绘图程序一样。. {3 f/ m2 H a& }. s: x9 m: a
2 m" x" p* o# D. P/ f# U能保存吗?
0 ~! P' t1 v; W- k, D: V8 z是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
/ t! z9 K9 R/ r- H: j. h
) F5 o, [" |9 J" L8 E7 _浏览器本身的右键菜单影响使用
, u/ W2 h; p8 [; X1 o) j- i0 T2 f- @可以在浏览器的设置中禁用右键菜单。4 n% ]% a3 t" u( S& W# R, H
& m4 G0 P# P1 U1 e8 \
为什么有些功能不能用? p$ `: C3 e: k
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
4 D. F+ }9 L9 D- s. k' s" d
; a; y9 I+ C7 S( \' x) kColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? - Y3 M5 b9 F) i
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
, ~1 f: P5 ]5 I# k4 ~% U+ n* S
( N) s/ n/ W8 m, M# M3 B7 ^+ X9 l技术细节
( d: A" U) u; F0 I3 g% n1 Q/ J程序中使用了 5 个 Canvas 对象。
* o6 K% d. N, [- w7 _, u! L2 J
+ v7 Q1 r. T3 B3 V" q2 S一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
9 Q" J) l" x- F4 a t其他人的 HTML5 Canvas 实验
6 r" ?: D: l7 QCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
* U' I. Q) ?6 ^# {CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
0 N" l* S$ N; N+ i/ Q0 T+ AImage reflections (用 HTML5 Canvas 实现图像倒影)
5 k& J: ? V1 o, P- E' yCanvas Painter (一个更为简单的 Canvas 画图程序)
' T: X; h' W5 L+ x" C/ t
3 l$ {2 E1 y0 \6 j3 ^真正令人赞叹的 HTML 画图程序
" [+ b6 ~. G0 s如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|