/* * Copyright (C) 2010 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _UI_INPUT_MANAGER_H #define _UI_INPUT_MANAGER_H /** * Native input manager. */ #include "InputClassifier.h" #include "InputReaderBase.h" #include #include #include #include #include #include #include #include #include #include namespace android { class InputChannel; class InputDispatcherThread; /* * The input manager is the core of the system event processing. * * The input manager has two components. * * 1. The InputReader class starts a thread that reads and preprocesses raw input events, applies * policy, and posts messages to a queue managed by the InputDispatcherThread. * 2. The InputDispatcher class starts a thread that waits for new events on the * queue and asynchronously dispatches them to applications. * * By design, the InputReader class and InputDispatcher class do not share any * internal state. Moreover, all communication is done one way from the InputReader * into the InputDispatcherThread and never the reverse. Both classes may interact with the * InputDispatchPolicy, however. * * The InputManager class never makes any calls into Java itself. Instead, the * InputDispatchPolicy is responsible for performing all external interactions with the * system, including calling DVM services. */ class InputManagerInterface : public virtual RefBase { protected: InputManagerInterface() { } virtual ~InputManagerInterface() { } public: /* Starts the input threads. */ virtual status_t start() = 0; /* Stops the input threads and waits for them to exit. */ virtual status_t stop() = 0; /* Gets the input reader. */ virtual sp getReader() = 0; /* Gets the input dispatcher. */ virtual sp getDispatcher() = 0; }; class InputManager : public InputManagerInterface, public BnInputFlinger { protected: virtual ~InputManager(); public: InputManager( const sp& readerPolicy, const sp& dispatcherPolicy); virtual status_t start(); virtual status_t stop(); virtual sp getReader(); virtual sp getClassifier(); virtual sp getDispatcher(); virtual void setInputWindows(const std::vector& handles, const sp& setInputWindowsListener); virtual void registerInputChannel(const sp& channel); virtual void unregisterInputChannel(const sp& channel); void setMotionClassifierEnabled(bool enabled); private: sp mReader; sp mClassifier; sp mDispatcher; }; } // namespace android #endif // _UI_INPUT_MANAGER_H