demo_view_dc.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. /*
  2. * 程序清单:DC操作演示
  3. *
  4. * 这个例子会在创建出的view上进行DC操作的演示
  5. */
  6. #include "demo_view.h"
  7. #include <rtgui/dc.h>
  8. #include <rtgui/rtgui_system.h>
  9. #include <rtgui/widgets/label.h>
  10. #include <rtgui/widgets/slider.h>
  11. #include <rtgui/image_hdc.h>
  12. #include "play.hdh"
  13. #include "stop.hdh"
  14. struct rtgui_image_hdcmm play_image = RTGUI_IMAGE_HDC_DEF(2, 0x1c, 0x16, play_hdh);
  15. struct rtgui_image_hdcmm stop_image = RTGUI_IMAGE_HDC_DEF(2, 0x1c, 0x16, stop_hdh);
  16. /*
  17. * view的事件处理函数
  18. */
  19. rt_bool_t dc_event_handler(struct rtgui_object* object, rtgui_event_t *event)
  20. {
  21. struct rtgui_widget *widget = RTGUI_WIDGET(object);
  22. /* 仅对PAINT事件进行处理 */
  23. if (event->type == RTGUI_EVENT_PAINT)
  24. {
  25. struct rtgui_dc* dc;
  26. rtgui_rect_t rect;
  27. const int vx[] = {20, 50, 60, 45, 60, 20};
  28. const int vy[] = {150, 50, 90, 60, 45, 50};
  29. /*
  30. * 因为用的是demo view,上面本身有一部分控件,所以在绘图时先要让demo view
  31. * 先绘图
  32. */
  33. rtgui_container_event_handler(RTGUI_OBJECT(widget), event);
  34. /************************************************************************/
  35. /* 下面的是DC的操作 */
  36. /************************************************************************/
  37. /* 获得控件所属的DC */
  38. dc = rtgui_dc_begin_drawing(widget);
  39. /* 如果不能正常获得DC,返回(如果控件或父控件是隐藏状态,DC是获取不成功的) */
  40. if (dc == RT_NULL)
  41. return RT_FALSE;
  42. /* 获得demo view允许绘图的区域 */
  43. demo_view_get_logic_rect(RTGUI_CONTAINER(widget), &rect);
  44. RTGUI_DC_TEXTALIGN(dc) = RTGUI_ALIGN_BOTTOM | RTGUI_ALIGN_CENTER_HORIZONTAL;
  45. /* 显示GUI的版本信息 */
  46. #ifdef RTGUI_USING_SMALL_SIZE
  47. rtgui_dc_draw_text(dc, "RT-Thread/GUI小型版本", &rect);
  48. #else
  49. rtgui_dc_draw_text(dc, "RT-Thread/GUI标准版本", &rect);
  50. #endif
  51. {
  52. rtgui_rect_t rect = {0, 0, 0x1c, 0x16};
  53. rtgui_rect_moveto(&rect, 80, 80);
  54. rtgui_image_blit((rtgui_image_t*)&play_image, dc, &rect);
  55. rect.x1 = 0; rect.y1 = 0;
  56. rect.x2 = 0x1c; rect.y2 = 0x16;
  57. rtgui_rect_moveto(&rect, 130, 80);
  58. rtgui_image_blit((rtgui_image_t*)&stop_image, dc, &rect);
  59. }
  60. /* 绘制一个圆形 */
  61. RTGUI_DC_FC(dc) = red;
  62. rtgui_dc_draw_circle(dc, rect.x1 + 10, rect.y1 + 10, 10);
  63. /* 填充一个圆形 */
  64. RTGUI_DC_FC(dc) = green;
  65. rtgui_dc_fill_circle(dc, rect.x1 + 30, rect.y1 + 10, 10);
  66. #if 0
  67. /* 画一个圆角矩形 */
  68. rect.x1 = 150;
  69. rect.y1 = 180;
  70. rect.x2 = 210;
  71. rect.y2 = 260;
  72. RTGUI_DC_FC(dc) = RTGUI_RGB(25, 70, 150);
  73. rtgui_dc_draw_round_rect(dc, &rect, 10);
  74. rect.x1 = 160;
  75. rect.y1 = 190;
  76. rect.x2 = 200;
  77. rect.y2 = 250;
  78. RTGUI_DC_FC(dc) = RTGUI_RGB(170, 7, 80);
  79. rtgui_dc_fill_round_rect(dc, &rect, 7);
  80. /* 画一个圆弧 */
  81. RTGUI_DC_FC(dc) = RTGUI_RGB(250, 120, 120);
  82. rtgui_dc_draw_arc(dc, rect.x1 + 120, rect.y1 + 60, 30, 0, 120);
  83. /* 画一个扇形圆环 */
  84. RTGUI_DC_FC(dc) = RTGUI_RGB(150, 23, 100);
  85. rtgui_dc_draw_annulus(dc, 180, 170, 30, 50, 210, 330);
  86. /* 多边形 */
  87. RTGUI_DC_FC(dc) = blue;
  88. rtgui_dc_draw_polygon(dc, vx, vy, 6);
  89. #endif
  90. RTGUI_DC_FC(dc) = blue;
  91. /* 绘制不同的边框 */
  92. {
  93. rtgui_rect_t rect = {0, 0, 16, 16};
  94. rtgui_rect_moveto(&rect, 30, 120);
  95. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_RAISE);
  96. rect.x1 += 20;
  97. rect.x2 += 20 + 50;
  98. rtgui_dc_draw_text(dc, "raise", &rect);
  99. rect.x1 -= 20;
  100. rect.x2 -= 20 + 50;
  101. rect.y1 += 20;
  102. rect.y2 += 20;
  103. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_SIMPLE);
  104. rect.x1 += 20;
  105. rect.x2 += 20 + 50;
  106. rtgui_dc_draw_text(dc, "simple", &rect);
  107. rect.x1 -= 20;
  108. rect.x2 -= 20 + 50;
  109. rect.y1 += 20;
  110. rect.y2 += 20;
  111. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_SUNKEN);
  112. rect.x1 += 20;
  113. rect.x2 += 20 + 50;
  114. rtgui_dc_draw_text(dc, "sunken", &rect);
  115. rect.x1 -= 20;
  116. rect.x2 -= 20 + 50;
  117. rect.y1 += 20;
  118. rect.y2 += 20;
  119. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_BOX);
  120. rect.x1 += 20;
  121. rect.x2 += 20 + 50;
  122. rtgui_dc_draw_text(dc, "box", &rect);
  123. rect.x1 -= 20;
  124. rect.x2 -= 20 + 50;
  125. rect.y1 += 20;
  126. rect.y2 += 20;
  127. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_STATIC);
  128. rect.x1 += 20;
  129. rect.x2 += 20 + 50;
  130. rtgui_dc_draw_text(dc, "static", &rect);
  131. rect.x1 -= 20;
  132. rect.x2 -= 20 + 50;
  133. rect.y1 += 20;
  134. rect.y2 += 20;
  135. rtgui_dc_draw_border(dc, &rect, RTGUI_BORDER_EXTRA);
  136. rect.x1 += 20;
  137. rect.x2 += 20 + 50;
  138. rtgui_dc_draw_text(dc, "extera", &rect);
  139. rect.x1 -= 20;
  140. rect.x2 -= 20 + 50;
  141. rect.y1 += 20;
  142. rect.y2 += 20;
  143. }
  144. /* 绘图完成 */
  145. rtgui_dc_end_drawing(dc);
  146. }
  147. else
  148. {
  149. /* 其他事件,调用默认的事件处理函数 */
  150. return rtgui_container_event_handler(object, event);
  151. }
  152. return RT_FALSE;
  153. }
  154. /* 创建用于DC操作演示用的视图 */
  155. rtgui_container_t *demo_view_dc(void)
  156. {
  157. rtgui_container_t *view;
  158. view = demo_view("DC Demo");
  159. if (view != RT_NULL)
  160. /* 设置成自己的事件处理函数 */
  161. rtgui_object_set_event_handler(RTGUI_OBJECT(view), dc_event_handler);
  162. return view;
  163. }