Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 module viz.hit_test.mojom; | |
| 6 | |
| 7 import "cc/ipc/surface_id.mojom"; | |
| 8 import "ui/gfx/geometry/mojo/geometry.mojom"; | |
| 9 import "ui/gfx/mojo/transform.mojom"; | |
| 10 | |
| 11 // Region maps to this surface ( me ). | |
| 12 const uint32 kHitTestMine = 0x01; | |
| 13 | |
| 14 // Region ignored for hit testing ( transparent backgrounds & hover:none ). | |
| 15 const uint32 kHitTestIgnore = 0x02; | |
| 16 | |
| 17 // Region maps to child surface ( OOPIF ). | |
| 18 const uint32 kHitTestChildSurface = 0x04; | |
| 19 | |
| 20 // Irregular boundary - send HitTestRequest to resolve. | |
| 21 const uint32 kHitTestAsk = 0x08; | |
| 22 | |
| 23 // No touch event handler exists - no need to send touch events. | |
| 24 const uint32 kHitTestNoTouchEventHandler = 0x10; | |
|
sadrul
2017/06/27 04:23:35
As mentioned in https://codereview.chromium.org/29
gklassen
2017/06/27 21:46:33
Hmmm... I reviewed this implementation in detail,
| |
| 25 | |
| 26 struct HitTestRegion { | |
| 27 | |
|
sadrul
2017/06/27 04:23:35
no blank line.
gklassen
2017/06/27 21:46:33
Done.
| |
| 28 // Flags to indicate the type of HitTestRegion. | |
| 29 uint32 flags; | |
| 30 | |
| 31 // SurfaceId is required when flags = kHitTestChildSurface. | |
| 32 cc.mojom.SurfaceId surface_id; | |
| 33 | |
| 34 // The rect of the region in the coordinate space of the embedder. | |
| 35 gfx.mojom.Rect rect; | |
| 36 | |
| 37 // The transform applied to the child region. | |
|
sadrul
2017/06/27 04:23:35
What is 'child region'? (https://codereview.chromi
gklassen
2017/06/27 21:46:33
Done.
| |
| 38 gfx.mojom.Transform transform; | |
| 39 }; | |
| 40 | |
| 41 struct HitTestData { | |
| 42 | |
|
sadrul
2017/06/27 04:23:35
ditto
gklassen
2017/06/27 21:46:33
Done.
| |
| 43 // SurfaceId corresponding to this HitTestData. | |
| 44 cc.mojom.SurfaceId surface_id; | |
| 45 | |
| 46 // Flags indicate how to handle events that match no sub-regions. | |
| 47 // kHitTestMine routes un-matched events to this surface ( opaque ). | |
| 48 // kHitTestIgnore keeps previous match in the parent ( transparent ). | |
| 49 uint32 flags; | |
| 50 | |
| 51 // The bounds of the surface. | |
| 52 gfx.mojom.Rect bounds; | |
| 53 | |
| 54 // The transform that applies to all regions in this surface. | |
| 55 gfx.mojom.Transform transform; | |
| 56 | |
| 57 // The list of sub-regions in front to back order. | |
| 58 // TODO(gklassen): invert order if it's easier to write them back to front. | |
| 59 array<HitTestRegion> regions; | |
|
sadrul
2017/06/27 04:23:35
As mentioned in Ria's CL, I think I would go with
gklassen
2017/06/27 21:46:33
Agreed that neither is clearly a list of the other
sadrul
2017/06/28 05:27:40
I think the distinction between the two that matte
gklassen
2017/06/28 16:29:59
Done.
| |
| 60 }; | |
| OLD | NEW |