 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。; }2 g3 {- F/ K* Y! }3 s0 u
0 {9 Z& v. @8 ~; I0 O, Z% |, s2 F' j; Y$ P6 m1 S% }; X
( ~2 v$ u- p0 @/ i! Y- y z$ k) Z6 H
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
; n$ w9 t' U5 C/ S% m
2 M) S2 h, h- W& Y. g为什么要开发这个程序?
% w0 w* Z1 Z9 l; Z+ i/ I. H目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
- O. I4 I; N* t, r; a6 j' G' r. { T2 T6 j; s( T8 t" Q
如何使用 " ~2 G P2 K+ }/ t
和标准 Windows 绘图程序一样。8 i0 G) c- r/ O) C; E3 @; H
! |+ P/ q8 P/ t能保存吗? : n, _& p% \- Q( d
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。5 x6 \9 j7 P" O# q+ A s( J
# ^" @8 o3 B9 H
浏览器本身的右键菜单影响使用 . F. I# }" v! X! N
可以在浏览器的设置中禁用右键菜单。
. U5 Q7 b9 u. T0 k0 F7 r) i0 p# b" m- Y( J0 y( _# q" ~
为什么有些功能不能用? , K' S$ {4 Z, \2 C/ D: A$ F
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):! c* J4 U+ ~' l3 B$ k
9 O1 S; w T8 ^# d
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? ( X! G0 x/ w. C" @7 q7 {
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。% N- t L& F: w' T0 p7 r
) P9 }) O! A- @ N; e% v5 c7 `+ y技术细节 & ^6 m- o6 E0 A6 `5 I6 ?
程序中使用了 5 个 Canvas 对象。
( {5 k6 g* |: H5 D& q- X8 ^7 Q) S0 D- g
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
! N5 G* W: T3 L" G4 L其他人的 HTML5 Canvas 实验
6 }$ t3 M! U! G, R1 _- }Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)( t( g( @# c# q, u1 U7 X7 z
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
1 T' l& @" _) G% q5 }Image reflections (用 HTML5 Canvas 实现图像倒影)
% w) g- Q0 `- z* dCanvas Painter (一个更为简单的 Canvas 画图程序)
5 x$ C! \ Z$ |& k4 F5 Y$ m8 x, |: h; A3 m) p w5 K# Q) o
真正令人赞叹的 HTML 画图程序 6 N2 c4 v; l0 _' Z2 O; q
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|