Changeset d63623f in mainline for uspace/lib/ui
- Timestamp:
- 2021-07-16T17:45:12Z (4 years ago)
- Branches:
- master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 4afb6c9
- Parents:
- 61bf9dd9
- Location:
- uspace/lib/ui
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/ui/include/ui/paint.h
r61bf9dd9 rd63623f 45 45 extern errno_t ui_paint_bevel(gfx_context_t *, gfx_rect_t *, gfx_color_t *, 46 46 gfx_color_t *, gfx_coord_t, gfx_rect_t *); 47 extern void ui_paint_get_bevel_inside(gfx_context_t *, gfx_rect_t *, 48 gfx_coord_t, gfx_rect_t *); 47 49 extern errno_t ui_paint_inset_frame(ui_resource_t *, gfx_rect_t *, 50 gfx_rect_t *); 51 extern void ui_paint_get_inset_frame_inside(ui_resource_t *, gfx_rect_t *, 48 52 gfx_rect_t *); 49 53 extern errno_t ui_paint_outset_frame(ui_resource_t *, gfx_rect_t *, -
uspace/lib/ui/private/entry.h
r61bf9dd9 rd63623f 66 66 }; 67 67 68 /** Text entry geometry. 69 * 70 * Computed geometry of text entry elements. 71 */ 72 typedef struct { 73 /** Interior rectangle */ 74 gfx_rect_t interior_rect; 75 /** Text anchor position */ 76 gfx_coord2_t text_pos; 77 } ui_entry_geom_t; 78 68 79 extern errno_t ui_entry_insert_str(ui_entry_t *, const char *); 69 80 extern ui_evclaim_t ui_entry_key_press_unmod(ui_entry_t *, kbd_event_t *); 81 extern void ui_entry_get_geom(ui_entry_t *, ui_entry_geom_t *); 82 extern size_t ui_entry_find_pos(ui_entry_t *, gfx_coord2_t *); 70 83 extern void ui_entry_activate(ui_entry_t *); 71 84 extern void ui_entry_deactivate(ui_entry_t *); -
uspace/lib/ui/src/entry.c
r61bf9dd9 rd63623f 256 256 { 257 257 ui_resource_t *res; 258 ui_entry_geom_t geom; 258 259 gfx_text_fmt_t fmt; 259 260 gfx_coord2_t pos; 260 gfx_coord_t hpad;261 gfx_coord_t vpad;262 gfx_coord_t width;263 261 gfx_rect_t inside; 264 262 errno_t rc; … … 266 264 res = ui_window_get_res(entry->window); 267 265 268 if (res->textmode) { 269 hpad = ui_entry_hpad_text; 270 vpad = ui_entry_vpad_text; 271 } else { 272 hpad = ui_entry_hpad; 273 vpad = ui_entry_vpad; 274 } 266 ui_entry_get_geom(entry, &geom); 275 267 276 268 if (res->textmode == false) { … … 293 285 goto error; 294 286 295 width = gfx_text_width(res->font, entry->text); 296 297 switch (entry->halign) { 298 case gfx_halign_left: 299 case gfx_halign_justify: 300 pos.x = inside.p0.x + hpad; 301 break; 302 case gfx_halign_center: 303 pos.x = (inside.p0.x + inside.p1.x) / 2 - width / 2; 304 break; 305 case gfx_halign_right: 306 pos.x = inside.p1.x - hpad - 1 - width; 307 break; 308 } 309 310 pos.y = inside.p0.y + vpad; 287 pos = geom.text_pos; 311 288 312 289 gfx_text_fmt_init(&fmt); … … 347 324 error: 348 325 return rc; 326 } 327 328 /** Find position in text entry. 329 * 330 * @param entry Text entry 331 * @param fpos Position for which we need to find text offset 332 * @return Corresponding byte offset in entry text 333 */ 334 size_t ui_entry_find_pos(ui_entry_t *entry, gfx_coord2_t *fpos) 335 { 336 ui_resource_t *res; 337 ui_entry_geom_t geom; 338 gfx_text_fmt_t fmt; 339 340 res = ui_window_get_res(entry->window); 341 342 ui_entry_get_geom(entry, &geom); 343 344 gfx_text_fmt_init(&fmt); 345 fmt.halign = gfx_halign_left; 346 fmt.valign = gfx_valign_top; 347 348 return gfx_text_find_pos(res->font, &geom.text_pos, &fmt, 349 entry->text, fpos); 349 350 } 350 351 … … 567 568 568 569 if (gfx_pix_inside_rect(&pos, &entry->rect)) { 569 ui_entry_activate(entry); 570 entry->pos = ui_entry_find_pos(entry, &pos); 571 if (entry->active) 572 ui_entry_paint(entry); 573 else 574 ui_entry_activate(entry); 570 575 571 576 return ui_claimed; … … 604 609 } 605 610 611 /** Get text entry geometry. 612 * 613 * @param entry Text entry 614 * @param geom Structure to fill in with computed geometry 615 */ 616 void ui_entry_get_geom(ui_entry_t *entry, ui_entry_geom_t *geom) 617 { 618 gfx_coord_t hpad; 619 gfx_coord_t vpad; 620 gfx_coord_t width; 621 ui_resource_t *res; 622 623 res = ui_window_get_res(entry->window); 624 625 if (res->textmode) { 626 hpad = ui_entry_hpad_text; 627 vpad = ui_entry_vpad_text; 628 } else { 629 hpad = ui_entry_hpad; 630 vpad = ui_entry_vpad; 631 } 632 633 if (res->textmode == false) { 634 ui_paint_get_inset_frame_inside(res, &entry->rect, 635 &geom->interior_rect); 636 } else { 637 geom->interior_rect = entry->rect; 638 } 639 640 width = gfx_text_width(res->font, entry->text); 641 642 switch (entry->halign) { 643 case gfx_halign_left: 644 case gfx_halign_justify: 645 geom->text_pos.x = geom->interior_rect.p0.x + hpad; 646 break; 647 case gfx_halign_center: 648 geom->text_pos.x = (geom->interior_rect.p0.x + 649 geom->interior_rect.p1.x) / 2 - width / 2; 650 break; 651 case gfx_halign_right: 652 geom->text_pos.x = geom->interior_rect.p1.x - hpad - 1 - width; 653 break; 654 } 655 656 geom->text_pos.y = geom->interior_rect.p0.y + vpad; 657 } 658 606 659 /** Activate text entry. 607 660 * … … 618 671 619 672 entry->active = true; 620 entry->pos = str_size(entry->text);621 673 (void) ui_entry_paint(entry); 622 674 -
uspace/lib/ui/src/paint.c
r61bf9dd9 rd63623f 49 49 * @param thickness Bevel thickness in pixels 50 50 * @param inside Place to store rectangle of the interior or @c NULL 51 * @re utrn EOK on success or an error code51 * @return EOK on success or an error code 52 52 */ 53 53 errno_t ui_paint_bevel(gfx_context_t *gc, gfx_rect_t *rect, … … 107 107 } 108 108 109 if (inside != NULL) { 110 inside->p0.x = rect->p0.x + thickness; 111 inside->p0.y = rect->p0.y + thickness; 112 inside->p1.x = rect->p1.x - thickness; 113 inside->p1.y = rect->p1.y - thickness; 114 } 109 if (inside != NULL) 110 ui_paint_get_bevel_inside(gc, rect, thickness, inside); 115 111 116 112 return EOK; 117 113 error: 118 114 return rc; 115 } 116 117 /** Get bevel interior rectangle. 118 * 119 * Get the bevel interior rectangle without painting it. 120 * 121 * @param gc Graphic context 122 * @param rect Rectangle to paint into 123 * @param thickness Bevel thickness in pixels 124 * @param inside Place to store rectangle of the interior 125 */ 126 void ui_paint_get_bevel_inside(gfx_context_t *gc, gfx_rect_t *rect, 127 gfx_coord_t thickness, gfx_rect_t *inside) 128 { 129 inside->p0.x = rect->p0.x + thickness; 130 inside->p0.y = rect->p0.y + thickness; 131 inside->p1.x = rect->p1.x - thickness; 132 inside->p1.y = rect->p1.y - thickness; 119 133 } 120 134 … … 147 161 error: 148 162 return rc; 163 } 164 165 /** Get inset frame interior rectangle. 166 * 167 * This allows one to get the interior rectangle without actually painting 168 * the inset frame. 169 * 170 * @param resource UI resource 171 * @param rect Rectangle to paint onto 172 * @param inside Place to store inside rectangle or @c NULL 173 */ 174 void ui_paint_get_inset_frame_inside(ui_resource_t *resource, gfx_rect_t *rect, 175 gfx_rect_t *inside) 176 { 177 ui_paint_get_bevel_inside(resource->gc, rect, 2, inside); 149 178 } 150 179 -
uspace/lib/ui/test/paint.c
r61bf9dd9 rd63623f 96 96 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 97 97 98 rect.p0.x = 10; 99 rect.p0.y = 20; 100 rect.p1.x = 30; 101 rect.p1.y = 40; 102 98 103 /* Paint bevel with NULL 'inside' output parameter */ 99 104 rc = ui_paint_bevel(gc, &rect, color1, color2, 2, NULL); … … 110 115 } 111 116 117 /** Get bevel inside */ 118 PCUT_TEST(get_bevel_inside) 119 { 120 errno_t rc; 121 gfx_context_t *gc = NULL; 122 test_gc_t tgc; 123 gfx_rect_t rect; 124 gfx_rect_t inside; 125 126 memset(&tgc, 0, sizeof(tgc)); 127 rc = gfx_context_new(&ops, &tgc, &gc); 128 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 129 130 rect.p0.x = 10; 131 rect.p0.y = 20; 132 rect.p1.x = 30; 133 rect.p1.y = 40; 134 135 ui_paint_get_bevel_inside(gc, &rect, 2, &inside); 136 PCUT_ASSERT_INT_EQUALS(12, inside.p0.x); 137 PCUT_ASSERT_INT_EQUALS(22, inside.p0.y); 138 PCUT_ASSERT_INT_EQUALS(28, inside.p1.x); 139 PCUT_ASSERT_INT_EQUALS(38, inside.p1.y); 140 141 rc = gfx_context_delete(gc); 142 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 143 } 144 112 145 /** Paint inset frame */ 113 146 PCUT_TEST(inset_frame) … … 128 161 PCUT_ASSERT_NOT_NULL(resource); 129 162 163 rect.p0.x = 10; 164 rect.p0.y = 20; 165 rect.p1.x = 30; 166 rect.p1.y = 40; 167 130 168 /* Paint inset frame with NULL 'inside' output parameter */ 131 169 rc = ui_paint_inset_frame(resource, &rect, NULL); … … 135 173 rc = ui_paint_inset_frame(resource, &rect, &inside); 136 174 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 175 176 ui_resource_destroy(resource); 177 rc = gfx_context_delete(gc); 178 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 179 } 180 181 /** Get inset frame inside */ 182 PCUT_TEST(get_inset_frame_inside) 183 { 184 errno_t rc; 185 gfx_context_t *gc = NULL; 186 ui_resource_t *resource = NULL; 187 test_gc_t tgc; 188 gfx_rect_t rect; 189 gfx_rect_t inside; 190 191 memset(&tgc, 0, sizeof(tgc)); 192 rc = gfx_context_new(&ops, &tgc, &gc); 193 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 194 195 rc = ui_resource_create(gc, false, &resource); 196 PCUT_ASSERT_ERRNO_VAL(EOK, rc); 197 PCUT_ASSERT_NOT_NULL(resource); 198 199 rect.p0.x = 10; 200 rect.p0.y = 20; 201 rect.p1.x = 30; 202 rect.p1.y = 40; 203 204 ui_paint_get_inset_frame_inside(resource, &rect, &inside); 205 PCUT_ASSERT_INT_EQUALS(12, inside.p0.x); 206 PCUT_ASSERT_INT_EQUALS(22, inside.p0.y); 207 PCUT_ASSERT_INT_EQUALS(28, inside.p1.x); 208 PCUT_ASSERT_INT_EQUALS(38, inside.p1.y); 137 209 138 210 ui_resource_destroy(resource);
Note:
See TracChangeset
for help on using the changeset viewer.