 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
' i9 W- z9 f( s6 k5 V! y' {, l& D
2 B, ]2 g8 u- U, D# F3 b) C8 n! V8 N0 m, l. K& p
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
7 _+ O+ _" m1 M) {; V
! u$ I/ y# G- c9 O3 E为什么要开发这个程序? # ?+ M2 v7 R9 `7 c) Q& M7 b1 [. ?
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
$ {) ]) O9 K4 \% @+ M3 [1 h' j2 N/ l/ j( |) R( A7 ~" O
如何使用
: y& c' U, b- q. c和标准 Windows 绘图程序一样。
2 L8 D+ w2 t6 v3 t% k% i
6 g3 D6 M/ ]* g# D能保存吗?
2 j# Y2 c* C$ c8 h( D! i是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
! _ V4 q7 c& p# Q* ~) I6 N& [- d# }' ]& x7 ?! Y* C0 Z
浏览器本身的右键菜单影响使用
! R; s |/ v+ H- T& n) B可以在浏览器的设置中禁用右键菜单。
$ V1 P% \/ F( D s9 |. X: A
: u3 W; o0 `! [/ N为什么有些功能不能用? % z1 ~: \7 \9 K* W
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
, {% l0 b2 j" }9 P. O4 o! ]' c% m
- `! a$ V( L/ ]. RColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
, B: N& h9 Z' i% @对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。1 b4 z: x" j1 u2 S, r; ?
# p$ m% o) h+ U: g( @# t$ ]技术细节
' j: r# `7 v7 P" ^ P2 A+ F程序中使用了 5 个 Canvas 对象。
3 F+ o9 t- Y% i$ l, T/ s1 p1 J4 g" f' V! }" E, t) Y( x1 o
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。9 n0 D5 d; M& H8 M. L* J
其他人的 HTML5 Canvas 实验
4 G/ w+ x6 P9 ^: ]7 t& j. f9 oCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)/ o5 u. ~( O! Z# u8 c( G9 O
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
( [$ l* k( R$ s% [, d* }Image reflections (用 HTML5 Canvas 实现图像倒影)0 o& Q$ Y- n \' j U
Canvas Painter (一个更为简单的 Canvas 画图程序)
6 ~1 n3 g! ~& p# i" _5 O$ s# H
4 Z# I' k% R5 D; b7 M真正令人赞叹的 HTML 画图程序 v3 E2 N$ o4 q) ^6 ]; n; k- C
如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|