鲜花( 0) 鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。2 B$ u5 o+ ~8 L- N0 i
* k+ u0 I. e; C8 y7 j
$ S' J3 e S. A3 y6 b/ V2 D' f9 j
2 {6 A' j) S" a. v5 g
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
6 |4 r, h$ h! M7 L$ S; a6 L
& t; `0 T1 a9 n8 j! i为什么要开发这个程序?
) D# D6 C8 j6 i' s目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
8 _4 ^) V4 \) G( T7 l2 K8 D. u3 H! S0 Z9 |( Q9 l
如何使用
+ \, f8 E8 `$ G& z- O% f( A$ d和标准 Windows 绘图程序一样。( F' T5 G4 f% T, i( j8 s% R
. a0 \- J, y5 `* u1 q) Q9 ]能保存吗? b) O9 I+ q( b1 {9 O# V
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
& f6 C1 v4 ~. Z9 S# b# i6 `1 B
; g5 k* L) p. V( m4 s& Y浏览器本身的右键菜单影响使用 + B) R2 t$ W2 A5 U1 d
可以在浏览器的设置中禁用右键菜单。
( f: L9 ^( Y! x" c" V) J% O, k" g5 f9 X! K( M
为什么有些功能不能用?
$ {) I4 u/ F3 o9 V一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
/ }! N: G) R/ [9 Q; l- D- E0 x- _; ^* t6 Y3 _
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
& `3 z& |% g; w9 i# Z5 a对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
/ A7 V, |2 I, d( G4 `7 y7 l* E4 R& x$ p3 W) f0 [
技术细节 9 T6 s+ \/ ?) J' y# C
程序中使用了 5 个 Canvas 对象。
. I* s( K& G* n, w9 T" s6 s6 W3 j$ T1 p+ y- M- G0 V
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。; y% f6 G' `9 u! `* l, T/ ]& L% o
其他人的 HTML5 Canvas 实验
( ~7 e6 k# m8 tCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
" U5 B5 I0 {' r. w8 [5 KCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
% W( O1 v$ d7 ^' P% K5 _; `* Y' zImage reflections (用 HTML5 Canvas 实现图像倒影)
$ ~/ n4 y" ^$ G' R! r# A+ hCanvas Painter (一个更为简单的 Canvas 画图程序)
o6 {0 v5 p& u) |# k9 R4 b- Q
+ u, u5 [5 a* P真正令人赞叹的 HTML 画图程序 1 \8 j! M2 d" A! L! H
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|