 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
5 A; o2 [7 O3 Z7 P! t3 p. N `6 m6 t2 j+ v% P% ^8 S" ~* a: t
4 }+ j0 g/ t: o( @. N
' Z3 L" j1 z/ m4 m) kCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。; L L) H( ?5 J, _9 ?& e! H
4 ?. M2 E8 @$ g3 ?% M% I( l为什么要开发这个程序? 8 |* l! E4 B" m6 U, h1 k1 Y
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
5 I' Q# K0 e; z% ?7 Z& G4 y3 E# U% Z3 J" l( G4 }
如何使用
9 H% [" A2 `4 g/ [- B5 y2 ^( R和标准 Windows 绘图程序一样。7 S0 B! \& x& J: |0 s: @6 t/ l. @
. ^" g& _* m4 d! ^) h8 j1 u8 v: ~能保存吗? / R0 E; n( s5 a
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。1 ]% v+ l2 `" N; v7 ]1 S- e0 w- k( T
9 b) Y: S+ W" `" ]% x; E浏览器本身的右键菜单影响使用 1 [- Q0 k9 i9 Q+ e; F$ a* Y
可以在浏览器的设置中禁用右键菜单。2 `0 w5 s3 C+ d2 Z- t5 X
$ u2 V2 n S$ a% k为什么有些功能不能用? 1 d# L3 k6 W& p; S
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):2 u T+ q5 ` G2 m1 z
8 L/ l# G& Z% q( N
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 8 B5 n1 }" |. D
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
0 V5 O, O9 M- ?
4 p& r5 L8 K- O$ S! a8 h技术细节 3 k1 l. w8 K% K$ `: f" W1 i
程序中使用了 5 个 Canvas 对象。
; e- J+ y8 ^/ R: X5 {; e8 S+ z) U8 S: N& u/ @+ G, c; I3 `: l
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
/ r) ] w8 \" j" b1 ]2 A7 I其他人的 HTML5 Canvas 实验 . f A4 r: @; c4 F. I
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)$ {+ f8 V9 o. e# A; s9 W! @7 ^
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
, c9 g* H1 }& L c6 FImage reflections (用 HTML5 Canvas 实现图像倒影)
& h) U' Y/ ^5 c; hCanvas Painter (一个更为简单的 Canvas 画图程序)
4 h* z- Z. F' m: \5 F! H7 Y8 j, G! [$ j4 l% \* X' `: i
真正令人赞叹的 HTML 画图程序
7 i' Z0 A5 S/ g% k如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|