2018-11-22 04:43:30 +03:00
|
|
|
/* vim: tabstop=4 shiftwidth=4 noexpandtab
|
|
|
|
* This file is part of ToaruOS and is released under the terms
|
|
|
|
* of the NCSA / University of Illinois License - see LICENSE.md
|
|
|
|
* Copyright (C) 2018 K. Lange
|
|
|
|
*
|
|
|
|
* ttk button widget
|
|
|
|
*/
|
|
|
|
#include <toaru/graphics.h>
|
|
|
|
#include <toaru/button.h>
|
|
|
|
#include <toaru/sdf.h>
|
2018-11-24 07:18:57 +03:00
|
|
|
#include <toaru/icon_cache.h>
|
2018-11-22 04:43:30 +03:00
|
|
|
|
|
|
|
void ttk_button_draw(gfx_context_t * ctx, struct TTKButton * button) {
|
|
|
|
if (button->width == 0) {
|
|
|
|
return;
|
|
|
|
}
|
2018-11-24 08:10:49 +03:00
|
|
|
|
|
|
|
int hilight = button->hilight & 0xFF;
|
|
|
|
int disabled = button->hilight & 0x100;
|
|
|
|
|
2018-11-22 04:43:30 +03:00
|
|
|
/* Dark edge */
|
2018-11-24 08:10:49 +03:00
|
|
|
if (hilight < 3) {
|
2018-11-24 07:18:57 +03:00
|
|
|
struct gradient_definition edge = {button->height, button->y, rgb(166,166,166), rgb(136,136,136)};
|
2018-11-24 16:22:55 +03:00
|
|
|
draw_rounded_rectangle_pattern(ctx, button->x, button->y, button->width, button->height, 4, gfx_vertical_gradient_pattern, &edge);
|
2018-11-24 07:18:57 +03:00
|
|
|
}
|
|
|
|
|
2018-11-22 04:43:30 +03:00
|
|
|
/* Sheen */
|
2018-11-24 08:10:49 +03:00
|
|
|
if (hilight < 2) {
|
2018-11-22 04:43:30 +03:00
|
|
|
draw_rounded_rectangle(ctx, button->x + 1, button->y + 1, button->width - 2, button->height - 2, 3, rgb(238,238,238));
|
|
|
|
/* Button face - this should normally be a gradient */
|
2018-11-24 08:10:49 +03:00
|
|
|
if (hilight == 1) {
|
2018-11-22 04:43:30 +03:00
|
|
|
struct gradient_definition face = {button->height-3, button->y + 2, rgb(240,240,240), rgb(230,230,230)};
|
2018-11-24 16:22:55 +03:00
|
|
|
draw_rounded_rectangle_pattern(ctx, button->x + 2, button->y + 2, button->width - 4, button->height - 3, 2, gfx_vertical_gradient_pattern, &face);
|
2018-11-22 04:43:30 +03:00
|
|
|
} else {
|
|
|
|
struct gradient_definition face = {button->height-3, button->y + 2, rgb(219,219,219), rgb(204,204,204)};
|
2018-11-24 16:22:55 +03:00
|
|
|
draw_rounded_rectangle_pattern(ctx, button->x + 2, button->y + 2, button->width - 4, button->height - 3, 2, gfx_vertical_gradient_pattern, &face);
|
2018-11-22 04:43:30 +03:00
|
|
|
}
|
2018-11-24 08:10:49 +03:00
|
|
|
} else if (hilight == 2) {
|
2018-11-22 04:43:30 +03:00
|
|
|
struct gradient_definition face = {button->height-2, button->y + 1, rgb(180,180,180), rgb(160,160,160)};
|
2018-11-24 16:22:55 +03:00
|
|
|
draw_rounded_rectangle_pattern(ctx, button->x + 1, button->y + 1, button->width - 2, button->height - 2, 3, gfx_vertical_gradient_pattern, &face);
|
2018-11-22 04:43:30 +03:00
|
|
|
}
|
|
|
|
|
2018-11-24 07:18:57 +03:00
|
|
|
if (button->title[0] != '\033') {
|
|
|
|
int label_width = draw_sdf_string_width(button->title, 16, SDF_FONT_THIN);
|
|
|
|
int centered = (button->width - label_width) / 2;
|
2018-11-22 04:43:30 +03:00
|
|
|
|
2018-11-24 07:18:57 +03:00
|
|
|
int centered_y = (button->height - 16) / 2;
|
2018-11-24 08:10:49 +03:00
|
|
|
draw_sdf_string(ctx, button->x + centered + (hilight == 2), button->y + centered_y + (hilight == 2), button->title, 16, disabled ? rgb(120,120,120) : rgb(0,0,0), SDF_FONT_THIN);
|
2018-11-24 07:18:57 +03:00
|
|
|
} else {
|
|
|
|
sprite_t * icon = icon_get_16(button->title+1);
|
2018-11-24 08:10:49 +03:00
|
|
|
int centered = button->x + (button->width - icon->width) / 2 + (hilight == 2);
|
|
|
|
int centered_y = button->y + (button->height - icon->height) / 2 + (hilight == 2);
|
|
|
|
if (disabled) {
|
|
|
|
draw_sprite_alpha(ctx, icon, centered, centered_y, 0.5);
|
|
|
|
} else {
|
|
|
|
draw_sprite(ctx, icon, centered, centered_y);
|
|
|
|
}
|
2018-11-24 07:18:57 +03:00
|
|
|
}
|
2018-11-22 04:43:30 +03:00
|
|
|
|
|
|
|
}
|
|
|
|
|