 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
^- _$ ]4 I0 N, v6 I" F v; r, P2 s# h% v- F$ Q9 L) p
% d8 p) Y3 x7 I2 q. E- a
! }7 r4 e5 T+ k! @# P* \CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
- ~" O& t$ C* G5 S: k$ \6 e1 m/ J2 o7 M
5 w& x* C2 K# P6 j! ?0 A/ V: d为什么要开发这个程序? ; c: \% l8 m: T+ `0 g! _+ u8 R
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
* N4 o, y/ C# w$ p1 b" ~, O' I0 l/ W" b/ y
如何使用 ) Y6 K6 {# t" h4 }. s
和标准 Windows 绘图程序一样。
4 I9 X2 v& Q3 v; F) U9 P k1 f: w
' `/ l# `! L* s4 r i: h( _- R$ w6 W能保存吗? 7 M4 G, I; [9 D8 g
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
; X" H# p7 A5 Z/ ]. r& p- V- C0 N, J2 a
浏览器本身的右键菜单影响使用 ( }0 g% X# q4 m
可以在浏览器的设置中禁用右键菜单。+ l s" ^' b& Q, R( v
' n4 G+ j8 k) i: _% _. D为什么有些功能不能用?
9 M, Q& S7 C+ @5 l# {+ B1 c一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
8 i6 G1 w( o$ n0 B" S2 K0 r- y6 G, \# V# M+ t) p: G
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? " W& A! f8 u0 f, |/ I
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。- k: O2 K' W! ~2 @
: K" T! n9 T% I1 e' q技术细节 : l, N5 G" _/ C! z2 j8 @3 x
程序中使用了 5 个 Canvas 对象。; k) S+ Z% d- o% B7 U
: E3 A2 @2 }, h5 L% z' O一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。! p0 @; m; U Q0 r- D5 V
其他人的 HTML5 Canvas 实验
, M6 R5 H9 B y& |8 gCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)8 T& y' n0 T; b; R
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )) l3 ~2 I! h6 N2 l f
Image reflections (用 HTML5 Canvas 实现图像倒影) {4 V$ @% i$ `
Canvas Painter (一个更为简单的 Canvas 画图程序)$ y y8 Y/ a, [6 M' {$ ?; V
6 ^/ }7 w( g/ b3 H. ]& h真正令人赞叹的 HTML 画图程序 % k' B+ ^! O0 J
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|