 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
* D \4 Z% z9 m. }, d; W* Z0 D
) n, {- Z7 a! \5 S
' e" L. G# {9 n' v% G; S+ V3 f2 p
- k% q9 D$ O- F" S) ~- uCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。7 ^* `; h' V5 \" H
7 e5 p: p. i3 W3 p, k0 A. ^9 a- \
为什么要开发这个程序? % t8 Q5 V8 d* |- |' s/ e- P
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
; T! m) P8 s0 z$ K0 b2 P( U" e: X- S" P$ J% Q5 F4 I
如何使用 2 t. b3 I6 a% B) h& f- _/ X
和标准 Windows 绘图程序一样。
/ n; h7 l/ C% X* w
; a* U+ m v4 r% m. N能保存吗? $ X- R( F3 p$ B d" v
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。 s% J0 |& S: k6 \; ?
- o* D& c L4 R' ]/ N; C, Z
浏览器本身的右键菜单影响使用 ' {8 a5 _7 b) m/ @% {4 T7 X
可以在浏览器的设置中禁用右键菜单。
' n% x8 v2 d( A* h# v, |& E. s6 x* M7 J& I' ~0 e; d# q$ Z
为什么有些功能不能用?
( y* A5 g _2 `' D$ h. D: v一些功能支持特定版本的浏览器(译者注:这是就2006年而言):( p9 [( L# G S) n. O
/ n. T* w9 e8 x3 r
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 4 J! @0 e' G1 Z+ W0 m/ J
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。" d& C) g J/ b5 E9 |
! g$ w; _8 Q5 u8 L
技术细节 6 O- J* m3 R% z; h6 x
程序中使用了 5 个 Canvas 对象。
7 I( q3 s9 J. L$ S$ ?1 |9 Q# _7 B) h, ^
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。* j) Z+ {' ~6 d4 t% ?! a
其他人的 HTML5 Canvas 实验 }* _3 |4 B6 F2 H0 S) h+ z: V
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)+ u9 `) q" s% G
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )4 W+ q% C5 E( s# m7 n
Image reflections (用 HTML5 Canvas 实现图像倒影)$ z) e; E( k5 s" C H' g* A2 F
Canvas Painter (一个更为简单的 Canvas 画图程序). D9 |4 O8 C3 F1 k% e
. A# q' g9 d* r6 N真正令人赞叹的 HTML 画图程序 % j/ Z+ ^- N! s1 v
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|