 鲜花( 0)  鸡蛋( 0)
|
Windows 画图程序一直伴随着 Windows 各个版本,这个很简单,几乎没有什么用处的程序拥有最基本的绘图功能,很适合用来涂鸦。HTML5 的 Canvas 对象使在线绘图成为可能,虽然 HTML5 还远未成熟,但很多人已经迫不及待地用它设计一些让人惊叹的应用。# e, l: A) m% A9 k
: M% ~6 s S X0 F% c Y. m
$ W8 G+ p9 h* X& Y z3 y6 g' B* o# t! |( A4 E/ b" ~. K
CanvasPaint 是一个基于 HTML5 的标准 Windows 画图程序,它拥有和 Windows 画图程序一模一样的界面和操作,功能也几乎完全一样,在特定浏览器的支持下,你甚至可以将最后的作品保存到本机。这并不是最近的项目,2006年就有了,因此,目前绝大多数支持标准的浏览器(Firefox,Safari,Chrome,Opera)都可以正常使用这个程序。以下是作者对这个项目的一些解释。' |! m" E2 |! c" z1 [
/ A# v6 B1 [$ m' V, W4 V m0 z为什么要开发这个程序?
; Y) u1 i9 D3 |$ t0 Q& {目的不是为了开发一个 Windows 画图程序,而是体验 HTML5 的 silkroad game gold 功能。
2 v5 |) x/ G* z4 o1 W. P; y
3 S: ? O+ x& n* p% ?% @如何使用 $ [2 z6 P9 b5 U8 v8 w
和标准 Windows 绘图程序一样。
r; B: z( }9 x; H' h/ Q7 v% u3 x4 o6 B
能保存吗? ; @8 M, E5 z" W. ?4 Y y$ d
是的,但只支持 Firefox 2 和 Opera 9 (译者注:这是作者2006年就实现的一个程序)。在本机保存,选择 File 菜单中的 Download,在线保存,选择 Save online,会自动生成一个 URL 在线显示你的作品。
6 p- L6 X6 p# b5 y! E+ t9 }8 A7 N4 R1 y8 f% l3 g( \/ i9 W' g0 d. r F3 ^
浏览器本身的右键菜单影响使用 ) d2 ~; C B$ J0 X! n
可以在浏览器的设置中禁用右键菜单。
; ^- r6 F, ?% U5 w3 H3 l1 {9 j1 Q2 s: q( R: G
为什么有些功能不能用?
6 [+ s% b( p. D" @' K一些功能支持特定版本的浏览器(译者注:这是就2006年而言):
1 d/ f! [; v {5 }" r* L
% B/ x! s Z/ t `Color pickerFirefox 2.0Opera 9 Flood fillOpera 9 Save imageFirefox 2.0Opera 9 Open URLFirefox 1.5Opera 9Latest WebKit Canvas 对象好用吗?
& G5 P; J" s. T0 I- }对那些不需要跨浏览器支持的应用很好用。但在绘画中,最大的问题是,受限于 mousemove 事件的刷新率,你不太容易发现光标的位置,使用喷笔的时候尤其明显。另外,当尺寸变得很大时,速度变得很慢,没有 getPixel() 功能。* L9 w6 D) S0 o2 a
( z7 ^6 \% j! ~8 t/ z) o/ E) S技术细节
! M) N$ [& \) P( w( `( Y+ s7 S程序中使用了 5 个 Canvas 对象。
; d1 @5 M7 W4 v
& ~8 N. a$ M% \& e一个主画板,一个是透明画板层浮动在上方显示预览绘画内容,一个隐藏的 Canvas 用来缓存选择的内容,另一个用来缓存反悔状态,一个用在程序标题栏,用来显示渐变色。
4 ]. j$ E! c% R+ u3 Q! A3 ]其他人的 HTML5 Canvas 实验 * [* ?* H: V' a/ C7 C3 Z- W3 k
Canvascape 3D (用 HTML5 实现简单的第一人称射击游戏)7 P: \# H' }' D/ I$ Q1 s8 T! H6 y
CanvasGraph (一个 HTML5 Canvas 绘图 JavaScript 类库 )& h6 ^5 c K7 S, p
Image reflections (用 HTML5 Canvas 实现图像倒影)
( e. l) ?: |1 n& VCanvas Painter (一个更为简单的 Canvas 画图程序)
' j' I) U) |+ {7 r; p& n
( a6 ]3 S- U2 }' n+ l真正令人赞叹的 HTML 画图程序
4 X+ c- ]+ ~2 P" ]& r2 x0 r1 L如果上面的程序已经让你对 HTML5 的 Canvas 功能感到鼓舞,下面这个画图程序会让你赞叹。拥有不输桌面的界面体验和流畅感,在多屏幕电脑上,我甚至有将那些浮动工具面板拖到第二个屏幕的冲动。 |
|