Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fold touchEvents from extensions.html into index.html #198

Open
wants to merge 10 commits into
base: gh-pages
Choose a base branch
from

Conversation

bradleyneedham
Copy link
Contributor

@bradleyneedham bradleyneedham commented Apr 9, 2024

@bradleyneedham
Copy link
Contributor Author

bradleyneedham commented Apr 9, 2024

I believe the failure of the tidy action is an indentation error on line 19 of .github/workflows/tidy.yml. The with needs to be even with the start of uses.
Current is:

line 18:             - uses:
line 19:             with:

Should be:

line 18:             - uses:
line 19:               with:

@bradleyneedham bradleyneedham force-pushed the issue-165-fold-touchEvents-into-main-spec branch 2 times, most recently from 8ec7959 to a4649ca Compare April 12, 2024 00:42
@bradleyneedham
Copy link
Contributor Author

I am moving this from "Draft". Any help with spotting the reason for the validate failure is appreciated.

Also I think that newline: LF should be added to the tidyconfig.txt to prevent local runs of tidy on windows from adding all CRLF.

@bradleyneedham bradleyneedham marked this pull request as ready for review April 12, 2024 00:58
@marcoscaceres
Copy link
Member

@bradleyneedham, sorry, I just need to double check if this is in scope of the Working Group. I seem to recall there was some concerns from some members around anything "touch" related, so just need to make sure it's all fine.

Shouldn't be too long!

index.html Outdated
@@ -2238,6 +2451,24 @@ <h2>
</p>
</div>
</section>
<section>
<h3>
Glossary
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should really be part of a Model section... or wherever the general idea of gamepad is defined.

index.html Outdated
Glossary
</h3>
<p>
<dfn>touch surface</dfn> is a surface that can detect contact from a
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<dfn>touch surface</dfn> is a surface that can detect contact from a
<dfn data-dfn-for="gamepad">touch surface</dfn> is a surface that can detect contact from a

index.html Outdated
users fingers and report where on the surface the contact is made.
</p>
<p>
<dfn>touch surface enumeration order</dfn> is an ordered listing of all
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<dfn>touch surface enumeration order</dfn> is an ordered listing of all
<dfn data-dfn-for="gamepad">touch surface enumeration order</dfn> is an ordered listing of all

index.html Outdated
the surfaces in a |gamepad|.
</p>
<p>
<dfn>active touch point</dfn> is defined in the <a href=
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a concept we can maybe use from Pointer Events instead?

index.html Outdated
`null`
</td>
<td>
List of generated touch events.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, so... are these really touch "events"? If we look at GamepadTouch, it's not an "Event" at all, so this is a misnomer.

They are more like snapshots of touch points.

index.html Outdated
@@ -460,6 +472,26 @@ <h2>
</li>
</ol>
</dd>
<dt>
<dfn>touchEvents</dfn>
Copy link
Member

@marcoscaceres marcoscaceres May 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As above... I think it's incorrect to call these "touch events". They are activation points on the track pad at some specific moment in time.

index.html Outdated
<ol class="algorithm">
<li>Let |surfaceId:unsigned long| be 0.
</li>
<li>Remove any existing events from
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems to assume the gamepad is a live object? I don't think this correct. Each gamepad object is just a snapshot in time.

index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
index.html Outdated
Comment on lines 1188 to 1189
readonly attribute Float32Array position;
readonly attribute Uint32Array? surfaceDimensions;
Copy link
Member

@marcoscaceres marcoscaceres Jun 13, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
readonly attribute Float32Array position;
readonly attribute Uint32Array? surfaceDimensions;
Float32Array position;
Uint32Array surfaceDimensions;

index.html Outdated
@@ -153,6 +153,7 @@ <h2>
readonly attribute GamepadMappingType mapping;
readonly attribute FrozenArray&lt;double&gt; axes;
readonly attribute FrozenArray&lt;GamepadButton&gt; buttons;
readonly attribute FrozenArray&lt;GamepadTouch&gt;? touchEvents;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
readonly attribute FrozenArray&lt;GamepadTouch&gt;? touchEvents;
readonly attribute FrozenArray&lt;GamepadTouch&gt;? touches;

@bradleyneedham
Copy link
Contributor Author

Just getting to back to this and wanted to verify our discussion at the last meeting.
In general is the following the suggested approach?

        dictionary GamepadTouch {
          unsigned long touchId;
          Float32Array position;
        };

        dictionary GamepadSurface {
          octet surfaceId;
          FrozenArray&lt;GamepadTouch&gt;? touches;
          Uint32Array surfaceDimensions;
        };

        interface Gamepad {
...
          readonly attribute FrozenArray&lt;GamepadSurface&gt;? surfaces;
...
        };

@nondebug
Copy link
Collaborator

If I remember correctly, we decided on maplike interfaces for the surfaceId -> GamepadSurface and touchId -> sequence<GamepadTouch> maps. I think it should look something like this:

        dictionary GamepadTouch {
          Float32Array position;
        };

        interface GamepadTouchMap {
          readonly maplike<unsigned long, sequence<GamepadTouch>>;
        };

        dictionary GamepadSurface {
          GamepadTouchMap touches;
          Uint32Array surfaceDimensions;
        };

        interface GamepadSurfaceMap {
          readonly maplike<octet, GamepadSurface>;
        };

        interface Gamepad {
...
          readonly attribute GamepadSurfaceMap surfaces;
...
        };

index.html Outdated
`null`
</td>
<td>
List of generated touch events.
Copy link
Member

@marcoscaceres marcoscaceres Jul 11, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
List of generated touch events.
A [=list=] of touch that are represented as {{GamepadTouch}}s. The ordering is hardware or platform specific.

@bradleyneedham bradleyneedham force-pushed the issue-165-fold-touchEvents-into-main-spec branch from 926ef0f to 0d65b74 Compare September 23, 2024 17:05
@bradleyneedham bradleyneedham force-pushed the issue-165-fold-touchEvents-into-main-spec branch from c3160a0 to 436b0c1 Compare November 14, 2024 19:48
A list of all the {{GamepadHapticActuator}}s in the gamepad. The same object
MUST be returned until the user agent needs to return different
values (or values in a different order).
A list of all the {{GamepadHapticActuator}}s in the gamepad. The same
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note: this is an optimization... as you say, this can't be assured.

index.html Outdated Show resolved Hide resolved
index.html Outdated
</dt>
<dd>
<p>
A list of {{GamepadTouch}} events generated from all touch
Copy link
Member

@marcoscaceres marcoscaceres Nov 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
A list of {{GamepadTouch}} events generated from all touch
A [=list=] of {{GamepadTouch}} generated from all touch

index.html Outdated
Comment on lines 481 to 482
surfaces. If the device does not support touch events, MUST be set
to `null`.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's make it empty.

index.html Outdated Show resolved Hide resolved
index.html Outdated
Comment on lines 688 to 687
<li>Remove any existing events from
{{Gamepad}}.{{Gamepad/[[touches]]}}.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<li>Remove any existing events from
{{Gamepad}}.{{Gamepad/[[touches]]}}.
<li>[=List/empty=] {{Gamepad}}.{{Gamepad/[[touches]]}}.

index.html Outdated
Comment on lines 699 to 704
<li>Set |touchEvent|.{{GamepadTouch/surfaceDimensions}}[0] to
the maximum X dimension on the touch surface in device units.
</li>
<li>Set |touchEvent|.{{GamepadTouch/surfaceDimensions}}[1] to
the maximum Y dimension on the touch surface in device units.
</li>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Use DOMRect/point terminology.

index.html Outdated
<li>If the touch surface exposes maximum surface dimensions in
device units:
<ol>
<li>Set |touchEvent|.{{GamepadTouch/surfaceDimensions}}[0] to
Copy link
Member

@marcoscaceres marcoscaceres Nov 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note, move away from calling it "*Event". Call it |gameTouch|, and

Suggested change
<li>Set |touchEvent|.{{GamepadTouch/surfaceDimensions}}[0] to
<li>Let |gamepadTouch| be a newly created {{GamepadTouch}.</li>
<li>Set |gamepadTouch|.{{GamepadTouch/surfaceDimensions}}[0] to

index.html Outdated
</li>
</ol>
</li>
<li>Increment |surfaceId|
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oops, increment twice

index.html Outdated Show resolved Hide resolved
<li>Maintaining the uniqueness of the id per origin to prevent
fingerprinting.
</li>
</ul>{{GamepadTouch/touchId}} SHOULD be set to a default value of 0
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instead of using 0 here, should we store a touchId counter in an internal slot somewhere? Maybe in the target Gamepad object?

index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
index.html Outdated Show resolved Hide resolved
@bradleyneedham bradleyneedham force-pushed the issue-165-fold-touchEvents-into-main-spec branch from 141c3a2 to 4a85ea0 Compare January 9, 2025 20:28
The {{Gamepad/touches}} getter steps are:
</p>
<ol>
<li>Return whatever is in the internal slot.
Copy link
Member

@marcoscaceres marcoscaceres Jan 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<li>Return whatever is in the internal slot.
<li>Return the [=list=] of the {{Gamepad/[[touches]]} internal slot.

<dfn data-dfn-for="Gamepad">[[\touches]]</dfn>
</td>
<td>
An empty [=list=]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
An empty [=list=]
Initialize to an [=list/empty=] [=list=]

An empty [=list=]
</td>
<td>
List of generated touches.
Copy link
Member

@marcoscaceres marcoscaceres Jan 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
List of generated touches.
Holds the list of user-generated touches, if any. If the gamepad does not support touch surfaces, then the list will remain empty.

Comment on lines +481 to +482
surfaces. If the device does not support touches, then an empty
[=list=].
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
surfaces. If the device does not support touches, then an empty
[=list=].
surfaces.

@@ -507,6 +536,8 @@ <h3>
</li>
<li>Run the steps to [=map and normalize buttons=] for |gamepad|.
</li>
<li>Run the steps to [=refresh touches=] for |gamepad|.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<li>Run the steps to [=refresh touches=] for |gamepad|.
<li>Run the steps to [=record touches=] for |gamepad|.

@@ -644,6 +675,74 @@ <h3>
</ol>
</li>
</ol>
<p>
To <dfn>refresh touches</dfn> for |gamepad:Gamepad|, run the
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
To <dfn>refresh touches</dfn> for |gamepad:Gamepad|, run the
To <dfn>record touches</dfn> for |gamepad:Gamepad|, run the

Comment on lines +683 to +685
<li>Remove any existing objects from
{{Gamepad}}.{{Gamepad/[[touches]]}}.
</li>
Copy link
Member

@marcoscaceres marcoscaceres Jan 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<li>Remove any existing objects from
{{Gamepad}}.{{Gamepad/[[touches]]}}.
</li>
<li>Assert: {{Gamepad}}.{{Gamepad/[[touches]]}} is [=list/empty=].
</li>

<li>Let |nextTouchId:unsigned long| be the next available
touchId for the |gamepad|.
</li>
<li>Let |touch:GamepadTouch| be a {{GamepadTouch}}.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<li>Let |touch:GamepadTouch| be a {{GamepadTouch}}.
<li>Let |touch:GamepadTouch| be a newly created {{GamepadTouch}} object.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Fold extensions.html into main spec
4 participants