 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
% m' f' h/ ^. `3 r
9 A+ d) o }' [! z5 w$ u/ R
% W& b7 F8 q3 {( e1 u1 q7 P+ Q$ e& M; x; ?
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
# g6 Z# Q% P$ Q. M/ O' F# y0 P7 e! V" |- F' k
为什么要开发这个程序?
9 w" A% X1 s" e+ \; K# u- m目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
[4 w1 t: J- y- f n9 d+ M G7 t1 I7 h" @: Q7 w5 w) m
如何使用
2 o- T* ?5 b2 r$ U! W和标准 Windows 绘图程序一样。" m( W$ v% m+ I L3 i( B
7 k& T/ G; L, w0 Q9 R8 j
能保存吗?
8 j6 s$ j7 M" M' [6 s/ p1 u1 S" p是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。/ K9 [% M* y- `/ I) w4 s5 u
- w& I# S! Y0 g3 [$ J& R9 M8 `浏览器本身的右键菜单影响使用 " E" q1 e4 N2 f: F
可以在浏览器的设置中禁用右键菜单。0 ~: Z' F$ d) w4 M
8 R3 n1 X9 T+ z3 g8 D为什么有些功能不能用?
& Z8 w% ?/ s- R/ ^& z一些功能支持特定版本的浏览器(译者注:这是就2006年而言):, M' v1 w+ P( _, v& r
4 n W9 }6 w5 R3 Z' W* `7 @5 T- uColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
3 ^+ L: U; K% s对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。- w- z4 k7 Z" U# ^2 {
7 Q' G0 M+ _7 l" ^# `9 I! A
技术细节
- i1 w" J' B$ H. I7 n* j9 z程序中使用了 5 个 Canvas 对象。
; H; B2 C/ r4 r$ ^, V' e: V# R$ _! K2 _# v& r
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。- Z; Q. m4 j$ T6 ~% g4 ?/ i0 r; l
其他人的 HTML5 Canvas 实验
9 P( T2 ^5 _+ H6 M5 ICanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)% _! }$ O, S/ `& L% N! x
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )# F- a2 C( c8 v: [; A+ a7 `
Image reflections (用 HTML5 Canvas 实现图像倒影)
5 H4 b6 z: T3 @$ R/ ^Canvas Painter (一个更为简单的 Canvas 画图程序)
% t. Q( X1 N4 g+ s
" P# A0 a Y% J4 a4 D真正令人赞叹的 HTML 画图程序
+ t( n/ f/ ?+ f8 {1 b9 O$ j Q如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|