Event properties

What is the type of the event?

This is the only question with a true cross-browser answer: use the typeproperty to read out the type:

 

 

 

 

 

Which HTML element is the target of the event?

W3C/Netscape says: the target. No, says Microsoft, the srcElement. Both properties return the HTML element the event took place on.

 

 

 

The last two lines of code are especially for Safari. If an event takes place on an element that contains text, this text node, and not the element, becomes the target of the event. Therefore we check if the target'snodeType is 3, a text node. If it is we move to its parent node, the HTML element.

 

 

Which key has been pressed?

This one is rel <script src="http://hi.images.csdn.net/js/blog/tiny_mce/themes/advanced/langs/zh.js" type="text/javascript"></script> <script src="http://hi.images.csdn.net/js/blog/tiny_mce/plugins/syntaxhl/langs/zh.js" type="text/javascript"></script> atively easy. First get the code of the key (a = 65) from thekeyCode property.

When you’ve read out the key code, send it through the methodString.fromCharCode() to obtain the actual key value, if necessary.

 

 

 

Which mouse button has been clicked?

There are two properties for finding out which mouse button has been clicked: which and button. Please note that these properties don’t always work on a click event. To safely detect a mouse button you have to use the mousedown or mouseup events.

which is an old Netscape property. Left button gives a value of 1, middle button (mouse wheel) gives 2, right button gives 3. No problems, except its meager support (and the fact that it’s also used for key detection).

Now button has been fouled up beyond all recognition. According to W3C its values should be:

 

  • Left button – 0
  • Middle button – 1
  • Right button – 2

According to Microsoft its values should be:

  • Left button – 1
  • Middle button – 4
  • Right button – 2

 

 

No doubt the Microsoft model is better than W3C’s. 0 should mean “no button pressed”, anything else is illogical.

Besides, only in the Microsoft model button values can be combined, so that 5 would mean “left and middle button”. Not even Explorer 6 actually supports this yet, but in the W3C model such a combination istheoretically impossible: you can never know whether the left button was also clicked.

In my opinion W3C has made some serious mistakes in defining button.

Right click

Fortunately you most often want to know if the right button has been clicked. Since W3C and Microsoft happen to agree on this one and givebutton a value of 2, you can still detect a right click.

 

 

 

Please note that, although Macs have only one mouse button, Mozilla gives a Ctrl–Click a button value of 2, since Ctrl–Click also brings up the context menu. iCab doesn’t yet support mouse button properties at all and you cannot yet detect a right–click in Opera.

 

 

Mouse position

As to the mouse position, the situation is horrible. Although there are no less than six mouse coordinates property pairs, there is no reliable cross–browser way to find the mouse coordinates relative to the document we need.

These are the six property pairs — see also the Event compatibility tables or the W3C DOM Compatibility - Events page.

  1. clientX,clientY
  2. layerX,layerY
  3. offsetX,offsetY
  4. pageX,pageY
  5. screenX,screenY
  6. x,y

I explained the problem, W3C’s vagueness and the use of pageX/Y andclientX/Y in my slightly outdated Evolt article.

The screenX and screenY properties are the only ones that are completely cross–browser compatible. They give the mouse position relative to the entire computer screen of the user. Unfortunately this information is completely useless: you never need to know the mouse position relative to the screen — well, maybe only if you want to place another window at the mouse position.

The other three property pairs are unimportant. See the W3C DOM Compatibility - Events page for a description.

Correct script

This is the correct script for detecting the mouse coordinates:

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include "axi.h" #include "navier-stokes/centered.h" #include "two-phase.h" #include "log-conform.h" #include "curvature.h" #define RHO_r 0.001 #define MU_r 0.001 #define RE 5. #define FR 2.26 #define LEVEL 7 #define BETA 0.1 #define WI 1.0 scalar lambdav[], mupv[]; u.n[right] = neumann(0); p[right] = dirichlet(0); u.t[left] = dirichlet(0); tau_qq[left] = dirichlet(0); f[left] = 0.; int main() { size (2.6); init_grid (1 << LEVEL); rho1 = 1.; rho2 = RHO_r; mu1 = BETA/RE; mu2 = MU_r/RE; mup = mupv; lambda = lambdav; DT = 2e-3; run(); } event init (t = 0) { scalar s = tau_p.x.x; s[left] = dirichlet(0.); fraction (f, - sq(x - 2.) - sq(y) + sq(0.5)); foreach() u.x[] = - f[]; } event acceleration (i++) { face vector av = a; foreach_face(x) av.x[] -= 1./sq(FR); } event properties (i++) { foreach() { mupv[] = (1. - BETA)clamp(f[],0,1)/RE; lambdav[] = WIclamp(f[],0,1); } } #if TREE event adapt (i++) { adapt_wavelet ({f, u.x, u.y}, (double[]){1e-2, 5e-3, 5e-3}, maxlevel = LEVEL, minlevel = LEVEL - 2); } #endif event logfile (i += 20; t <= 5) { scalar pos[]; position (f, pos, {0,1}); fprintf (stderr, "%g %g\n", t, 2.*statsf(pos).max); } #include "view.h" event viewing (i += 10) { view (width = 400, height = 400, fov = 20, ty = -0.5, quat = {0, 0, -0.707, 0.707}); clear(); draw_vof ("f", lw = 2); squares ("u.x", linear = true); box (notics = true); mirror ({0,1}) { draw_vof ("f", lw = 2); squares ("u.y", linear = true); box (notics = true); } save ("movie.mp4"); #if 0 static FILE * fp = popen ("bppm","w"); save (fp = fp); #endif }
07-16
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值