view.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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. static void _rtgui_view_constructor(rtgui_view_t *view)
  18. {
  19. /* init view */
  20. rtgui_widget_set_event_handler(view,rtgui_view_event_handler);
  21. RTGUI_WIDGET_BORDER_STYLE(view) = RTGUI_BORDER_NONE;
  22. view->title = RT_NULL;
  23. }
  24. static void _rtgui_view_destructor(rtgui_view_t *view)
  25. {
  26. rt_free(view->title);
  27. }
  28. rtgui_type_t *rtgui_view_type_get(void)
  29. {
  30. static rtgui_type_t *view_type = RT_NULL;
  31. if(!view_type)
  32. {
  33. view_type = rtgui_type_create("view", RTGUI_CONTAINER_TYPE,
  34. sizeof(rtgui_view_t),
  35. RTGUI_CONSTRUCTOR(_rtgui_view_constructor),
  36. RTGUI_DESTRUCTOR(_rtgui_view_destructor));
  37. }
  38. return view_type;
  39. }
  40. rtgui_view_t* rtgui_view_create(PVOID parent,const char* title,int left,int top,int w,int h)
  41. {
  42. rtgui_view_t* view;
  43. RT_ASSERT(parent != RT_NULL);
  44. /* allocate view */
  45. view = rtgui_widget_create (RTGUI_VIEW_TYPE);
  46. if(view != RT_NULL)
  47. {
  48. rtgui_rect_t rect;
  49. rtgui_widget_get_rect(parent,&rect);
  50. rtgui_widget_rect_to_device(parent, &rect);
  51. rect.x1 += left;
  52. rect.y1 += top;
  53. rect.x2 = rect.x1+w;
  54. rect.y2 = rect.y1+h;
  55. rtgui_widget_set_rect(view,&rect);
  56. if(title != RT_NULL)
  57. view->title = rt_strdup(title);
  58. rtgui_container_add_child(parent, view);
  59. }
  60. return view;
  61. }
  62. void rtgui_view_destroy(rtgui_view_t* view)
  63. {
  64. rtgui_widget_destroy(view);
  65. }
  66. rt_bool_t rtgui_view_event_handler(PVOID wdt, rtgui_event_t* event)
  67. {
  68. rtgui_widget_t *widget = (rtgui_widget_t*)wdt;
  69. rtgui_view_t* view = (rtgui_view_t*) widget;
  70. RT_ASSERT(wdt != RT_NULL);
  71. switch (event->type)
  72. {
  73. case RTGUI_EVENT_PAINT:
  74. if(widget->on_draw != RT_NULL)
  75. widget->on_draw(widget, event);
  76. else
  77. {
  78. rtgui_rect_t rect;
  79. rtgui_dc_t* dc;
  80. /* begin drawing */
  81. dc = rtgui_dc_begin_drawing(view);
  82. if(dc == RT_NULL)return RT_FALSE;
  83. rtgui_widget_get_rect(view, &rect);
  84. /* fill view with background */
  85. rtgui_dc_fill_rect(dc, &rect);
  86. if(RTGUI_WIDGET_BORDER(view)>0)
  87. rtgui_dc_draw_border(dc,&rect,RTGUI_WIDGET_BORDER_STYLE(view));
  88. rtgui_dc_end_drawing(dc);
  89. /* paint on each child */
  90. rtgui_container_dispatch_event(RTGUI_CONTAINER(view), event);
  91. }
  92. break;
  93. default:
  94. return rtgui_container_event_handler(widget, event);
  95. }
  96. return RT_FALSE;
  97. }
  98. rt_bool_t rtgui_view_show(rtgui_view_t* view)
  99. {
  100. /* parameter check */
  101. if(view == RT_NULL) return RT_FALSE;
  102. //该句放在后面
  103. rtgui_widget_show(view);
  104. /* no modal mode, always return modal_ok */
  105. return RT_TRUE;
  106. }
  107. void rtgui_view_hide(rtgui_view_t* view)
  108. {
  109. if(view == RT_NULL) return;
  110. if(RTGUI_WIDGET_PARENT(view) == RT_NULL)
  111. {
  112. RTGUI_WIDGET_HIDE(view);
  113. return;
  114. }
  115. rtgui_widget_hide(view);
  116. }
  117. char* rtgui_view_get_title(rtgui_view_t* view)
  118. {
  119. RT_ASSERT(view != RT_NULL);
  120. return view->title;
  121. }
  122. void rtgui_view_set_title(rtgui_view_t* view, const char *title)
  123. {
  124. RT_ASSERT(view != RT_NULL);
  125. rt_free(view->title);
  126. if(title != RT_NULL)
  127. view->title = rt_strdup(title);
  128. else
  129. view->title = RT_NULL;
  130. }
  131. //显示一个视图下指定名称的子视图
  132. void rtgui_view_show_child(PVOID wdt,const char* name)
  133. {
  134. rtgui_list_t* node;
  135. rtgui_container_t *container = (rtgui_container_t*)wdt;
  136. rtgui_list_foreach(node, &(container->children))
  137. {
  138. rtgui_widget_t* child = rtgui_list_entry(node, rtgui_widget_t, sibling);
  139. if(RTGUI_IS_VIEW(child))
  140. {
  141. if(strcmp(RTGUI_VIEW(child)->title,name)==0)
  142. {
  143. RTGUI_WIDGET_UNHIDE(child);
  144. }
  145. else
  146. {
  147. RTGUI_WIDGET_HIDE(child);
  148. }
  149. }
  150. }
  151. rtgui_widget_update_clip(wdt);
  152. rtgui_widget_update(wdt);
  153. }