 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
* N" ]& b* E# h* H `
2 q' p+ I2 Q: |& J; H# q0 \! s# l! c Z7 V' D. y! ]+ H
/ N) p; j% K% z* x3 r; f" \; pCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
- |. K3 i$ D5 @, q: x+ o9 C
9 i* p2 }' @4 _. p4 m% P为什么要开发这个程序? $ N5 O" y4 g$ M# s2 a+ z! _& {
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。7 N6 e8 Y8 ?, O
; Z# W) t# b- q& Y如何使用 8 W1 K; i" w/ N& ]' O
和标准 Windows 绘图程序一样。4 D; }2 `4 E. G; U! X) E8 P
9 P5 _& g) Y: x# s6 D4 f能保存吗?
9 ^; A3 {2 F( ^! \: Q2 \$ x* F是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。" t2 g' K: U% j/ t0 m2 x& R
1 k! h" R% u' q6 U4 N浏览器本身的右键菜单影响使用
- H2 x; ^: a2 g9 Y可以在浏览器的设置中禁用右键菜单。" f7 f$ ]+ f1 C G0 c5 k6 W- A9 Q1 V
3 ^* [: E: S& T z4 r6 z( \+ ~
为什么有些功能不能用? 7 L/ m5 `6 d" N
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
5 {$ K- @6 c9 P2 M: r& G- A, [- J) G# j; D- Q: @
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
% W/ l* z$ l7 v对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
. u$ Z4 q/ t) f+ j
* X' g" M; K3 j技术细节
2 y) k' d; l/ c, ]. R程序中使用了 5 个 Canvas 对象。2 d4 W$ a" C" n1 p$ P) i1 F5 E: q
& K6 D, f& l( n0 {
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。; {0 j9 {4 o% d" I
其他人的 HTML5 Canvas 实验 4 P6 t! d1 [, y7 C h( A$ D3 C
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
- H& q- ?" V0 S/ Q- L6 Z; LCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )% \( Z* L$ r; B3 n: _8 T
Image reflections (用 HTML5 Canvas 实现图像倒影)
; H$ M' l0 `& W+ HCanvas Painter (一个更为简单的 Canvas 画图程序)$ s# Q; j5 u& n) G+ J3 r
" _1 x" b/ H' A. S: h6 d# ?) ^! V
真正令人赞叹的 HTML 画图程序 0 W- ~" A/ d# k- f
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|