UIEvents.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379
  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 "Object.h"
  24. namespace Urho3D
  25. {
  26. /// Mouse click in the UI.
  27. EVENT(E_UIMOUSECLICK, UIMouseClick)
  28. {
  29. PARAM(P_ELEMENT, Element); // UIElement pointer
  30. PARAM(P_X, X); // int
  31. PARAM(P_Y, Y); // int
  32. PARAM(P_BUTTON, Button); // int
  33. PARAM(P_BUTTONS, Buttons); // int
  34. PARAM(P_QUALIFIERS, Qualifiers); // int
  35. }
  36. /// Mouse click end in the UI.
  37. EVENT(E_UIMOUSECLICKEND, UIMouseClickEnd)
  38. {
  39. PARAM(P_ELEMENT, Element); // UIElement pointer
  40. PARAM(P_BEGINELEMENT, BeginElement); // UIElement pointer
  41. PARAM(P_X, X); // int
  42. PARAM(P_Y, Y); // int
  43. PARAM(P_BUTTON, Button); // int
  44. PARAM(P_BUTTONS, Buttons); // int
  45. PARAM(P_QUALIFIERS, Qualifiers); // int
  46. }
  47. /// Mouse double click in the UI.
  48. EVENT(E_UIMOUSEDOUBLECLICK, UIMouseDoubleClick)
  49. {
  50. PARAM(P_ELEMENT, Element); // UIElement pointer
  51. PARAM(P_X, X); // int
  52. PARAM(P_Y, Y); // int
  53. PARAM(P_BUTTON, Button); // int
  54. PARAM(P_BUTTONS, Buttons); // int
  55. PARAM(P_QUALIFIERS, Qualifiers); // int
  56. }
  57. /// Drag and drop test.
  58. EVENT(E_DRAGDROPTEST, DragDropTest)
  59. {
  60. PARAM(P_SOURCE, Source); // UIElement pointer
  61. PARAM(P_TARGET, Target); // UIElement pointer
  62. PARAM(P_ACCEPT, Accept); // bool
  63. };
  64. /// Drag and drop finish.
  65. EVENT(E_DRAGDROPFINISH, DragDropFinish)
  66. {
  67. PARAM(P_SOURCE, Source); // UIElement pointer
  68. PARAM(P_TARGET, Target); // UIElement pointer
  69. PARAM(P_ACCEPT, Accept); // bool
  70. };
  71. /// Focus element changed.
  72. EVENT(E_FOCUSCHANGED, FocusChanged)
  73. {
  74. PARAM(P_ELEMENT, Element); // UIElement pointer
  75. PARAM(P_CLICKEDELEMENT, ClickedElement); // UIElement pointer
  76. }
  77. /// UI element name changed.
  78. EVENT(E_NAMECHANGED, NameChanged)
  79. {
  80. PARAM(P_ELEMENT, Element); // UIElement pointer
  81. }
  82. /// UI element resized.
  83. EVENT(E_RESIZED, Resized)
  84. {
  85. PARAM(P_ELEMENT, Element); // UIElement pointer
  86. PARAM(P_WIDTH, Width); // int
  87. PARAM(P_HEIGHT, Height); // int
  88. }
  89. /// UI element positioned.
  90. EVENT(E_POSITIONED, Positioned)
  91. {
  92. PARAM(P_ELEMENT, Element); // UIElement pointer
  93. PARAM(P_X, X); // int
  94. PARAM(P_Y, Y); // int
  95. }
  96. /// UI element visibility changed.
  97. EVENT(E_VISIBLECHANGED, VisibleChanged)
  98. {
  99. PARAM(P_ELEMENT, Element); // UIElement pointer
  100. PARAM(P_VISIBLE, Visible); // bool
  101. }
  102. /// UI element focused.
  103. EVENT(E_FOCUSED, Focused)
  104. {
  105. PARAM(P_ELEMENT, Element); // UIElement pointer
  106. PARAM(P_BYKEY, ByKey); // bool
  107. }
  108. /// UI element defocused.
  109. EVENT(E_DEFOCUSED, Defocused)
  110. {
  111. PARAM(P_ELEMENT, Element); // UIElement pointer
  112. }
  113. /// UI element layout updated.
  114. EVENT(E_LAYOUTUPDATED, LayoutUpdated)
  115. {
  116. PARAM(P_ELEMENT, Element); // UIElement pointer
  117. }
  118. /// UI button pressed.
  119. EVENT(E_PRESSED, Pressed)
  120. {
  121. PARAM(P_ELEMENT, Element); // UIElement pointer
  122. }
  123. /// UI button was pressed, then released.
  124. EVENT(E_RELEASED, Released)
  125. {
  126. PARAM(P_ELEMENT, Element); // UIElement pointer
  127. }
  128. /// UI checkbox toggled.
  129. EVENT(E_TOGGLED, Toggled)
  130. {
  131. PARAM(P_ELEMENT, Element); // UIElement pointer
  132. PARAM(P_STATE, State); // bool
  133. }
  134. /// UI slider value changed
  135. EVENT(E_SLIDERCHANGED, SliderChanged)
  136. {
  137. PARAM(P_ELEMENT, Element); // UIElement pointer
  138. PARAM(P_VALUE, Value); // float
  139. }
  140. /// UI slider being paged.
  141. EVENT(E_SLIDERPAGED, SliderPaged)
  142. {
  143. PARAM(P_ELEMENT, Element); // UIElement pointer
  144. PARAM(P_OFFSET, Offset); // int
  145. PARAM(P_PRESSED, Pressed); // bool
  146. }
  147. /// UI scrollbar value changed.
  148. EVENT(E_SCROLLBARCHANGED, ScrollBarChanged)
  149. {
  150. PARAM(P_ELEMENT, Element); // UIElement pointer
  151. PARAM(P_VALUE, Value); // float
  152. }
  153. /// UI scrollview position changed.
  154. EVENT(E_VIEWCHANGED, ViewChanged)
  155. {
  156. PARAM(P_ELEMENT, Element); // UIElement pointer
  157. PARAM(P_X, X); // int
  158. PARAM(P_Y, Y); // int
  159. }
  160. /// UI modal changed (currently only Window has modal flag).
  161. EVENT(E_MODALCHANGED, ModalChanged)
  162. {
  163. PARAM(P_ELEMENT, Element); // UIElement pointer
  164. PARAM(P_MODAL, Modal); // bool
  165. }
  166. /// Text entry into a LineEdit. The char can be modified in the event data.
  167. EVENT(E_TEXTENTRY, CharEntry)
  168. {
  169. PARAM(P_ELEMENT, Element); // UIElement pointer
  170. PARAM(P_TEXT, Text); // String
  171. PARAM(P_BUTTONS, Buttons); // int
  172. PARAM(P_QUALIFIERS, Qualifiers); // int
  173. }
  174. /// Editable text changed
  175. EVENT(E_TEXTCHANGED, TextChanged)
  176. {
  177. PARAM(P_ELEMENT, Element); // UIElement pointer
  178. PARAM(P_TEXT, Text); // String
  179. }
  180. /// Text editing finished (enter pressed on a LineEdit)
  181. EVENT(E_TEXTFINISHED, TextFinished)
  182. {
  183. PARAM(P_ELEMENT, Element); // UIElement pointer
  184. PARAM(P_TEXT, Text); // String
  185. PARAM(P_VALUE, Value); // Float
  186. }
  187. /// Menu selected.
  188. EVENT(E_MENUSELECTED, MenuSelected)
  189. {
  190. PARAM(P_ELEMENT, Element); // UIElement pointer
  191. }
  192. /// Listview or DropDownList item selected.
  193. EVENT(E_ITEMSELECTED, ItemSelected)
  194. {
  195. PARAM(P_ELEMENT, Element); // UIElement pointer
  196. PARAM(P_SELECTION, Selection); // int
  197. }
  198. /// Listview item deselected.
  199. EVENT(E_ITEMDESELECTED, ItemDeselected)
  200. {
  201. PARAM(P_ELEMENT, Element); // UIElement pointer
  202. PARAM(P_SELECTION, Selection); // int
  203. }
  204. /// Listview selection change finished.
  205. EVENT(E_SELECTIONCHANGED, SelectionChanged)
  206. {
  207. PARAM(P_ELEMENT, Element); // UIElement pointer
  208. }
  209. /// 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.
  210. EVENT(E_ITEMCLICKED, ItemClicked)
  211. {
  212. PARAM(P_ELEMENT, Element); // UIElement pointer
  213. PARAM(P_ITEM, Item); // UIElement pointer
  214. PARAM(P_SELECTION, Selection); // int
  215. PARAM(P_BUTTON, Button); // int
  216. PARAM(P_BUTTONS, Buttons); // int
  217. PARAM(P_QUALIFIERS, Qualifiers); // int
  218. }
  219. /// Listview item double clicked.
  220. EVENT(E_ITEMDOUBLECLICKED, ItemDoubleClicked)
  221. {
  222. PARAM(P_ELEMENT, Element); // UIElement pointer
  223. PARAM(P_ITEM, Item); // UIElement pointer
  224. PARAM(P_SELECTION, Selection); // int
  225. PARAM(P_BUTTON, Button); // int
  226. PARAM(P_BUTTONS, Buttons); // int
  227. PARAM(P_QUALIFIERS, Qualifiers); // int
  228. }
  229. /// LineEdit or ListView unhandled key pressed.
  230. EVENT(E_UNHANDLEDKEY, UnhandledKey)
  231. {
  232. PARAM(P_ELEMENT, Element); // UIElement pointer
  233. PARAM(P_KEY, Key); // int
  234. PARAM(P_BUTTONS, Buttons); // int
  235. PARAM(P_QUALIFIERS, Qualifiers); // int
  236. }
  237. /// Fileselector choice.
  238. EVENT(E_FILESELECTED, FileSelected)
  239. {
  240. PARAM(P_FILENAME, FileName); // String
  241. PARAM(P_FILTER, Filter); // String
  242. PARAM(P_OK, Ok); // bool
  243. }
  244. /// MessageBox acknowlegement.
  245. EVENT(E_MESSAGEACK, MessageACK)
  246. {
  247. PARAM(P_OK, Ok); // bool
  248. }
  249. /// A child element has been added to an element. Sent by the UI root element, or element-event-sender if set.
  250. EVENT(E_ELEMENTADDED, ElementAdded)
  251. {
  252. PARAM(P_ROOT, Root); // UIElement pointer
  253. PARAM(P_PARENT, Parent); // UIElement pointer
  254. PARAM(P_ELEMENT, Element); // UIElement pointer
  255. }
  256. /// A child element is about to be removed from an element. Sent by the UI root element, or element-event-sender if set.
  257. EVENT(E_ELEMENTREMOVED, ElementRemoved)
  258. {
  259. PARAM(P_ROOT, Root); // UIElement pointer
  260. PARAM(P_PARENT, Parent); // UIElement pointer
  261. PARAM(P_ELEMENT, Element); // UIElement pointer
  262. }
  263. /// Hovering on an UI element has started
  264. EVENT(E_HOVERBEGIN, HoverBegin)
  265. {
  266. PARAM(P_ELEMENT, Element); // UIElement pointer
  267. PARAM(P_X, X); // int
  268. PARAM(P_Y, Y); // int
  269. PARAM(P_ELEMENTX, ElementX); // int
  270. PARAM(P_ELEMENTY, ElementY); // int
  271. }
  272. /// Hovering on an UI element has ended
  273. EVENT(E_HOVEREND, HoverEnd)
  274. {
  275. PARAM(P_ELEMENT, Element); // UIElement pointer
  276. }
  277. /// Drag behavior of a UI Element has started
  278. EVENT(E_DRAGBEGIN, DragBegin)
  279. {
  280. PARAM(P_ELEMENT, Element); // UIElement pointer
  281. PARAM(P_X, X); // int
  282. PARAM(P_Y, Y); // int
  283. PARAM(P_ELEMENTX, ElementX); // int
  284. PARAM(P_ELEMENTY, ElementY); // int
  285. PARAM(P_BUTTONS, Buttons); // int
  286. PARAM(P_NUMBUTTONS, NumButtons); // int
  287. }
  288. /// Drag behavior of a UI Element when the input device has moved
  289. EVENT(E_DRAGMOVE, DragMove)
  290. {
  291. PARAM(P_ELEMENT, Element); // UIElement pointer
  292. PARAM(P_X, X); // int
  293. PARAM(P_Y, Y); // int
  294. PARAM(P_DX, DX); // int
  295. PARAM(P_DY, DY); // int
  296. PARAM(P_ELEMENTX, ElementX); // int
  297. PARAM(P_ELEMENTY, ElementY); // int
  298. PARAM(P_BUTTONS, Buttons); // int
  299. PARAM(P_NUMBUTTONS, NumButtons); // int
  300. }
  301. /// Drag behavior of a UI Element has finished
  302. EVENT(E_DRAGEND, DragEnd)
  303. {
  304. PARAM(P_ELEMENT, Element); // UIElement pointer
  305. PARAM(P_X, X); // int
  306. PARAM(P_Y, Y); // int
  307. PARAM(P_ELEMENTX, ElementX); // int
  308. PARAM(P_ELEMENTY, ElementY); // int
  309. PARAM(P_BUTTONS, Buttons); // int
  310. PARAM(P_NUMBUTTONS, NumButtons); // int
  311. }
  312. /// Drag of a UI Element was canceled by pressing ESC
  313. EVENT(E_DRAGCANCEL, DragCancel)
  314. {
  315. PARAM(P_ELEMENT, Element); // UIElement pointer
  316. PARAM(P_X, X); // int
  317. PARAM(P_Y, Y); // int
  318. PARAM(P_ELEMENTX, ElementX); // int
  319. PARAM(P_ELEMENTY, ElementY); // int
  320. PARAM(P_BUTTONS, Buttons); // int
  321. PARAM(P_NUMBUTTONS, NumButtons); // int
  322. }
  323. /// A file was drag-dropped into the application window. Includes also coordinates and UI element if applicable
  324. EVENT(E_UIDROPFILE, UIDropFile)
  325. {
  326. PARAM(P_FILENAME, FileName); // String
  327. PARAM(P_ELEMENT, Element); // UIElement pointer
  328. PARAM(P_X, X); // int
  329. PARAM(P_Y, Y); // int
  330. PARAM(P_ELEMENTX, ElementX); // int (only if element is non-null)
  331. PARAM(P_ELEMENTY, ElementY); // int (only if element is non-null)
  332. }
  333. }