 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
" @% C1 }7 B2 Y& Q
+ _4 O$ I: H3 R3 v9 n" N! a$ `+ o2 R+ w
* a4 U C" s2 n) m3 v! B
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
' C7 z/ I% W0 e+ [- W `" e0 o! ?; N; m& f7 A- x
为什么要开发这个程序?
& M S9 |- F' q$ g$ A目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。: {) H0 Q9 {6 O( z" Z! I
# R: ? I0 D, @: B如何使用 $ N9 ]- `0 B% ^1 |, |' S0 x
和标准 Windows 绘图程序一样。
7 O# U& X0 a6 V% J6 k5 @2 \/ H+ C C( k. m0 R& O0 |8 A* m
能保存吗? 8 n. g& t2 g/ v- N9 X
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
# d, {4 p1 l0 l: V3 ?4 n# _+ W0 c, L( H9 k9 i. O
浏览器本身的右键菜单影响使用
$ f" l3 Z$ H! ]2 J8 d! ~( l7 j可以在浏览器的设置中禁用右键菜单。 C& D4 ]; L4 r! d F! Q
/ y: R& Q$ y7 p5 C8 E
为什么有些功能不能用?
& C* R- R! j2 y9 e x, N一些功能支持特定版本的浏览器(译者注:这是就2006年而言):+ e/ J# S+ G2 ]+ {5 h+ e/ ?" G
' B; W S2 ?8 y3 J# ?! L& x" s( dColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 1 E \1 N p; w- \; e0 u2 ?. ?
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
8 Y) i4 L9 ~& }! m6 }6 t
& T& o3 N- i1 v6 S+ T$ V技术细节 . J2 g6 M4 t$ a6 y
程序中使用了 5 个 Canvas 对象。 Y* ~ `* {6 ^9 \ Z
( l6 S3 s3 r3 ^/ H& Y6 B3 Y一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。; Y" I. }% k3 X$ f. C! j* B/ W* G
其他人的 HTML5 Canvas 实验 7 V. N* R0 V/ ?; m0 M9 v
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
( J2 Q; w8 @) t0 H6 @CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
& r7 y9 @/ y5 oImage reflections (用 HTML5 Canvas 实现图像倒影)
' q4 I- Q6 |4 I3 q/ J; e) tCanvas Painter (一个更为简单的 Canvas 画图程序)0 p$ |( R5 g1 @; L
i6 i1 x) O8 h& ]$ y" T- [- I真正令人赞叹的 HTML 画图程序 # r6 @" B( l K) f+ k
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|