123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- /*
- * File : iconbox.c
- * This file is part of RT-Thread RTOS
- * COPYRIGHT (C) 2006 - 2009, RT-Thread Development Team
- *
- * The license and distribution terms for this file may be
- * found in the file LICENSE in this distribution or at
- * http://www.rt-thread.org/license/LICENSE
- *
- * Change Logs:
- * Date Author Notes
- * 2009-10-16 Bernard first version
- */
- #include <rtgui/dc.h>
- #include <rtgui/widgets/iconbox.h>
- #include <rtgui/rtgui_theme.h>
- static void _rtgui_iconbox_constructor(rtgui_iconbox_t *iconbox)
- {
- /* init widget and set event handler */
- RTGUI_WIDGET(iconbox)->flag |= (RTGUI_WIDGET_FLAG_TRANSPARENT | RTGUI_WIDGET_FLAG_FOCUSABLE);
- rtgui_object_set_event_handler(RTGUI_OBJECT(iconbox), rtgui_iconbox_event_handler);
- /* set proper of control */
- iconbox->image = RT_NULL;
- iconbox->selected = RT_FALSE;
- iconbox->text = RT_NULL;
- iconbox->text_position = RTGUI_ICONBOX_TEXT_BELOW;
- }
- static void _rtgui_iconbox_destructor(rtgui_iconbox_t *iconbox)
- {
- if (iconbox->image != RT_NULL)
- {
- rtgui_image_destroy(iconbox->image);
- iconbox->image = RT_NULL;
- }
- if (iconbox->text != RT_NULL)
- {
- rt_free(iconbox->text);
- iconbox->text = RT_NULL;
- }
- }
- DEFINE_CLASS_TYPE(iconbox, "iconbox",
- RTGUI_WIDGET_TYPE,
- _rtgui_iconbox_constructor,
- _rtgui_iconbox_destructor,
- sizeof(struct rtgui_iconbox));
- rt_bool_t rtgui_iconbox_event_handler(struct rtgui_object *object, struct rtgui_event *event)
- {
- struct rtgui_iconbox *iconbox;
- iconbox = RTGUI_ICONBOX(object);
- switch (event->type)
- {
- case RTGUI_EVENT_PAINT:
- rtgui_theme_draw_iconbox(iconbox);
- break;
- case RTGUI_EVENT_MOUSE_BUTTON:
- if (RTGUI_WIDGET_IS_HIDE(object)) return RT_FALSE;
- {
- struct rtgui_event_mouse *emouse = (struct rtgui_event_mouse *)event;
- /* it's not this widget event, clean status */
- if (rtgui_rect_contains_point(&(RTGUI_WIDGET(iconbox)->extent),
- emouse->x, emouse->y) != RT_EOK)
- {
- if (iconbox->selected != RT_TRUE)
- {
- rtgui_iconbox_set_selected(iconbox, RT_TRUE);
- rtgui_widget_focus(RTGUI_WIDGET(iconbox));
- }
- break;
- }
- }
- return RT_TRUE;
- default:
- return rtgui_widget_event_handler(object, event);
- }
- return RT_FALSE;
- }
- struct rtgui_iconbox *rtgui_iconbox_create(struct rtgui_image *image,
- const char *text,
- int position)
- {
- struct rtgui_iconbox *iconbox;
- iconbox = (struct rtgui_iconbox *)rtgui_widget_create(RTGUI_ICONBOX_TYPE);
- if (iconbox != RT_NULL)
- {
- rtgui_rect_t rect = {0, 0, 0, 0}, text_rect;
- rect.x2 = image->w;
- rect.y2 = image->h;
- /* get text rect */
- rtgui_font_get_metrics(rtgui_font_default(), text, &text_rect);
- if (position == RTGUI_ICONBOX_TEXT_BELOW)
- {
- rect.y2 += RTGUI_WIDGET_DEFAULT_MARGIN;
- if (text_rect.x2 > rect.x2)
- {
- rect.x2 = text_rect.x2;
- }
- rect.y2 += text_rect.y2;
- }
- else if (position == RTGUI_ICONBOX_TEXT_RIGHT)
- {
- rect.x2 += RTGUI_WIDGET_DEFAULT_MARGIN;
- if (text_rect.y2 > rect.y2)
- {
- rect.y2 = text_rect.y2;
- }
- rect.x2 += text_rect.x2;
- }
- /* set widget rect */
- rtgui_widget_set_rect(RTGUI_WIDGET(iconbox), &rect);
- /* set image and text position */
- iconbox->image = image;
- iconbox->text = (char *)rt_strdup((const char *)text);
- iconbox->text_position = position;
- }
- return iconbox;
- }
- void rtgui_iconbox_destroy(struct rtgui_iconbox *iconbox)
- {
- rtgui_widget_destroy(RTGUI_WIDGET(iconbox));
- }
- void rtgui_iconbox_set_text_position(struct rtgui_iconbox *iconbox, int position)
- {
- struct rtgui_rect rect = {0, 0, 0, 0}, text_rect;
- RT_ASSERT(iconbox != RT_NULL);
- iconbox->text_position = position;
- /* set mini width and height */
- rect.x2 = iconbox->image->w;
- rect.y2 = iconbox->image->h;
- /* get text rect */
- if (iconbox->text != RT_NULL)
- {
- rtgui_font_get_metrics(rtgui_font_default(),
- iconbox->text, &text_rect);
- if (position == RTGUI_ICONBOX_TEXT_BELOW)
- {
- rect.y2 += RTGUI_WIDGET_DEFAULT_MARGIN;
- if (text_rect.x2 > rect.x2)
- {
- rect.x2 = text_rect.x2;
- }
- rect.y2 += text_rect.y2;
- }
- else if (position == RTGUI_ICONBOX_TEXT_RIGHT)
- {
- rect.x2 += RTGUI_WIDGET_DEFAULT_MARGIN;
- if (text_rect.y2 > rect.y2)
- {
- rect.y2 = text_rect.y2;
- }
- rect.x2 += text_rect.x2;
- }
- }
- }
- void rtgui_iconbox_set_selected(struct rtgui_iconbox *iconbox, rt_bool_t selected)
- {
- RT_ASSERT(iconbox != RT_NULL);
- iconbox->selected = selected;
- }
|