 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。 T; ~0 s# v% {9 s: D
; {! F; d/ l6 _ Q7 `! P; ` Z; \. D
7 A/ V P9 \8 m3 I5 q/ ?& I5 x9 a
' {6 M% B# s5 ]$ s" `. L0 s
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。 I; s: w9 _/ E1 J. V8 x
. @# _" |' U( g z# f$ B+ V* p* i A为什么要开发这个程序?
4 e T0 @$ X; {1 Z- M3 s ~目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
7 P- `3 O6 ]7 `$ i$ o2 B$ ^
' u% o) G+ u/ _如何使用 / v0 w y6 O5 }* ?4 j
和标准 Windows 绘图程序一样。9 o1 P9 p4 A7 P1 U5 E# i
" y6 u$ _+ a5 V4 S, U! I6 g* ]能保存吗?
X. ^* u8 g$ H是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
; W- T' d. `) H U3 O/ O, f3 X1 {1 U R$ X
浏览器本身的右键菜单影响使用 3 e) z! d7 H2 G" d
可以在浏览器的设置中禁用右键菜单。' f& ]6 X: g) u9 z- P1 |: l# M
, n+ q Z6 k( _4 {! k a" y为什么有些功能不能用?
$ ~0 g7 u2 T& s- S q# h9 b' p" J, a" f一些功能支持特定版本的浏览器(译者注:这是就2006年而言):5 ]# m A6 e' ?3 ]
5 P+ I6 O" S. d) _$ S3 |( G9 @Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? - X) S. x7 [3 N1 ^" P2 H
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。/ F/ G6 A: t; a3 z
6 l6 p L/ C( V7 N$ Y T5 Q! N
技术细节 I& X7 F1 v' ]! F; I$ Q
程序中使用了 5 个 Canvas 对象。$ `/ I$ _+ o6 O0 Z4 G* X j2 I
$ d; H0 p% o [ o
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。1 A9 r: r1 s4 T; L/ B2 G
其他人的 HTML5 Canvas 实验
$ j2 K* `! T \% mCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏) z3 O7 ?/ j$ c1 w
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )' f! M/ Y( p1 p) d
Image reflections (用 HTML5 Canvas 实现图像倒影)* [; z8 l( ?' A5 p) l
Canvas Painter (一个更为简单的 Canvas 画图程序)
. `+ g/ a5 m7 F- F3 d, [& O6 ~/ m) g @1 o4 Y- o
真正令人赞叹的 HTML 画图程序
6 z# O( G6 A) f5 u/ n, G( L* Q/ I如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|