nxfe.h 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. /****************************************************************************
  2. * graphics/nxsu/nxfe.h
  3. *
  4. * Copyright (C) 2008-2010, 2013 Gregory Nutt. All rights reserved.
  5. * Author: Gregory Nutt <gnutt@nuttx.org>
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. *
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. * 2. Redistributions in binary form must reproduce the above copyright
  14. * notice, this list of conditions and the following disclaimer in
  15. * the documentation and/or other materials provided with the
  16. * distribution.
  17. * 3. Neither the name NuttX nor the names of its contributors may be
  18. * used to endorse or promote products derived from this software
  19. * without specific prior written permission.
  20. *
  21. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  22. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  23. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  24. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  25. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  26. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  27. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  28. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  29. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  31. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  32. * POSSIBILITY OF SUCH DAMAGE.
  33. *
  34. ****************************************************************************/
  35. #ifndef __GRAPHICS_NXSU_NXFE_H
  36. #define __GRAPHICS_NXSU_NXFE_H
  37. /****************************************************************************
  38. * Included Files
  39. ****************************************************************************/
  40. #include <nuttx/config.h>
  41. #include <mqueue.h>
  42. #include <semaphore.h>
  43. #include <nuttx/nx/nx.h>
  44. #include "nxbe.h"
  45. /****************************************************************************
  46. * Pre-Processor Definitions
  47. ****************************************************************************/
  48. /****************************************************************************
  49. * Public Types
  50. ****************************************************************************/
  51. /* Server state structure ***************************************************/
  52. /* This the server 'front-end' state structure. It is really the same
  53. * as the back-end state, but we wrap the back-end state so that we can add
  54. * things to the structure in the future
  55. */
  56. struct nxfe_state_s
  57. {
  58. /* The 'back-end' window status. Must be first so that instances of
  59. * struct nxbe_state_s can be simply cast to an instance of struct
  60. * nxfe_state_s
  61. */
  62. struct nxbe_state_s be;
  63. };
  64. /****************************************************************************
  65. * Public Data
  66. ****************************************************************************/
  67. #undef EXTERN
  68. #if defined(__cplusplus)
  69. #define EXTERN extern "C"
  70. extern "C" {
  71. #else
  72. #define EXTERN extern
  73. #endif
  74. EXTERN const struct nx_callback_s g_bkgdcb;
  75. /****************************************************************************
  76. * Public Functions
  77. ****************************************************************************/
  78. /****************************************************************************
  79. * Name: nxfe_constructwindow
  80. *
  81. * Description:
  82. * This function is the same a nx_openwindow EXCEPT that the client provides
  83. * the window structure instance. nx_constructwindow will initialize the
  84. * the pre-allocated window structure for use by NX. This function is
  85. * provided in addition to nx_open window in order to support a kind of
  86. * inheritance: The caller's window structure may include extensions that
  87. * are not visible to NX.
  88. *
  89. * NOTE: wnd must have been allocated using kmalloc() (or related allocators)
  90. * Once provided to nxfe_constructwindow() that memory is owned and managed
  91. * by NX. On certain error conditions or when the window is closed, NX will
  92. * free the window.
  93. *
  94. * Input Parameters:
  95. * handle - The handle returned by nx_connect
  96. * wnd - The pre-allocated window structure.
  97. * cb - Callbacks used to process window events
  98. * arg - User provided value that will be returned with NX callbacks.
  99. *
  100. * Return:
  101. * OK on success; ERROR on failure with errno set appropriately. In the
  102. * case of ERROR, NX will have dealloated the pre-allocated window.
  103. *
  104. ****************************************************************************/
  105. EXTERN int nxfe_constructwindow(NXHANDLE handle,
  106. FAR struct nxbe_window_s *wnd,
  107. FAR const struct nx_callback_s *cb,
  108. FAR void *arg);
  109. /****************************************************************************
  110. * Name: nxfe_redrawreq
  111. *
  112. * Descripton:
  113. * Request the client that has this window to redraw the rectangular region.
  114. *
  115. ****************************************************************************/
  116. EXTERN void nxfe_redrawreq(FAR struct nxbe_window_s *wnd,
  117. FAR const struct nxgl_rect_s *rect);
  118. /****************************************************************************
  119. * Name: nxfe_reportposition
  120. *
  121. * Descripton:
  122. * Report the new size/position of the window.
  123. *
  124. ****************************************************************************/
  125. EXTERN void nxfe_reportposition(FAR struct nxbe_window_s *wnd);
  126. /****************************************************************************
  127. * Name: nxmu_mouseinit
  128. *
  129. * Description:
  130. * Initialize with the mouse in the center of the display
  131. *
  132. ****************************************************************************/
  133. #ifdef CONFIG_NX_MOUSE
  134. EXTERN void nxsu_mouseinit(int x, int y);
  135. #endif
  136. /****************************************************************************
  137. * Name: nxmu_mousereport
  138. *
  139. * Description:
  140. * Report mouse position info to the specified window
  141. *
  142. * Input Parameters:
  143. * wnd - The window to receive the mouse report
  144. *
  145. * Returned Value:
  146. * 0: Mouse report sent; >0: Mouse report not sent; <0: An error occurred
  147. *
  148. ****************************************************************************/
  149. #ifdef CONFIG_NX_MOUSE
  150. EXTERN int nxsu_mousereport(struct nxbe_window_s *wnd);
  151. #endif
  152. #undef EXTERN
  153. #if defined(__cplusplus)
  154. }
  155. #endif
  156. #endif /* __GRAPHICS_NXSU_NXFE_H */