W3C home > Mailing lists > Public > public-web-perf@w3.org > March 2018

RE: Minimal event timing proposal

From: Todd Reifsteck <toddreif@microsoft.com>
Date: Mon, 26 Mar 2018 21:03:58 +0000
To: Mark Rejhon <mark@blurbusters.com>, Timothy Dresser <tdresser@chromium.org>
CC: Ilya Grigorik <igrigorik@google.com>, "public-web-perf@w3.org" <public-web-perf@w3.org>
Message-ID: <CY4PR21MB07420101EC47CF4E34D6822CC2AD0@CY4PR21MB0742.namprd21.prod.outlook.com>
I’m not sure exactly how that feedback relates to Tim’s proposal. Can you give specific and direct feedback on Tim’s proposal if I’m not accurately

My translation of the feedback being given on this specification:

  *   Could a site enable this at < 50 ms when using this for high speed animations/games on well-tuned sites?
     *   Yes, but it may trigger a lot more often than many web sites want to measure. Perhaps this could default to 50 ms, but allow a site to opt in to < 50 ms for scenarios such as what Mark is describing?
  *   How do we measure the duration between the event updating the DOM and the display actually showing it?
     *   Tim?

With regard to the general statements made:
Having the point data at much higher precision than 1/frame should allow all movement data to be used when processing. If the screen is only updated at 60 Hz, any updates to the actual graphics occurring more often than 60 Hz can often cause “double resource usage” when animations are thrown away multiple times a frame. The purpose of allowing input callbacks to receive all input data 1/paint loop is to allow the “best of both worlds” by allowing the site to ensure the single paint uses all input data when calculating the UI updates. If this is not true in real world usage, I think the input and rendering teams would be interested to hear exactly how BUT that is not the focus of this specification. (Lets please start a new thread if that is a topic we’d like to discuss.)

Hope that helps!

From: blurbusters@gmail.com <blurbusters@gmail.com> On Behalf Of Mark Rejhon
Sent: Monday, March 26, 2018 1:47 PM
To: Timothy Dresser <tdresser@chromium.org>
Cc: Ilya Grigorik <igrigorik@google.com>; public-web-perf@w3.org
Subject: Re: Minimal event timing proposal

Regarding First Input Delay, we do lots of input latency measurements as Blur Busters, albiet from other points of views (e.g. gaming latency).  Even 5ms makes a big difference in certain contexts.  Over the long term, 1000Hz mice should be streamed directly in an atomic manner to Javascript -- instead of always permanently only coalesced into PointerEvents API.

Microsoft Resarch has found that realtime processing of 1000Hz input make a huge difference:

Even on a 60Hz display it can still have large benefits.

That said, understandably, while battery power can be a concern, Safari has been limiting lots of processing to 60Hz even on the new 120Hz iPads, certainly should be fleshed out better in all of this standardization work.  Many things like requestAnimationFrame() in Safari only runs at 60fps even on the 120Hz iPads, even though Section of HTML 5.2 recommends it running at full frame rates on higher-Hz displays (like in other browsers, Chrome, FireFox, Opera, and even some versions of Edge).   These add unwanted input lag to touchscreen events on Safari.   These are major input lag considerations, adding +8ms of input lag to browser apps rendered in <canvas> by running rAF() at 60fps instead of 120fps on the 120Hz iPads.   The display-side equation is part of the lag arithmetic too, even though there are also power-consumption-versus-lag tradeoffs.

On Mon, Mar 26, 2018 at 4:26 PM, Timothy Dresser <tdresser@chromium.org<mailto:tdresser@chromium.org>> wrote:
I've updated the proposal on WICG here<https://github.com/WICG/event-timing/blob/master/README.md>.
This proposal requires only dispatching PerformanceEventTiming entries if the duration between event startTime and when event processing is finished is > 50ms.

On Fri, Feb 16, 2018 at 1:43 PM Ilya Grigorik <igrigorik@google.com<mailto:igrigorik@google.com>> wrote:
Tim, thanks for drafting this! I like where this is headed.

Left a few questions in the doc and added this to our agenda for next design call<https://docs.google.com/document/d/10dz_7QM5XCNsGeI63R864lF9gFqlqQD37B4q8Q46LMM/edit#heading=h.ljsbtcikd3cl> (date TBD).

On Thu, Feb 15, 2018 at 1:53 PM, Timothy Dresser <tdresser@chromium.org<mailto:tdresser@chromium.org>> wrote:
Based on our discussion on First Input Delay<https://docs.google.com/document/d/1Tnobrn4I8ObzreIztfah_BYnDkbx3_ZfJV5gj2nrYnY/edit> at the last WG meeting, I've put together a minimal proposal<https://docs.google.com/document/d/10CdRCrUQzQF1sk8uHmhEPG7F_jcZ2S3l9Zm40lp3qYk/edit#heading=h.fbdd8nwxr7v4> for an event timing API.

The extensions to the DOM spec are fairly straight forward, and the API itself is pretty bare bones. The main question is whether or not dispatching an entry per DOM event is too expensive.

If it is, we'll need to devise a method to only report a subset of events.

I'd appreciate any feedback you have,

Received on Monday, 26 March 2018 21:04:30 UTC

This archive was generated by hypermail 2.3.1 : Monday, 26 March 2018 21:04:31 UTC