view.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. /*
  2. * File : view.c
  3. * This file is part of RT-Thread RTOS
  4. * COPYRIGHT (C) 2006 - 2009, RT-Thread Development Team
  5. *
  6. * The license and distribution terms for this file may be
  7. * found in the file LICENSE in this distribution or at
  8. * http://www.rt-thread.org/license/LICENSE
  9. *
  10. * Change Logs:
  11. * Date Author Notes
  12. * 2009-10-16 Bernard first version
  13. */
  14. #include <rtgui/dc.h>
  15. #include <rtgui/rtgui_system.h>
  16. #include <rtgui/widgets/view.h>
  17. #include <rtgui/widgets/workbench.h>
  18. static void _rtgui_view_constructor(rtgui_view_t *view)
  19. {
  20. /* init view */
  21. rtgui_widget_set_event_handler(RTGUI_WIDGET(view),
  22. rtgui_view_event_handler);
  23. view->modal_show = RT_FALSE;
  24. view->title = RT_NULL;
  25. }
  26. static void _rtgui_view_destructor(rtgui_view_t *view)
  27. {
  28. /* remove view from workbench */
  29. if (RTGUI_WIDGET(view)->parent != RT_NULL)
  30. {
  31. rtgui_workbench_t *workbench;
  32. if (view->modal_show == RT_TRUE)
  33. rtgui_view_end_modal(view, RTGUI_MODAL_CANCEL);
  34. workbench = RTGUI_WORKBENCH(RTGUI_WIDGET(view)->parent);
  35. rtgui_workbench_remove_view(workbench, view);
  36. }
  37. if (view->title != RT_NULL)
  38. {
  39. rt_free(view->title);
  40. view->title = RT_NULL;
  41. }
  42. }
  43. rtgui_type_t *rtgui_view_type_get(void)
  44. {
  45. static rtgui_type_t *view_type = RT_NULL;
  46. if (!view_type)
  47. {
  48. view_type = rtgui_type_create("view", RTGUI_CONTAINER_TYPE,
  49. sizeof(rtgui_view_t),
  50. RTGUI_CONSTRUCTOR(_rtgui_view_constructor),
  51. RTGUI_DESTRUCTOR(_rtgui_view_destructor));
  52. }
  53. return view_type;
  54. }
  55. rt_bool_t rtgui_view_event_handler(struct rtgui_widget* widget, struct rtgui_event* event)
  56. {
  57. struct rtgui_view* view = (struct rtgui_view*) widget;
  58. RT_ASSERT(widget != RT_NULL);
  59. switch (event->type)
  60. {
  61. case RTGUI_EVENT_PAINT:
  62. if (widget->on_draw != RT_NULL) widget->on_draw(widget, event);
  63. else
  64. {
  65. struct rtgui_dc* dc;
  66. struct rtgui_rect rect;
  67. dc = rtgui_dc_begin_drawing(widget);
  68. if (dc == RT_NULL) return RT_FALSE;
  69. rtgui_widget_get_rect(widget, &rect);
  70. /* fill view with background */
  71. rtgui_dc_fill_rect(dc, &rect);
  72. /* paint on each child */
  73. rtgui_container_dispatch_event(RTGUI_CONTAINER(view), event);
  74. rtgui_dc_end_drawing(dc);
  75. }
  76. break;
  77. default:
  78. return rtgui_container_event_handler(widget, event);
  79. }
  80. return RT_FALSE;
  81. }
  82. rtgui_view_t* rtgui_view_create(const char* title)
  83. {
  84. struct rtgui_view* view;
  85. /* allocate view */
  86. view = (struct rtgui_view*) rtgui_widget_create (RTGUI_VIEW_TYPE);
  87. if (view != RT_NULL)
  88. {
  89. if (title != RT_NULL)
  90. view->title = rt_strdup(title);
  91. }
  92. return view;
  93. }
  94. void rtgui_view_destroy(rtgui_view_t* view)
  95. {
  96. rtgui_widget_destroy(RTGUI_WIDGET(view));
  97. }
  98. void rtgui_view_set_box(rtgui_view_t* view, rtgui_box_t* box)
  99. {
  100. if (view == RT_NULL ||
  101. box == RT_NULL) return;
  102. rtgui_container_add_child(RTGUI_CONTAINER(view), RTGUI_WIDGET(box));
  103. rtgui_widget_set_rect(RTGUI_WIDGET(box), &(RTGUI_WIDGET(view)->extent));
  104. }
  105. rtgui_modal_code_t rtgui_view_show(rtgui_view_t* view, rt_bool_t is_modal)
  106. {
  107. rtgui_workbench_t* workbench;
  108. /* parameter check */
  109. if (view == RT_NULL) return RTGUI_MODAL_CANCEL;
  110. if (RTGUI_WIDGET(view)->parent == RT_NULL)
  111. {
  112. RTGUI_WIDGET_UNHIDE(RTGUI_WIDGET(view));
  113. return RTGUI_MODAL_CANCEL;
  114. }
  115. workbench = RTGUI_WORKBENCH(RTGUI_WIDGET(view)->parent);
  116. rtgui_workbench_show_view(workbench, view);
  117. if (RTGUI_WIDGET_IS_FOCUSABLE(RTGUI_WIDGET(view)))
  118. rtgui_widget_focus(RTGUI_WIDGET(view));
  119. view->modal_show = is_modal;
  120. if (is_modal == RT_TRUE)
  121. {
  122. /* set modal mode */
  123. workbench->flag |= RTGUI_WORKBENCH_FLAG_MODAL_MODE;
  124. /* perform workbench event loop */
  125. rtgui_workbench_event_loop(workbench);
  126. return workbench->modal_code;
  127. }
  128. /* no modal mode, always return modal_ok */
  129. return RTGUI_MODAL_OK;
  130. }
  131. void rtgui_view_end_modal(rtgui_view_t* view, rtgui_modal_code_t modal_code)
  132. {
  133. rtgui_workbench_t* workbench;
  134. /* parameter check */
  135. if ((view == RT_NULL) || (RTGUI_WIDGET(view)->parent == RT_NULL))return ;
  136. workbench = RTGUI_WORKBENCH(RTGUI_WIDGET(view)->parent);
  137. workbench->modal_code = modal_code;
  138. workbench->flag &= ~RTGUI_WORKBENCH_FLAG_MODAL_MODE;
  139. }
  140. void rtgui_view_hide(rtgui_view_t* view)
  141. {
  142. if (view == RT_NULL) return;
  143. if (RTGUI_WIDGET(view)->parent == RT_NULL)
  144. {
  145. RTGUI_WIDGET_HIDE(RTGUI_WIDGET(view));
  146. return;
  147. }
  148. rtgui_workbench_hide_view((rtgui_workbench_t*)(RTGUI_WIDGET(view)->parent), view);
  149. }
  150. char* rtgui_view_get_title(rtgui_view_t* view)
  151. {
  152. RT_ASSERT(view != RT_NULL);
  153. return view->title;
  154. }
  155. void rtgui_view_set_title(rtgui_view_t* view, const char *title)
  156. {
  157. RT_ASSERT(view != RT_NULL);
  158. if (view->title != RT_NULL)
  159. {
  160. rtgui_free(view->title);
  161. if (title != RT_NULL) view->title = rt_strdup(title);
  162. else view->title = RT_NULL;
  163. }
  164. }