 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。5 n6 a/ f9 z4 r$ k- H4 d3 U. v; w. y4 _
% O) Y" |/ h7 D: b; |1 T8 \( q
' A8 B3 h- H2 W5 r# M
6 c9 I0 R. P) l5 u6 M9 \9 L% NCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。) x' Q) d# T h1 d$ _/ x/ Y
% x# ^ y/ H. _0 W5 \) {* Y
为什么要开发这个程序? 7 g u- r1 H. K9 W4 E
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
* U* s2 |- ^) a* u: s, U$ z& q( F& ~; X9 }
如何使用 * S' S. |- L1 _$ [" F4 t
和标准 Windows 绘图程序一样。% O* o6 d4 B- a, y4 l4 Q3 d
" r5 H9 s% E6 o! }6 f" v! b
能保存吗? 9 y" H+ L {/ `8 Q, _
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
' k- C5 r* T, L5 b! a! T+ Q# b% M! T# e8 F2 n2 i
浏览器本身的右键菜单影响使用 3 X; }4 ~% q' \
可以在浏览器的设置中禁用右键菜单。% f% i1 R* r7 i R4 _4 M5 N
/ P9 b* r/ @- q+ Z( |7 `( V+ b
为什么有些功能不能用? % A% i% A# s. `, x9 l; J7 @
一些功能支持特定版本的浏览器(译者注:这是就2006年而言):( Y/ X& a# F6 L3 k$ D: ]/ W
7 [/ k& E9 h4 w+ k2 }
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? . @3 r0 C: |, }+ @
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
* t6 v0 I M% O1 ^3 I) ^
/ @5 k7 R7 b# f8 u技术细节
, y6 e. y# q4 ^9 @9 a& q% Q程序中使用了 5 个 Canvas 对象。
( L0 i/ d( Z4 C5 b
& Q4 W+ K9 R3 w+ {2 W一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
+ Y# J" h7 r* C; ^其他人的 HTML5 Canvas 实验 3 | ~; G9 J( N7 [! |# o
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏) w1 ?8 Z% f+ p/ A7 Y) L
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
+ O! I% A- F0 z" ^Image reflections (用 HTML5 Canvas 实现图像倒影)
9 A5 i: S' W4 bCanvas Painter (一个更为简单的 Canvas 画图程序)7 F+ [( z$ a9 L7 T; b, O- A* d% s" r
% F( q, @1 K! ~: \3 \3 j/ o真正令人赞叹的 HTML 画图程序
* b/ L4 N. O0 X8 p: c# R; u如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|