xref: /aosp_15_r20/frameworks/native/services/inputflinger/dispatcher/InputTargetFlags.h (revision 38e8c45f13ce32b0dcecb25141ffecaf386fa17f)
1*38e8c45fSAndroid Build Coastguard Worker /*
2*38e8c45fSAndroid Build Coastguard Worker  * Copyright 2024 The Android Open Source Project
3*38e8c45fSAndroid Build Coastguard Worker  *
4*38e8c45fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*38e8c45fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*38e8c45fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*38e8c45fSAndroid Build Coastguard Worker  *
8*38e8c45fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*38e8c45fSAndroid Build Coastguard Worker  *
10*38e8c45fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*38e8c45fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*38e8c45fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*38e8c45fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*38e8c45fSAndroid Build Coastguard Worker  * limitations under the License.
15*38e8c45fSAndroid Build Coastguard Worker  */
16*38e8c45fSAndroid Build Coastguard Worker 
17*38e8c45fSAndroid Build Coastguard Worker #pragma once
18*38e8c45fSAndroid Build Coastguard Worker 
19*38e8c45fSAndroid Build Coastguard Worker #include <ftl/flags.h>
20*38e8c45fSAndroid Build Coastguard Worker 
21*38e8c45fSAndroid Build Coastguard Worker namespace android::inputdispatcher {
22*38e8c45fSAndroid Build Coastguard Worker 
23*38e8c45fSAndroid Build Coastguard Worker enum class InputTargetFlags : uint32_t {
24*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that the event is being delivered to a foreground application. */
25*38e8c45fSAndroid Build Coastguard Worker     FOREGROUND = 1 << 0,
26*38e8c45fSAndroid Build Coastguard Worker 
27*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that the MotionEvent falls within the area of the target
28*38e8c45fSAndroid Build Coastguard Worker      * obscured by another visible window above it.  The motion event should be
29*38e8c45fSAndroid Build Coastguard Worker      * delivered with flag AMOTION_EVENT_FLAG_WINDOW_IS_OBSCURED. */
30*38e8c45fSAndroid Build Coastguard Worker     WINDOW_IS_OBSCURED = 1 << 1,
31*38e8c45fSAndroid Build Coastguard Worker 
32*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that a motion event is being split across multiple windows. */
33*38e8c45fSAndroid Build Coastguard Worker     SPLIT = 1 << 2,
34*38e8c45fSAndroid Build Coastguard Worker 
35*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that the pointer coordinates dispatched to the application
36*38e8c45fSAndroid Build Coastguard Worker      * will be zeroed out to avoid revealing information to an application. This is
37*38e8c45fSAndroid Build Coastguard Worker      * used in conjunction with FLAG_DISPATCH_AS_OUTSIDE to prevent apps not sharing
38*38e8c45fSAndroid Build Coastguard Worker      * the same UID from watching all touches. */
39*38e8c45fSAndroid Build Coastguard Worker     ZERO_COORDS = 1 << 3,
40*38e8c45fSAndroid Build Coastguard Worker 
41*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that the event will not cause a focus change if it is directed to an
42*38e8c45fSAndroid Build Coastguard Worker      * unfocused window, even if it an ACTION_DOWN. This is typically used to allow gestures to be
43*38e8c45fSAndroid Build Coastguard Worker      * directed to an unfocused window without bringing it into focus. The motion event should be
44*38e8c45fSAndroid Build Coastguard Worker      * delivered with flag AMOTION_EVENT_FLAG_NO_FOCUS_CHANGE. */
45*38e8c45fSAndroid Build Coastguard Worker     NO_FOCUS_CHANGE = 1 << 4,
46*38e8c45fSAndroid Build Coastguard Worker 
47*38e8c45fSAndroid Build Coastguard Worker     /* This flag indicates that the target of a MotionEvent is partly or wholly
48*38e8c45fSAndroid Build Coastguard Worker      * obscured by another visible window above it.  The motion event should be
49*38e8c45fSAndroid Build Coastguard Worker      * delivered with flag AMOTION_EVENT_FLAG_WINDOW_IS_PARTIALLY_OBSCURED. */
50*38e8c45fSAndroid Build Coastguard Worker     WINDOW_IS_PARTIALLY_OBSCURED = 1 << 14,
51*38e8c45fSAndroid Build Coastguard Worker };
52*38e8c45fSAndroid Build Coastguard Worker 
53*38e8c45fSAndroid Build Coastguard Worker } // namespace android::inputdispatcher
54