 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
- o* ]9 ?5 A/ v* y4 `8 X' A
4 R7 o9 Y0 p6 X* V2 ~7 L0 v7 e; |# \* y' u* E" D9 W# k, W7 {
! o& [) |& O. _" S3 x' FCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
$ q* }: J" r6 H" N9 y3 B( L& m3 Q7 g% ?. R% Z; f7 V
为什么要开发这个程序?
" w! b& o: f3 t' L目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
6 q8 T+ q% f; ]) D4 o. w, c. m3 z5 W2 M. D
如何使用
3 k. V) H2 K0 P4 p% `和标准 Windows 绘图程序一样。
3 |# g4 k. i b. ?! U! r' q8 m
" t" q- {, j- ~( ?能保存吗? 2 s8 D- U' C8 s, d; U
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
1 U+ v6 Q) Z6 t7 M/ p9 ]5 n/ h7 C5 Z# m8 \$ S7 w
浏览器本身的右键菜单影响使用 5 n6 O9 W+ B6 N. m% d& P
可以在浏览器的设置中禁用右键菜单。: a0 T# i1 Z( i0 u, M
& @4 _) l& g9 A v Q
为什么有些功能不能用?
& t& ]3 @8 R# j( _+ {3 ^一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
5 A. }# C; G4 C' Y) n
) v& D7 k; x; M. L+ I$ SColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? % }9 P4 M- K P/ m' n* T* O- O
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。: d3 t8 D- T- ^) e4 x: Z4 [
1 X+ c9 N( l; B7 o5 ?
技术细节
+ |* ~1 p; |! l7 ]6 H% f, g程序中使用了 5 个 Canvas 对象。2 c& T& X$ m7 o7 F' c0 V
: }0 J1 x$ T6 J; v% e一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。% i" ^( ], Y1 m" t3 o
其他人的 HTML5 Canvas 实验 ( |) p. R1 H9 P" }
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏): y' }0 g E- g$ I' P2 P6 W5 @
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
9 e% G9 _4 ~: P7 tImage reflections (用 HTML5 Canvas 实现图像倒影)9 k5 M2 b, j& z5 \
Canvas Painter (一个更为简单的 Canvas 画图程序)
% y7 U9 V4 l$ r% b$ S! Y! S$ z& ]% |" k: \4 r9 S4 O
真正令人赞叹的 HTML 画图程序
, j2 W1 W8 t- n8 U5 J+ E# H如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|