 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。5 ~4 h9 x" {# U2 X% h
! V4 ?! G/ {6 X
0 T- I4 i2 X8 G* c4 {# ^5 m! s: Y# y) E3 Y- c8 U$ t+ J# ^
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
0 I! J8 T7 b" D4 b& P5 `5 R
. n. v4 w5 b; P+ |为什么要开发这个程序?
! Q. r; w3 L$ _: W9 k; Y6 h目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。+ v: ^/ H0 Q( j2 E/ y9 k7 X
0 q& ~6 ~4 x/ e& L9 W6 @8 Y
如何使用 0 o B" W; K0 o
和标准 Windows 绘图程序一样。" X) y9 w8 F% t
7 y: Z B: t9 G8 X& \能保存吗?
8 k- T8 U0 l6 K2 k是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。' Z$ C. y. T& ~$ J5 v: C, v$ x
) T$ l/ p) F, u1 b/ b% \! a1 W
浏览器本身的右键菜单影响使用 $ |9 I( I$ x! _0 u: k4 O. X
可以在浏览器的设置中禁用右键菜单。
z7 _% b" I) M3 X& ` O$ _; t+ z/ t3 f% U9 z+ r/ K
为什么有些功能不能用?
5 }" b6 u! k* x4 P4 y" v一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
# R0 ]/ ?; Z% k& W' L, C6 f# o* e: z' h% t% J: c: I
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
e* K# n7 g( J1 h$ x对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。( U1 G3 O+ ?& I
8 E4 s! X5 x& D8 \+ k
技术细节 # J( i `, D. k0 T% `
程序中使用了 5 个 Canvas 对象。4 t. d$ M- s/ f! E( d
6 ]/ }& f, }; h' @# |一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
/ L$ X: e0 g- M其他人的 HTML5 Canvas 实验
8 g, w2 W% [1 ~2 F7 s! H" W. eCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
) n" s) F$ z6 k; dCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )2 F5 B: I( z; l1 G- X' W: G! x6 P
Image reflections (用 HTML5 Canvas 实现图像倒影)! _0 T; D: z1 p5 T- P
Canvas Painter (一个更为简单的 Canvas 画图程序)
* p( C9 l- r% ~% l o& ]9 X4 }
9 J: X$ D1 ]: V4 ]& y9 V; I2 U; x真正令人赞叹的 HTML 画图程序
, V( ^+ g# V! C) { s6 B, N, o6 C如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|