Gecko/Touch: Difference between revisions

From MozillaWiki
Jump to navigation Jump to search
(update planning section)
m (→‎Planning: move link to correct place)
 
(9 intermediate revisions by 3 users not shown)
Line 6: Line 6:
|-
|-
! Platform        !! Touch Events !! Pointer Events ({{bug|960316}})
! Platform        !! Touch Events !! Pointer Events ({{bug|960316}})
                                                           ! touch-action        !! async pan/zoom        !! mobile viewport
                                                           ! touch-action        !! async pan/zoom (APZ)       !! mobile viewport
|-
|-
| Android        || yes          || no                    || no ({{bug|1029631}}) || Java ({{bug|776030}}) || Java ({{bug|799585}})
| Android        || yes          || no                    || no ({{bug|1029631}}) || Java ({{bug|776030}})     || Java ({{bug|799585}})
|-
|-
| Firefox OS      || yes          || no                    || no ({{bug|960209}})  || Gecko APZC           || Gecko
| Firefox OS      || yes          || no                    || no ({{bug|960209}})  || Gecko APZC                 || Gecko
|-
|-
| Linux          || no          || mouse only (disabled) || no                  || no                    || no
| Linux          || no          || mouse only (nightly) || no                  || disabled ({{bug|1013364}}) || no
|-
|-
| Mac            || no          || mouse only (disabled) || no                  || no ({{bug|1011833}}) || no
| Mac            || no          || mouse only (nightly) || no                  || disabled ({{bug|1013364}}) || no
|-
|-
| Windows desktop || disabled ({{bug|win-touch-issues}})
| Windows desktop || disabled ({{bug|win-touch-issues}})
                                   || mouse only (disabled) || no ({{bug|1001440}}) || no                    || no
                                   || mouse (nightly) <br>touch (nightly + APZ)
                                                          || no ({{bug|1001440}}) || disabled ({{bug|1013364}}) || no
|-
|-
| Windows metro  || yes          || yes (disabled)        || yes                  || Gecko APZC           || Gecko
| Windows metro  || yes          || yes (disabled)        || yes                  || Gecko APZC                 || Gecko
|}
|}


Line 46: Line 47:
* [http://www.w3.org/TR/pointerevents/ W3C Pointer Events] (shipped by IE Desktop, IE Mobile)
* [http://www.w3.org/TR/pointerevents/ W3C Pointer Events] (shipped by IE Desktop, IE Mobile)
** touch-action is part of the Pointer Events spec (shipped by Chrome, IE Desktop, IE Mobile)
** touch-action is part of the Pointer Events spec (shipped by Chrome, IE Desktop, IE Mobile)
Other documentation:
* [[Platform/Input/Touch]]


== Planning ==
== Planning ==
Line 51: Line 56:
Current work:
Current work:


* '''Mac''': Use async pan/zoom (gfx).
* '''Windows, Mac, Linux''': Use async pan/zoom (APZ).
* '''Windows desktop''': Fix and enable Touch Events, and implement Pointer Events + touch-action (MS Open Tech, Platform Integration?).
** Status: disabled, can be tested in nightly builds with pref: layers.async-pan-zoom.enabled
** [https://bugzilla.mozilla.org/showdependencytree.cgi?id=1013364&hide_resolved=1 Tracking bug]
* '''Windows, Mac, Linux''': Support Pointer Events for mouse input.
** [https://bugzilla.mozilla.org/showdependencytree.cgi?id=960316&hide_resolved=1 Tracking bug]
** Status: enabled on nightly channel.  Controlled by pref:
*** dom.w3c_pointer_events.enabled
* '''Windows desktop''': Support Pointer Events for touch input, and touch-action CSS property.
** Status: Works on nightly channel when APZ and Pointer Events are both enabled.
** CSS property is controlled by pref:
*** layout.css.touch_action.enabled
* '''Windows desktop''': Fix and enable Touch Events.
** Status: disabled, can be tested in nightly builds with prefs:
*** dom.w3c_touch_events.enabled


Possible future work:
Possible future work:


* '''Firefox OS''': Implement and enable pointer events and/or touch-action (MS Open Tech?).
* '''Linux desktop''': Add support for touch events, pointer events, touch-action.
* '''Firefox OS''': Implement and enable pointer events and/or touch-action.
* '''Android''': Unify Android and Gecko APZC and viewport code.
* '''Android''': Implement Pointer Events and/or touch-action.
* '''Android''': Implement Pointer Events and/or touch-action.
* '''Android''': Unify Android and Gecko APZC and viewport code.
* '''Layout''': Implement CSS Device Adaptation to rationalize mobile viewport code ({{bug|747754}}).
* '''Windows/Linux desktop''': Use async pan/zoom ({{bug|apzc-desktop}}).
* '''Platform''': Implement CSS Device Adaptation to rationalize mobile viewport code ({{bug|747754}}).
 
Notes:
 
* Just implementing Touch Events and touch-action (without Pointer Events) would allow efficient Pointer Events polyfills, and other developer benefits (including ability to improve responsiveness of touch UIs).  This is what Chrome is currently doing.
* Implementing APZC on desktop would allow desktop Firefox to share much of the Touch Events / Pointer Events / touch-action code with Firefox OS.
** Similarly, porting Firefox for Android to the Gecko APZC and meta viewport code would allow increased code sharing with Firefox OS.

Latest revision as of 18:38, 6 July 2015

Status in Gecko

This table summarizes some of the broad features related to touch input on the web, and their implementation status on different Gecko platforms:

Platform Touch Events Pointer Events (bug 960316) touch-action async pan/zoom (APZ) mobile viewport
Android yes no no (bug 1029631) Java (bug 776030) Java (bug 799585)
Firefox OS yes no no (bug 960209) Gecko APZC Gecko
Linux no mouse only (nightly) no disabled (bug 1013364) no
Mac no mouse only (nightly) no disabled (bug 1013364) no
Windows desktop disabled (bug win-touch-issues) mouse (nightly)
touch (nightly + APZ)
no (bug 1001440) disabled (bug 1013364) no
Windows metro yes yes (disabled) yes Gecko APZC Gecko

Status in other browsers

This table lists support by other browsers as of December 2014:

Browser Touch Events Pointer Events touch-action
Chrome
IE desktop
IE mobile
Safari

References

Standards:

  • W3C Touch Events (shipped by Safari, Chrome, IE Mobile, Firefox for Android, Firefox OS)
  • W3C Pointer Events (shipped by IE Desktop, IE Mobile)
    • touch-action is part of the Pointer Events spec (shipped by Chrome, IE Desktop, IE Mobile)

Other documentation:

Planning

Current work:

  • Windows, Mac, Linux: Use async pan/zoom (APZ).
    • Status: disabled, can be tested in nightly builds with pref: layers.async-pan-zoom.enabled
    • Tracking bug
  • Windows, Mac, Linux: Support Pointer Events for mouse input.
    • Tracking bug
    • Status: enabled on nightly channel. Controlled by pref:
      • dom.w3c_pointer_events.enabled
  • Windows desktop: Support Pointer Events for touch input, and touch-action CSS property.
    • Status: Works on nightly channel when APZ and Pointer Events are both enabled.
    • CSS property is controlled by pref:
      • layout.css.touch_action.enabled
  • Windows desktop: Fix and enable Touch Events.
    • Status: disabled, can be tested in nightly builds with prefs:
      • dom.w3c_touch_events.enabled

Possible future work:

  • Linux desktop: Add support for touch events, pointer events, touch-action.
  • Firefox OS: Implement and enable pointer events and/or touch-action.
  • Android: Unify Android and Gecko APZC and viewport code.
  • Android: Implement Pointer Events and/or touch-action.
  • Layout: Implement CSS Device Adaptation to rationalize mobile viewport code (bug 747754).