 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。; o3 e+ @1 s! L
, e0 u I. m' \8 v+ n
7 u$ k# C+ U: C5 r$ q5 L6 ?
* a5 [5 Z( P/ v) ~+ x+ ^8 XCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。8 M8 e+ {! K) t4 F
2 {- e, k/ z3 `+ a$ |为什么要开发这个程序?
0 F+ `8 N) c$ K4 @ W% D& z1 X目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。7 P$ c% A$ B; I/ G& h7 `( r
" J- {5 n! Z* s) j如何使用 ! }+ ?6 t6 H) u3 w, z+ h/ W! I. \# N
和标准 Windows 绘图程序一样。" u5 o/ b/ r- Q g. A: A
, w& b1 b/ Z: p0 I# b1 ^) Z能保存吗?
7 Q0 e6 J9 t3 i8 Z是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。1 D" Y) a+ t5 }& O: N# H5 p ~
; i; J8 Q8 A5 L* o% w8 ]浏览器本身的右键菜单影响使用
. B4 M) g9 k; z# F3 N9 }& i) v6 v可以在浏览器的设置中禁用右键菜单。/ w0 ?9 A; _4 P% }8 \" P
; E5 C" I5 N. { o }" ]( B
为什么有些功能不能用?
0 b" w, @ a+ [7 ^( O% {' ?一些功能支持特定版本的浏览器(译者注:这是就2006年而言):/ X9 L; Z) A8 i) N" Y
- L, u( i" g2 e+ j( `
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
/ ^+ G3 X3 F7 y, w0 c对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
1 e0 k# U$ H8 c) W3 P" r9 s+ G } X7 Q1 x2 f0 f& j' p# u; J
技术细节 1 k" {2 x( I w8 J! i* e) `, U: r* ^2 E7 o
程序中使用了 5 个 Canvas 对象。
3 \8 ], I* B1 C7 I& z% b2 w3 X' M7 B
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
! o2 e/ w& T6 ?2 H3 O0 s4 ^其他人的 HTML5 Canvas 实验 # K9 _' N- }/ r. r
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)' |* ~, p4 H# T' y& j% i
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )7 o; ]! E, Z( b1 q. [7 {
Image reflections (用 HTML5 Canvas 实现图像倒影)7 \ t6 Y9 ?2 c5 ]* O" J
Canvas Painter (一个更为简单的 Canvas 画图程序)
9 I. y0 b6 B. c; P0 n6 v$ E+ j) z# o# }
真正令人赞叹的 HTML 画图程序 6 h; {8 U$ l3 {6 g, Z0 c+ s
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|