 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。2 }# E1 J/ M& y+ Y/ J" U
) O$ i; Q7 Q. s: o1 L4 y
( n: ?5 ]5 L" B2 _, k# Q- r
) t, E+ a/ C# OCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
; D6 V7 v2 J: r1 q4 [" G* u( u& D, N9 O3 d& O2 `: s
为什么要开发这个程序? : S2 D! Y$ P: b6 w& s. C8 v8 G
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
! N; K! \9 i( [" y4 ]' w
; i4 @7 i1 B& x. K如何使用 9 r N% E% i% e' a
和标准 Windows 绘图程序一样。3 X; f7 K5 ]7 ~
! I" B5 h% T$ j, \. k9 i
能保存吗? ) S; L( t4 s* B
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
2 b+ _/ p8 @+ |* d* l; d
3 B% l4 I9 F S. H! H9 o" q浏览器本身的右键菜单影响使用 $ ]3 ]; F* I+ E; F6 I
可以在浏览器的设置中禁用右键菜单。9 \+ r" ]* l6 P! D8 t
8 u; K# L" A, ` \ u) D6 u8 {
为什么有些功能不能用?
6 h8 q2 i1 G- r, J4 i3 E一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
1 o5 b' l! g& w1 U, F+ q2 R
% [4 O# e, w) Y& J Y( \! nColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
) a- _! g' H; Z' J对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
8 s# V, m: S$ J! p9 C- g J- A: y9 n6 U2 y
技术细节
, t4 c+ F P& b3 |程序中使用了 5 个 Canvas 对象。
/ j& h3 c- v3 A9 o
7 S' T; J! u- v; }2 f- o! P% X一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
- B0 m6 w- P7 a- Q其他人的 HTML5 Canvas 实验
4 L% e9 \ M- g; o9 WCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
( r- n9 s7 x' Q3 q! A! sCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
/ V6 `) I: L0 _: aImage reflections (用 HTML5 Canvas 实现图像倒影)3 |7 F0 O% F4 c
Canvas Painter (一个更为简单的 Canvas 画图程序)+ u- V% g3 G+ d: Z) e. @
8 p2 u% D; x- v$ b/ P# K
真正令人赞叹的 HTML 画图程序
% _! a/ u4 L8 @& o如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|