 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。! q' w6 Z* g; [
( m- w0 w7 C4 D9 d8 L& r0 J
0 m8 n' l0 m1 g" N0 R, l
5 L |8 `% H, M$ C0 b$ iCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
# J9 u8 ~0 Z4 @3 L
2 X& V* K# ]3 m1 k+ M/ U为什么要开发这个程序?
8 n. C* t* U- b# ^5 S目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
/ e6 V* T' {5 {9 H6 S9 u; }/ ]! z8 F5 v, E G
如何使用 1 X2 \& j' S, F0 y) S5 A6 u; s$ j4 _2 {
和标准 Windows 绘图程序一样。" f$ z) a; F! b+ M
( V, Z; P# O2 u. B( s( j3 {( V
能保存吗?
6 F. _% t# i1 P# Y d3 R是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。/ Z& g& H- M4 K* w: X- Y
; u1 e6 I7 s8 x' [, p5 h6 j
浏览器本身的右键菜单影响使用
3 D/ Y1 D, D7 s5 W7 @# B可以在浏览器的设置中禁用右键菜单。
5 N; a" Z6 Z5 K( Z: D! w: G
& V# D( e5 P* j7 W2 e, _( f4 c为什么有些功能不能用? % i J @+ c5 v* D
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):0 U& M( `* U- g3 ~- E- {6 X9 I
/ f1 ~3 a, W9 J2 K- IColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 6 W. U5 z% Q2 `$ o7 @9 G$ j
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。4 |0 H& }' V* {4 ^4 w' k: ?2 v" g
# y/ Q* h! ^; y' A2 S
技术细节 ( r( q* }$ d' B( j: ^% Z
程序中使用了 5 个 Canvas 对象。
4 G6 m* M$ S! x$ t+ b
; ^: T1 N# R3 Z一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
4 M. V" Y3 A9 f( u0 X: J# A9 H/ J其他人的 HTML5 Canvas 实验 " h0 E; j, I- l: M: B
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)3 _, L$ _9 M1 |
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )& c- O: H, @& a" F% S
Image reflections (用 HTML5 Canvas 实现图像倒影). ^, J& c, E# U: l# N
Canvas Painter (一个更为简单的 Canvas 画图程序)
" m" v! Y; ~- o
/ o, k' u9 y) Z, L. D$ w8 w/ L真正令人赞叹的 HTML 画图程序 / P6 t, m; t+ I, p: S, a. h, T
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|