 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
& t* A5 s) p2 u. h5 h+ f W
2 p% F# _; u( G! M
@6 r% B/ D4 M+ {% B& ^. R* i
; d* R% _3 ~ d6 c) Z& j+ ~' HCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
, ?8 _- i J2 V$ e3 c
& U. C: u8 o, D: P$ p* }. Z1 u8 h为什么要开发这个程序? " q( p. n) l2 d+ x! b
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。; x8 T. L7 b! [3 m; n6 @, u. D+ a
, Z4 D$ {- g2 Y+ _9 i1 a+ r如何使用
8 l5 f* @- D: F* U# @* W4 L' F和标准 Windows 绘图程序一样。% X) g8 f8 x: [6 J* h
6 r5 d$ ]: b2 k* p能保存吗? * P8 X8 \0 z- v4 `* _
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。5 Y5 h8 R& D+ u+ K/ _7 m+ z
: H/ `5 k) v; t0 q8 W1 |浏览器本身的右键菜单影响使用 ) m/ s0 ]: A% y
可以在浏览器的设置中禁用右键菜单。
, ~4 F7 ]% F5 d) {# x1 @1 R/ |7 n' l9 T- W
为什么有些功能不能用?
d' g0 n; ^1 s+ L5 B一些功能支持特定版本的浏览器(译者注:这是就2006年而言):* G# ~ R/ y! g! n) X
1 } ^8 U6 \! lColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? , M1 [4 R9 R% o5 ^+ i" U6 F. j
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
1 r7 d+ W- g# K# F8 _
" L* j4 F5 i+ K0 y技术细节
1 Z6 a$ X3 E: r程序中使用了 5 个 Canvas 对象。
! H; l3 p: f) a$ u# [# t5 c4 N+ V
4 T* K/ ~% {( R0 S一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。; b9 }) S( E3 V! L
其他人的 HTML5 Canvas 实验 1 d1 ^% E E9 k! t; V2 S. P
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
# I. u5 j" \; y( W+ u3 BCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
/ G* y' X# N0 ]7 `Image reflections (用 HTML5 Canvas 实现图像倒影): s4 n$ R, r$ e3 m- @; @
Canvas Painter (一个更为简单的 Canvas 画图程序)
" O% ~: f+ w+ `5 G% Q( m) Z% ~8 g" V$ Q& l* z6 |% }6 O3 Z6 @
真正令人赞叹的 HTML 画图程序 ' l, I- \0 }: G/ {- W
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|