1a3e0fd82Sopenharmony_ci/* 2a3e0fd82Sopenharmony_ci * Copyright (c) 2020-2021 Huawei Device Co., Ltd. 3a3e0fd82Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4a3e0fd82Sopenharmony_ci * you may not use this file except in compliance with the License. 5a3e0fd82Sopenharmony_ci * You may obtain a copy of the License at 6a3e0fd82Sopenharmony_ci * 7a3e0fd82Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8a3e0fd82Sopenharmony_ci * 9a3e0fd82Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10a3e0fd82Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11a3e0fd82Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12a3e0fd82Sopenharmony_ci * See the License for the specific language governing permissions and 13a3e0fd82Sopenharmony_ci * limitations under the License. 14a3e0fd82Sopenharmony_ci */ 15a3e0fd82Sopenharmony_ci 16a3e0fd82Sopenharmony_ci/** 17a3e0fd82Sopenharmony_ci * @addtogroup UI_Events 18a3e0fd82Sopenharmony_ci * @{ 19a3e0fd82Sopenharmony_ci * 20a3e0fd82Sopenharmony_ci * @brief Defines UI events, such as press, click and drag events. 21a3e0fd82Sopenharmony_ci * 22a3e0fd82Sopenharmony_ci * @since 1.0 23a3e0fd82Sopenharmony_ci * @version 1.0 24a3e0fd82Sopenharmony_ci */ 25a3e0fd82Sopenharmony_ci 26a3e0fd82Sopenharmony_ci/** 27a3e0fd82Sopenharmony_ci * @file virtual_device_event.h 28a3e0fd82Sopenharmony_ci * 29a3e0fd82Sopenharmony_ci * @brief Declares a virtual device event, which is used to receive a customized input event and call back 30a3e0fd82Sopenharmony_ci * the listening function registered. 31a3e0fd82Sopenharmony_ci * 32a3e0fd82Sopenharmony_ci * @since 1.0 33a3e0fd82Sopenharmony_ci * @version 1.0 34a3e0fd82Sopenharmony_ci */ 35a3e0fd82Sopenharmony_ci 36a3e0fd82Sopenharmony_ci#ifndef GRAPHIC_LITE_VIRTUAL_DEVICE_EVENT_H 37a3e0fd82Sopenharmony_ci#define GRAPHIC_LITE_VIRTUAL_DEVICE_EVENT_H 38a3e0fd82Sopenharmony_ci 39a3e0fd82Sopenharmony_ci#include "event.h" 40a3e0fd82Sopenharmony_ci 41a3e0fd82Sopenharmony_cinamespace OHOS { 42a3e0fd82Sopenharmony_ci/** 43a3e0fd82Sopenharmony_ci * @brief Defines a virtual device event, which is used to receive a customized input event and call back 44a3e0fd82Sopenharmony_ci * the listening function registered. 45a3e0fd82Sopenharmony_ci * 46a3e0fd82Sopenharmony_ci * @since 1.0 47a3e0fd82Sopenharmony_ci * @version 1.0 48a3e0fd82Sopenharmony_ci */ 49a3e0fd82Sopenharmony_ciclass VirtualDeviceEvent : public Event { 50a3e0fd82Sopenharmony_cipublic: 51a3e0fd82Sopenharmony_ci VirtualDeviceEvent() = delete; 52a3e0fd82Sopenharmony_ci 53a3e0fd82Sopenharmony_ci /** 54a3e0fd82Sopenharmony_ci * @brief A constructor used to create a <b>VirtualDeviceEvent</b> instance. 55a3e0fd82Sopenharmony_ci * 56a3e0fd82Sopenharmony_ci * @param type Indicates the virtual device type. The options are <b>AOD</b> and <b>PRIVATE</b>. 57a3e0fd82Sopenharmony_ci * @param value Indicates the virtual event value. 58a3e0fd82Sopenharmony_ci * @since 1.0 59a3e0fd82Sopenharmony_ci * @version 1.0 60a3e0fd82Sopenharmony_ci */ 61a3e0fd82Sopenharmony_ci VirtualDeviceEvent(uint16_t type, uint16_t value) : type_(type), state_(value) {} 62a3e0fd82Sopenharmony_ci 63a3e0fd82Sopenharmony_ci /** 64a3e0fd82Sopenharmony_ci * @brief A destructor used to delete the <b>VirtualDeviceEvent</b> instance. 65a3e0fd82Sopenharmony_ci * 66a3e0fd82Sopenharmony_ci * @since 1.0 67a3e0fd82Sopenharmony_ci * @version 1.0 68a3e0fd82Sopenharmony_ci */ 69a3e0fd82Sopenharmony_ci ~VirtualDeviceEvent() {} 70a3e0fd82Sopenharmony_ci 71a3e0fd82Sopenharmony_ci /** 72a3e0fd82Sopenharmony_ci * @brief Enumerates virtual device types. 73a3e0fd82Sopenharmony_ci * 74a3e0fd82Sopenharmony_ci */ 75a3e0fd82Sopenharmony_ci enum DeviceType { 76a3e0fd82Sopenharmony_ci AOD, // Standby event 77a3e0fd82Sopenharmony_ci PRIVATE, // Other customized events 78a3e0fd82Sopenharmony_ci }; 79a3e0fd82Sopenharmony_ci 80a3e0fd82Sopenharmony_ci /** 81a3e0fd82Sopenharmony_ci * @brief Obtains the type of the virtual device. 82a3e0fd82Sopenharmony_ci * 83a3e0fd82Sopenharmony_ci * @return Returns the type. 84a3e0fd82Sopenharmony_ci * @since 1.0 85a3e0fd82Sopenharmony_ci * @version 1.0 86a3e0fd82Sopenharmony_ci */ 87a3e0fd82Sopenharmony_ci uint16_t GetType() const 88a3e0fd82Sopenharmony_ci { 89a3e0fd82Sopenharmony_ci return type_; 90a3e0fd82Sopenharmony_ci } 91a3e0fd82Sopenharmony_ci 92a3e0fd82Sopenharmony_ci /** 93a3e0fd82Sopenharmony_ci * @brief Obtains the state of the virtual event. 94a3e0fd82Sopenharmony_ci * 95a3e0fd82Sopenharmony_ci * @return Returns the state. 96a3e0fd82Sopenharmony_ci * @since 1.0 97a3e0fd82Sopenharmony_ci * @version 1.0 98a3e0fd82Sopenharmony_ci */ 99a3e0fd82Sopenharmony_ci uint16_t GetState() const 100a3e0fd82Sopenharmony_ci { 101a3e0fd82Sopenharmony_ci return state_; 102a3e0fd82Sopenharmony_ci } 103a3e0fd82Sopenharmony_ci 104a3e0fd82Sopenharmony_ciprivate: 105a3e0fd82Sopenharmony_ci uint16_t type_; 106a3e0fd82Sopenharmony_ci uint16_t state_; 107a3e0fd82Sopenharmony_ci static constexpr uint16_t INVALID_VIRTUAL_INPUT_STATE = UINT16_MAX; 108a3e0fd82Sopenharmony_ci}; 109a3e0fd82Sopenharmony_ci} // namespace OHOS 110a3e0fd82Sopenharmony_ci#endif // GRAPHIC_LITE_VIRTUAL_DEVICE_EVENT_H 111