 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
, V6 {7 |; {" m" r' \5 o! h4 A% t. v9 k; ~7 W' c
5 T! _; c. W, r- I. N
" V# z# S3 y$ Q c7 o1 u# P. rCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
; z1 x; {0 v4 x+ `4 W, S( @2 e$ k( T+ G: c% [- k
为什么要开发这个程序? ) G" p1 P4 r; { W. H' J4 t. I7 B
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。9 b/ c0 i# v2 |8 x
# m/ r$ b( M$ f5 C: |( y4 w q$ s7 Y
如何使用
$ X8 W+ `0 h$ `和标准 Windows 绘图程序一样。; D1 d+ @* @. A* s1 L. o Z
* n" \8 ~- e: |; R能保存吗? + C5 v# e; N: l
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。2 @6 L3 |8 Y) E# S* v0 e! \
0 V( V4 f) q& S3 V5 j9 D5 c
浏览器本身的右键菜单影响使用
* J, V Y! X( @7 ~% c7 G0 g0 z& I可以在浏览器的设置中禁用右键菜单。
' U! ]& z& w# a$ \' E& \" v$ ^9 v5 T) L7 [
为什么有些功能不能用?
T1 H4 i1 {7 C$ P$ U5 F一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
# Y* T: B/ ?! A* I$ R! @- y( x5 p3 }- x) ]. g5 h. C
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 4 x6 C* X/ \% c& B+ Z* C l
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
: G- Z# Q' J: k
1 M. |: j* d5 {+ }& d, i技术细节
e. w. h; _- Z程序中使用了 5 个 Canvas 对象。
5 u% |- e4 D8 f& f7 l1 b2 A% s) ?. t7 i) {0 M
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。" u% a- N8 c% N! k9 N' g9 r
其他人的 HTML5 Canvas 实验
5 b4 w6 L. h* ]8 i" t Q, QCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
% j( H, J" P' a8 n* R+ eCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
: e* z% R) P: p0 xImage reflections (用 HTML5 Canvas 实现图像倒影)2 W! V2 q; O! R; B
Canvas Painter (一个更为简单的 Canvas 画图程序), M" O, Q9 B' E/ r. n& W
. d* d" s5 U7 z @7 v" o真正令人赞叹的 HTML 画图程序
) ?5 ~# f8 ]7 D$ L) A6 {如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|