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