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