UIEvents.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. //
  2. // Copyright (c) 2008-2014 the Urho3D project.
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to deal
  6. // in the Software without restriction, including without limitation the rights
  7. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. // copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20. // THE SOFTWARE.
  21. //
  22. #pragma once
  23. #include "../Core/Object.h"
  24. namespace Atomic
  25. {
  26. EVENT(E_WIDGETEVENT, WidgetEvent)
  27. {
  28. PARAM(P_HANDLER, Handler); // UIWidget pointer of widget's OnEvent we are in
  29. PARAM(P_TARGET, Target); // UIWidget pointer
  30. PARAM(P_TYPE, Type); // EVENT_TYPE enum
  31. PARAM(P_X, X); // int
  32. PARAM(P_Y, Y); // int
  33. PARAM(P_DELTAX, DeltaX); // int
  34. PARAM(P_DELTAY, DeltaY); // int
  35. PARAM(P_COUNT, Count); // int
  36. PARAM(P_KEY, Key); // int
  37. PARAM(P_SPECIALKEY, SpecialKey); // enum SPECIAL_KEY
  38. PARAM(P_MODIFIERKEYS, ModifierKeys); // enum MODIFIER_KEYS
  39. PARAM(P_REFID, RefID); // unsigned (TBID)
  40. PARAM(P_TOUCH, Touch); // bool
  41. // EventHandled can be set by event receivers to stop event bubble
  42. PARAM(P_HANDLED, Handled); // [OUT] -> bool
  43. }
  44. EVENT(E_WIDGETLOADED, WidgetLoaded)
  45. {
  46. PARAM(P_WIDGET, Widget); // UIWidget pointer
  47. }
  48. EVENT(E_WIDGETDELETED, WidgetDeleted)
  49. {
  50. PARAM(P_WIDGET, Widget); // UIWidget pointer
  51. }
  52. EVENT(E_POPUPMENUSELECT, PopupMenuSelect)
  53. {
  54. PARAM(P_BUTTON, Button); // UIButton that created popup
  55. PARAM(P_REFID, RefID); // unsigned tbid
  56. }
  57. /// Mouse click in the UI.
  58. EVENT(E_UIMOUSECLICK, UIMouseClick)
  59. {
  60. PARAM(P_ELEMENT, Element); // UIElement pointer
  61. PARAM(P_X, X); // int
  62. PARAM(P_Y, Y); // int
  63. PARAM(P_BUTTON, Button); // int
  64. PARAM(P_BUTTONS, Buttons); // int
  65. PARAM(P_QUALIFIERS, Qualifiers); // int
  66. }
  67. /// Mouse click end in the UI.
  68. EVENT(E_UIMOUSECLICKEND, UIMouseClickEnd)
  69. {
  70. PARAM(P_ELEMENT, Element); // UIElement pointer
  71. PARAM(P_BEGINELEMENT, BeginElement); // UIElement pointer
  72. PARAM(P_X, X); // int
  73. PARAM(P_Y, Y); // int
  74. PARAM(P_BUTTON, Button); // int
  75. PARAM(P_BUTTONS, Buttons); // int
  76. PARAM(P_QUALIFIERS, Qualifiers); // int
  77. }
  78. /// Mouse double click in the UI.
  79. EVENT(E_UIMOUSEDOUBLECLICK, UIMouseDoubleClick)
  80. {
  81. PARAM(P_ELEMENT, Element); // UIElement pointer
  82. PARAM(P_X, X); // int
  83. PARAM(P_Y, Y); // int
  84. PARAM(P_BUTTON, Button); // int
  85. PARAM(P_BUTTONS, Buttons); // int
  86. PARAM(P_QUALIFIERS, Qualifiers); // int
  87. }
  88. /// Drag and drop test.
  89. EVENT(E_DRAGDROPTEST, DragDropTest)
  90. {
  91. PARAM(P_SOURCE, Source); // UIElement pointer
  92. PARAM(P_TARGET, Target); // UIElement pointer
  93. PARAM(P_ACCEPT, Accept); // bool
  94. };
  95. /// Drag and drop finish.
  96. EVENT(E_DRAGDROPFINISH, DragDropFinish)
  97. {
  98. PARAM(P_SOURCE, Source); // UIElement pointer
  99. PARAM(P_TARGET, Target); // UIElement pointer
  100. PARAM(P_ACCEPT, Accept); // bool
  101. };
  102. /// Focus element changed.
  103. EVENT(E_FOCUSCHANGED, FocusChanged)
  104. {
  105. PARAM(P_ELEMENT, Element); // UIElement pointer
  106. PARAM(P_CLICKEDELEMENT, ClickedElement); // UIElement pointer
  107. }
  108. /// UI element name changed.
  109. EVENT(E_NAMECHANGED, NameChanged)
  110. {
  111. PARAM(P_ELEMENT, Element); // UIElement pointer
  112. }
  113. /// UI element resized.
  114. EVENT(E_RESIZED, Resized)
  115. {
  116. PARAM(P_ELEMENT, Element); // UIElement pointer
  117. PARAM(P_WIDTH, Width); // int
  118. PARAM(P_HEIGHT, Height); // int
  119. }
  120. /// UI element positioned.
  121. EVENT(E_POSITIONED, Positioned)
  122. {
  123. PARAM(P_ELEMENT, Element); // UIElement pointer
  124. PARAM(P_X, X); // int
  125. PARAM(P_Y, Y); // int
  126. }
  127. /// UI element visibility changed.
  128. EVENT(E_VISIBLECHANGED, VisibleChanged)
  129. {
  130. PARAM(P_ELEMENT, Element); // UIElement pointer
  131. PARAM(P_VISIBLE, Visible); // bool
  132. }
  133. /// UI element focused.
  134. EVENT(E_FOCUSED, Focused)
  135. {
  136. PARAM(P_ELEMENT, Element); // UIElement pointer
  137. PARAM(P_BYKEY, ByKey); // bool
  138. }
  139. /// UI element defocused.
  140. EVENT(E_DEFOCUSED, Defocused)
  141. {
  142. PARAM(P_ELEMENT, Element); // UIElement pointer
  143. }
  144. /// UI element layout updated.
  145. EVENT(E_LAYOUTUPDATED, LayoutUpdated)
  146. {
  147. PARAM(P_ELEMENT, Element); // UIElement pointer
  148. }
  149. /// UI button pressed.
  150. EVENT(E_PRESSED, Pressed)
  151. {
  152. PARAM(P_ELEMENT, Element); // UIElement pointer
  153. }
  154. /// UI button was pressed, then released.
  155. EVENT(E_RELEASED, Released)
  156. {
  157. PARAM(P_ELEMENT, Element); // UIElement pointer
  158. }
  159. /// UI checkbox toggled.
  160. EVENT(E_TOGGLED, Toggled)
  161. {
  162. PARAM(P_ELEMENT, Element); // UIElement pointer
  163. PARAM(P_STATE, State); // bool
  164. }
  165. /// UI slider value changed
  166. EVENT(E_SLIDERCHANGED, SliderChanged)
  167. {
  168. PARAM(P_ELEMENT, Element); // UIElement pointer
  169. PARAM(P_VALUE, Value); // float
  170. }
  171. /// UI slider being paged.
  172. EVENT(E_SLIDERPAGED, SliderPaged)
  173. {
  174. PARAM(P_ELEMENT, Element); // UIElement pointer
  175. PARAM(P_OFFSET, Offset); // int
  176. PARAM(P_PRESSED, Pressed); // bool
  177. }
  178. /// UI scrollbar value changed.
  179. EVENT(E_SCROLLBARCHANGED, ScrollBarChanged)
  180. {
  181. PARAM(P_ELEMENT, Element); // UIElement pointer
  182. PARAM(P_VALUE, Value); // float
  183. }
  184. /// UI scrollview position changed.
  185. EVENT(E_VIEWCHANGED, ViewChanged)
  186. {
  187. PARAM(P_ELEMENT, Element); // UIElement pointer
  188. PARAM(P_X, X); // int
  189. PARAM(P_Y, Y); // int
  190. }
  191. /// UI modal changed (currently only Window has modal flag).
  192. EVENT(E_MODALCHANGED, ModalChanged)
  193. {
  194. PARAM(P_ELEMENT, Element); // UIElement pointer
  195. PARAM(P_MODAL, Modal); // bool
  196. }
  197. /// Text entry into a LineEdit. The char can be modified in the event data.
  198. EVENT(E_TEXTENTRY, CharEntry)
  199. {
  200. PARAM(P_ELEMENT, Element); // UIElement pointer
  201. PARAM(P_TEXT, Text); // String
  202. PARAM(P_BUTTONS, Buttons); // int
  203. PARAM(P_QUALIFIERS, Qualifiers); // int
  204. }
  205. /// Editable text changed
  206. EVENT(E_TEXTCHANGED, TextChanged)
  207. {
  208. PARAM(P_ELEMENT, Element); // UIElement pointer
  209. PARAM(P_TEXT, Text); // String
  210. }
  211. /// Text editing finished (enter pressed on a LineEdit)
  212. EVENT(E_TEXTFINISHED, TextFinished)
  213. {
  214. PARAM(P_ELEMENT, Element); // UIElement pointer
  215. PARAM(P_TEXT, Text); // String
  216. PARAM(P_VALUE, Value); // Float
  217. }
  218. /// Menu selected.
  219. EVENT(E_MENUSELECTED, MenuSelected)
  220. {
  221. PARAM(P_ELEMENT, Element); // UIElement pointer
  222. }
  223. /// Listview or DropDownList item selected.
  224. EVENT(E_ITEMSELECTED, ItemSelected)
  225. {
  226. PARAM(P_ELEMENT, Element); // UIElement pointer
  227. PARAM(P_SELECTION, Selection); // int
  228. }
  229. /// Listview item deselected.
  230. EVENT(E_ITEMDESELECTED, ItemDeselected)
  231. {
  232. PARAM(P_ELEMENT, Element); // UIElement pointer
  233. PARAM(P_SELECTION, Selection); // int
  234. }
  235. /// Listview selection change finished.
  236. EVENT(E_SELECTIONCHANGED, SelectionChanged)
  237. {
  238. PARAM(P_ELEMENT, Element); // UIElement pointer
  239. }
  240. /// Listview item clicked. If this is a left-click, also ItemSelected event will be sent. If this is a right-click, only this event is sent.
  241. EVENT(E_ITEMCLICKED, ItemClicked)
  242. {
  243. PARAM(P_ELEMENT, Element); // UIElement pointer
  244. PARAM(P_ITEM, Item); // UIElement pointer
  245. PARAM(P_SELECTION, Selection); // int
  246. PARAM(P_BUTTON, Button); // int
  247. PARAM(P_BUTTONS, Buttons); // int
  248. PARAM(P_QUALIFIERS, Qualifiers); // int
  249. }
  250. /// Listview item double clicked.
  251. EVENT(E_ITEMDOUBLECLICKED, ItemDoubleClicked)
  252. {
  253. PARAM(P_ELEMENT, Element); // UIElement pointer
  254. PARAM(P_ITEM, Item); // UIElement pointer
  255. PARAM(P_SELECTION, Selection); // int
  256. PARAM(P_BUTTON, Button); // int
  257. PARAM(P_BUTTONS, Buttons); // int
  258. PARAM(P_QUALIFIERS, Qualifiers); // int
  259. }
  260. /// LineEdit or ListView unhandled key pressed.
  261. EVENT(E_UNHANDLEDKEY, UnhandledKey)
  262. {
  263. PARAM(P_ELEMENT, Element); // UIElement pointer
  264. PARAM(P_KEY, Key); // int
  265. PARAM(P_BUTTONS, Buttons); // int
  266. PARAM(P_QUALIFIERS, Qualifiers); // int
  267. }
  268. /// Fileselector choice.
  269. EVENT(E_FILESELECTED, FileSelected)
  270. {
  271. PARAM(P_FILENAME, FileName); // String
  272. PARAM(P_FILTER, Filter); // String
  273. PARAM(P_OK, Ok); // bool
  274. }
  275. /// MessageBox acknowlegement.
  276. EVENT(E_MESSAGEACK, MessageACK)
  277. {
  278. PARAM(P_OK, Ok); // bool
  279. }
  280. /// A child element has been added to an element. Sent by the UI root element, or element-event-sender if set.
  281. EVENT(E_ELEMENTADDED, ElementAdded)
  282. {
  283. PARAM(P_ROOT, Root); // UIElement pointer
  284. PARAM(P_PARENT, Parent); // UIElement pointer
  285. PARAM(P_ELEMENT, Element); // UIElement pointer
  286. }
  287. /// A child element is about to be removed from an element. Sent by the UI root element, or element-event-sender if set.
  288. EVENT(E_ELEMENTREMOVED, ElementRemoved)
  289. {
  290. PARAM(P_ROOT, Root); // UIElement pointer
  291. PARAM(P_PARENT, Parent); // UIElement pointer
  292. PARAM(P_ELEMENT, Element); // UIElement pointer
  293. }
  294. /// Hovering on an UI element has started
  295. EVENT(E_HOVERBEGIN, HoverBegin)
  296. {
  297. PARAM(P_ELEMENT, Element); // UIElement pointer
  298. PARAM(P_X, X); // int
  299. PARAM(P_Y, Y); // int
  300. PARAM(P_ELEMENTX, ElementX); // int
  301. PARAM(P_ELEMENTY, ElementY); // int
  302. }
  303. /// Hovering on an UI element has ended
  304. EVENT(E_HOVEREND, HoverEnd)
  305. {
  306. PARAM(P_ELEMENT, Element); // UIElement pointer
  307. }
  308. /// Drag behavior of a UI Element has started
  309. EVENT(E_DRAGBEGIN, DragBegin)
  310. {
  311. PARAM(P_ELEMENT, Element); // UIElement pointer
  312. PARAM(P_X, X); // int
  313. PARAM(P_Y, Y); // int
  314. PARAM(P_ELEMENTX, ElementX); // int
  315. PARAM(P_ELEMENTY, ElementY); // int
  316. PARAM(P_BUTTONS, Buttons); // int
  317. PARAM(P_NUMBUTTONS, NumButtons); // int
  318. }
  319. /// Drag behavior of a UI Element when the input device has moved
  320. EVENT(E_DRAGMOVE, DragMove)
  321. {
  322. PARAM(P_ELEMENT, Element); // UIElement pointer
  323. PARAM(P_X, X); // int
  324. PARAM(P_Y, Y); // int
  325. PARAM(P_DX, DX); // int
  326. PARAM(P_DY, DY); // int
  327. PARAM(P_ELEMENTX, ElementX); // int
  328. PARAM(P_ELEMENTY, ElementY); // int
  329. PARAM(P_BUTTONS, Buttons); // int
  330. PARAM(P_NUMBUTTONS, NumButtons); // int
  331. }
  332. /// Drag behavior of a UI Element has finished
  333. EVENT(E_DRAGEND, DragEnd)
  334. {
  335. PARAM(P_ELEMENT, Element); // UIElement pointer
  336. PARAM(P_X, X); // int
  337. PARAM(P_Y, Y); // int
  338. PARAM(P_ELEMENTX, ElementX); // int
  339. PARAM(P_ELEMENTY, ElementY); // int
  340. PARAM(P_BUTTONS, Buttons); // int
  341. PARAM(P_NUMBUTTONS, NumButtons); // int
  342. }
  343. /// Drag of a UI Element was canceled by pressing ESC
  344. EVENT(E_DRAGCANCEL, DragCancel)
  345. {
  346. PARAM(P_ELEMENT, Element); // UIElement pointer
  347. PARAM(P_X, X); // int
  348. PARAM(P_Y, Y); // int
  349. PARAM(P_ELEMENTX, ElementX); // int
  350. PARAM(P_ELEMENTY, ElementY); // int
  351. PARAM(P_BUTTONS, Buttons); // int
  352. PARAM(P_NUMBUTTONS, NumButtons); // int
  353. }
  354. /// A file was drag-dropped into the application window. Includes also coordinates and UI element if applicable
  355. EVENT(E_UIDROPFILE, UIDropFile)
  356. {
  357. PARAM(P_FILENAME, FileName); // String
  358. PARAM(P_ELEMENT, Element); // UIElement pointer
  359. PARAM(P_X, X); // int
  360. PARAM(P_Y, Y); // int
  361. PARAM(P_ELEMENTX, ElementX); // int (only if element is non-null)
  362. PARAM(P_ELEMENTY, ElementY); // int (only if element is non-null)
  363. }
  364. }