 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
$ {7 Z7 c# k' B! T1 m' l3 v: l
* R& @' g4 w( Z: h* @2 S( r' ~+ \0 R) ]5 _% O( C% w2 z
$ u4 C7 D7 { N2 Q
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
3 Q, Y) p' T7 }; f' Y
( H, P; Y+ j' e2 F8 ~* I* {为什么要开发这个程序? 3 ]9 a( t, M8 j5 w& r, L
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
$ J2 O- [* l$ k2 [- Z" V# R
( M. k! {( I; M/ V0 E8 i如何使用
, q ~8 ^% e2 i% W# w和标准 Windows 绘图程序一样。( d: V8 y1 T8 f* F |! O
4 \# ]8 X9 \( ~5 I* Y0 O
能保存吗?
& X4 K- ?# b8 V. `/ E! ^: ^! L是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
! z5 {" u0 K: \& g: h: w; W( ?& F4 l
浏览器本身的右键菜单影响使用 $ b% r6 R2 ~. Z( u, l
可以在浏览器的设置中禁用右键菜单。
2 i8 D0 V( U3 P- X/ g0 _- |
u0 @ @- [. X3 z; u/ v1 J, j为什么有些功能不能用? 3 ?7 {; y( E6 t! ^1 w9 e
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
, Y. q5 R7 p4 O2 N9 S$ e" u8 Q [# I. t$ [
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
% l' q7 b& U5 V5 J! h6 O对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
, D" g/ O) L; U3 }. z! @3 z9 ^6 V+ T) g$ r3 D% m' i
技术细节
. l8 ?' o# Y) k程序中使用了 5 个 Canvas 对象。
* r. |& m! q* J/ m7 @
) Y" N8 o: A1 q/ c- X1 }一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
) {9 v+ J0 Y& _6 g+ o" O0 }其他人的 HTML5 Canvas 实验
" D1 G( x/ [' R' D7 Q yCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)* M& }6 c: X' p
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )' m, u6 y2 e0 C8 c+ |
Image reflections (用 HTML5 Canvas 实现图像倒影), R# ~& m2 R& N+ F" w! ~
Canvas Painter (一个更为简单的 Canvas 画图程序)
5 S R0 u2 L$ f( r5 m
. M& v( m8 M) a+ C7 ?+ y& ^真正令人赞叹的 HTML 画图程序 4 q, r. r2 a2 j$ _8 k: B: I
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|