1 #ifndef DALI_KEY_EVENT_DEVEL_H
\r
2 #define DALI_KEY_EVENT_DEVEL_H
\r
5 * Copyright (c) 2020 Samsung Electronics Co., Ltd.
\r
7 * Licensed under the Apache License, Version 2.0 (the "License");
\r
8 * you may not use this file except in compliance with the License.
\r
9 * You may obtain a copy of the License at
\r
11 * http://www.apache.org/licenses/LICENSE-2.0
\r
13 * Unless required by applicable law or agreed to in writing, software
\r
14 * distributed under the License is distributed on an "AS IS" BASIS,
\r
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
16 * See the License for the specific language governing permissions and
\r
17 * limitations under the License.
\r
21 // INTERNAL INCLUDES
\r
22 #include <dali/public-api/events/key-event.h>
\r
27 namespace DevelKeyEvent
\r
31 * @brief Creates an initialized WheelEvent.
\r
34 * @param[in] keyName The name of the key pressed or command from the IMF, if later then the some following parameters will be needed.
\r
35 * @param[in] logicalKey The logical key symbol (eg. shift + 1 == "exclamation")
\r
36 * @param[in] keyString The string of input characters or key pressed
\r
37 * @param[in] keyCode The unique key code for the key pressed.
\r
38 * @param[in] keyModifier The key modifier for special keys like shift and alt
\r
39 * @param[in] timeStamp The time (in ms) that the key event occurred.
\r
40 * @param[in] keyState The state of the key event.
\r
41 * @param[in] compose The key compose
\r
42 * @param[in] deviceName The name of device the key event originated from
\r
43 * @param[in] deviceClass The class of device the key event originated from
\r
44 * @param[in] deviceSubclass The subclass of device the key event originated from
\r
45 * @return A handle to a newly allocated Dali resource
\r
47 DALI_CORE_API KeyEvent New( const std::string& keyName,
\r
48 const std::string& logicalKey,
\r
49 const std::string& keyString,
\r
52 unsigned long timeStamp,
\r
53 const Dali::KeyEvent::State& keyState,
\r
54 const std::string& compose,
\r
55 const std::string& deviceName,
\r
56 const Device::Class::Type deviceClass,
\r
57 const Device::Subclass::Type deviceSubclass );
\r
60 * @brief Set the name given to the key pressed
\r
63 * @param[in] keyEvent The instance of KeyEvent.
\r
64 * @param[in] keyName The name given to the key pressed.
\r
66 void SetKeyName( KeyEvent keyEvent, const std::string& keyName );
\r
69 * @brief Set the actual string of input characters that should be used for input editors.
\r
72 * @param[in] keyEvent The instance of KeyEvent.
\r
73 * @param[in] keyString The actual string of input characters
\r
75 void SetKeyString( KeyEvent keyEvent, const std::string& keyString );
\r
78 * @brief Set the unique key code for the key pressed.
\r
81 * @param[in] keyEvent The instance of KeyEvent.
\r
82 * @param[in] keyCode The unique key code for the key pressed
\r
84 void SetKeyCode( KeyEvent keyEvent, int32_t keyCode );
\r
87 * @brief Set the key modifier for special keys like Shift, Alt and Ctrl which modify the next key pressed.
\r
90 * @param[in] keyEvent The instance of KeyEvent.
\r
91 * @param[in] keyModifier The key modifier
\r
93 void SetKeyModifier( KeyEvent keyEvent, int32_t keyModifier );
\r
96 * @brief Set the time (in ms) that the key event occurred.
\r
99 * @param[in] keyEvent The instance of KeyEvent.
\r
100 * @param[in] time The time (in ms)
\r
102 void SetTime( KeyEvent keyEvent, unsigned long time );
\r
105 * @brief Set the state of the key event.
\r
108 * @param[in] keyEvent The instance of KeyEvent.
\r
109 * @param[in] state The state of the key event
\r
111 void SetState( KeyEvent keyEvent, const KeyEvent::State& state );
\r
113 } // namespace DevelKeyEvent
\r
115 } // namespace Dali
\r
117 #endif // DALI_KEY_EVENT_DEVEL_H
\r