鲜花( 0) 鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。
, A( r' k& j5 J. P$ _$ X4 ?2 R/ a) L9 R9 k( r
: y! D: r$ a! B2 N/ W" @
! I3 {& b' n4 U6 N* e( wCanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。 s) D: U5 v4 H& u* c0 H9 ~( Q$ F
8 x0 |6 ~9 [2 J# V为什么要开发这个程序?
' w: o2 H' I4 B% r7 [, @( {7 X1 V目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。8 o- q ]; Z# i# n. f8 F# J
3 h: d( |" \& ~" G7 f7 [
如何使用
0 J: C9 z1 l3 z% N和标准 Windows 绘图程序一样。
9 w8 F3 n8 E, l: G6 I, `- t5 q% j0 e! |- i7 h
能保存吗? 8 |0 W/ j+ [9 W( b1 J
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
7 y) C% y2 k: Z/ z8 U3 @; ~: z( H6 `2 {2 b, p! x
浏览器本身的右键菜单影响使用 * x' W/ p, C# R/ i# f( ]
可以在浏览器的设置中禁用右键菜单。6 D5 w1 p9 s* s9 M1 {$ l
% h( X, Q& t% f为什么有些功能不能用?
' o l$ [* Z1 ^ l* ^( U% x5 e一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
2 y! v% G$ i/ D& s. A( S
* z5 p8 l, P {: s& ^, rColor pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗? 9 Z! m5 W, |; \7 ^
对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。
0 p& n/ b- h* W- r, X2 x5 L+ p7 k4 V
技术细节
+ H1 Q" I' J/ c }/ M5 g* g! t6 ~程序中使用了 5 个 Canvas 对象。0 E- u3 Y5 B" z6 L0 j1 w6 m6 Q
+ l! a; A7 Q! x1 U一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。5 D! p5 ~1 n5 ?$ w/ h
其他人的 HTML5 Canvas 实验 + g8 H) N/ M" {; F) Z e2 y$ S D
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏); [4 p* T! Z- p# b( Q
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )# K, N9 B* V9 K4 X) G; {
Image reflections (用 HTML5 Canvas 实现图像倒影)
: h) _" [% v, B3 K6 l* vCanvas Painter (一个更为简单的 Canvas 画图程序)' E* ^7 A: g& p$ u5 w/ c
6 p# ^, s- ?9 n* T4 H
真正令人赞叹的 HTML 画图程序
4 x, M0 j2 F0 V- f( B如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|