鲜花( 0) 鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。2 C: H. H8 ?% L/ a; k+ o
% V) F2 M2 ~6 k/ _, P. @( ]8 C& a; u/ v; e1 y$ F
4 w" j8 {. g) A8 U1 aCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
$ e2 [; g% D+ ?4 K) r6 W! d: y/ z, r
2 r" K# J. t$ M. Y3 X" b+ X! ~为什么要开发这个程序?
8 O# x! w7 T, a" {目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
3 Y: d' @+ ^! S5 O0 z9 x8 O( f8 f& A0 g$ M, A8 a% {
如何使用 . t3 b% g5 [) W( `+ W. {
和标准 Windows 绘图程序一样。$ _5 f# Q5 n2 G
8 p# |! k$ y+ ~# P* L能保存吗?
5 ]( Q1 r6 F% u& N! w是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。+ }5 R$ T% P$ A+ j* z
1 R# |9 X: F1 Z; `, V' @
浏览器本身的右键菜单影响使用 ! `+ t# C* _! n" U2 }* ~! L8 |8 i
可以在浏览器的设置中禁用右键菜单。; a# l2 x2 |; A6 N8 f' c
3 q* Y4 X0 k* h5 X: g为什么有些功能不能用?
% [7 O( g* `. i% Q一些功能支持特定版本的浏览器(译者注:这是就2006年而言):" e( b. G/ [' n# m% Z) a
, G$ `' [7 l' d1 s2 q& r* n3 ?
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
E: [' ^2 v) ~/ |( b$ g对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
: H1 G( i a6 T, O; D6 i5 i
. M& Y% T) [; P3 `技术细节
; N7 o' m. R2 [+ r5 _程序中使用了 5 个 Canvas 对象。
% Q' ]. ~* w, H! N+ K6 M' Z
; h# q0 ^- m2 U( J }5 {; p: G一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。, V+ _! R' s- w
其他人的 HTML5 Canvas 实验
3 T( V4 I( |2 ?! p q% i' ICanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
! n$ O1 i7 W2 u: mCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )4 `: v% {8 D8 b. V7 B; i
Image reflections (用 HTML5 Canvas 实现图像倒影)5 |/ V) D0 s9 G
Canvas Painter (一个更为简单的 Canvas 画图程序)& q) c1 E F6 e4 N9 U1 |
& j. o! R1 \: u
真正令人赞叹的 HTML 画图程序
* D( r. _1 Y% i0 r: l, `. r+ J如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|