 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。 u7 K1 i, ]# F- D! B0 o5 z. V
7 ^" K$ z, U. ^5 W5 S+ v
- f9 Q& {" I7 d% J) C
. P* O$ p) n, i1 A# ?: }) C
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。
+ \" x Y" u$ b4 ]5 D, U7 r$ a
8 ~7 n* k" d- o2 R为什么要开发这个程序? % P" D C7 u8 E( ^% I9 {% ~( q
目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。/ u! n$ x, s5 { h; D) U* O t9 _
4 H9 w% @( p( z% r如何使用
3 ]' c2 R7 O) h& X和标准 Windows 绘图程序一样。! R, L2 _0 y6 ]# s& b% x! C
" q, t" U, s- p# T能保存吗? ! _ ~" }% b$ w; R6 u
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
) e! }' t$ a; b, X8 `4 h& C
. q' T; k, G' S+ r; i浏览器本身的右键菜单影响使用
|! o" d6 w- W& ^4 _可以在浏览器的设置中禁用右键菜单。
: o9 K5 Y3 V% S' e3 G: m5 I8 E* N, E- H/ E8 A# c F
为什么有些功能不能用?
9 E. [. F$ d; `4 e4 M, [$ H" Z一些功能支持特定版本的浏览器(译者注:这是就2006年而言):- B l+ X% Q& J" _$ | J
7 z, H6 r) A8 y0 ]% o# Q
Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
+ G* R: s% [3 t: y+ w* C7 y对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
2 Y, e/ w, K: T/ F5 q* A$ G+ X& M- z1 H1 W' T
技术细节 ' i3 u+ j2 O. G( v& X
程序中使用了 5 个 Canvas 对象。
4 h' {+ H' i6 A7 O: c6 ]3 Q! u0 ^0 F4 @1 l J0 m
一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
4 [, g& _# W _4 @2 J: S$ Z2 }" M其他人的 HTML5 Canvas 实验
" N( b8 D/ R* |7 l1 {! f, FCanvascape 3D (用 HTML5 实现简单的第一人称射击游戏)
) C' a" |, z! Z' w3 G- a/ V5 ]2 w9 fCanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 ) F: J0 [4 Z( {, |4 S+ a0 Q
Image reflections (用 HTML5 Canvas 实现图像倒影)
, ^$ i( {7 N5 V% ^/ qCanvas Painter (一个更为简单的 Canvas 画图程序)$ q% |' |" Y/ n) Y- f, |
" o N' Y9 O9 g真正令人赞叹的 HTML 画图程序
! ?* H& O' ]* C }" }如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|