鲜花( 0) 鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
8 F' n }+ T, d- [2 ]1 x- \; {+ Z, w0 T; }- m# A
5 S2 ]! ^4 W' n
( `) p) i3 [% W# C5 J
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
* g+ D5 v1 m9 p5 B4 W" l
" Y# r6 ~8 W. j8 E9 M6 J$ j0 N为什么要开发这个程序? 0 I- \4 x2 d) g0 q" D% I: d
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。* V- g" S: i \" ? {
3 _4 I; M& I1 I) R" W7 z
如何使用
4 J9 Y# i; Z- O4 {1 Y和标准 Windows 绘图程序一样。
9 O. V7 e3 M' g S4 ]. S `
; X4 ~! n' [8 r( M6 p能保存吗? 3 H/ \: D7 f/ e* @* H
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
/ K/ ]1 Y6 _* V: h6 O, ~7 h q' n8 z
% `! W2 ]* m, V/ r. B( u* S& m浏览器本身的右键菜单影响使用
9 x. T F; t" }% T0 q可以在浏览器的设置中禁用右键菜单。) g' |. J3 {: e, R0 ^' m* v
$ s8 K$ S4 n6 l0 ~- h9 _3 }为什么有些功能不能用?
* _" o& x/ J/ _% z( R3 x一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
3 |5 f$ A0 d {
3 S N- ~7 l9 F2 r* n& t! c( EColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? B) L1 K ^" Z$ j
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。9 h3 d+ {% x) ?1 Y1 b! v& B3 h
- I+ A* G9 ^0 i q' e
技术细节 $ s; c) Q6 m. V$ m. r# r7 x0 o
程序中使用了 5 个 Canvas 对象。3 j: w3 ]8 S- u: _; O1 D
/ d* M6 @, j' R* g. H, x& S一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
8 K! u# T/ E* V其他人的 HTML5 Canvas 实验 - K; i2 i' _9 N# P; c8 M7 o
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
2 O! ^) V- e% H8 R6 q# GCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )
: h5 a; q( t: U. D, o. yImage reflections (用 HTML5 Canvas 实现图像倒影)' ]& ^# @9 `" p7 m
Canvas Painter (一个更为简单的 Canvas 画图程序); b, e' G5 Z `" c
/ [1 {: a# {; k9 U6 s8 P
真正令人赞叹的 HTML 画图程序
# y& F* f1 g3 S) j2 x! @6 m; u如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|