fixes more or less
This commit is contained in:
parent
a315d72a57
commit
74c5f7a004
7 changed files with 67 additions and 63 deletions
|
|
@ -4,29 +4,35 @@ void pgpl_gui_theme_configure(PGPL_GuiTheme *theme, PGPL_Color base_color,
|
|||
double content_font_size, PGPL_Font *font) {
|
||||
theme->background_color = pgpl_color_divide(base_color, 8);
|
||||
|
||||
theme->widget_background_color[0] = pgpl_color_divide(base_color, 5);
|
||||
theme->widget_background_color[1] = pgpl_color_divide(base_color, 4);
|
||||
theme->widget_background_color[2] = pgpl_color_divide(base_color, 3);
|
||||
theme->widget_background_color[PGPL_GUI_STATUS_COLOR_NORMAL] =
|
||||
pgpl_color_divide(base_color, 5);
|
||||
theme->widget_background_color[PGPL_GUI_STATUS_COLOR_HOVER] =
|
||||
pgpl_color_divide(base_color, 4);
|
||||
theme->widget_background_color[PGPL_GUI_STATUS_COLOR_ACTIVE] =
|
||||
pgpl_color_divide(base_color, 3);
|
||||
|
||||
theme->text_color[0] = pgpl_color_divide(base_color, 1.5);
|
||||
theme->text_color[1] = pgpl_color_divide(base_color, 1.25);
|
||||
theme->text_color[2] = base_color;
|
||||
theme->text_color[PGPL_GUI_STATUS_COLOR_NORMAL] =
|
||||
pgpl_color_divide(base_color, 1.5);
|
||||
theme->text_color[PGPL_GUI_STATUS_COLOR_HOVER] =
|
||||
pgpl_color_divide(base_color, 1.25);
|
||||
theme->text_color[PGPL_GUI_STATUS_COLOR_ACTIVE] = base_color;
|
||||
|
||||
theme->font_size[0] = content_font_size * 3;
|
||||
theme->font_size[1] = content_font_size * 2;
|
||||
theme->font_size[2] = content_font_size;
|
||||
theme->font_size[PGPL_GUI_FONT_SIZE_TITLE] = content_font_size * 4;
|
||||
theme->font_size[PGPL_GUI_FONT_SIZE_HEADING_LARGE] = content_font_size * 3;
|
||||
theme->font_size[PGPL_GUI_FONT_SIZE_HEADING_SMALL] = content_font_size * 2;
|
||||
theme->font_size[PGPL_GUI_FONT_SIZE_CONTENT] = content_font_size;
|
||||
|
||||
theme->margin.top = content_font_size / 6;
|
||||
theme->margin.top = content_font_size / 3;
|
||||
theme->margin.left = theme->margin.top;
|
||||
theme->margin.bottom = theme->margin.top;
|
||||
theme->margin.right = theme->margin.top;
|
||||
|
||||
theme->border.top = content_font_size / 12;
|
||||
theme->border.top = content_font_size / 6;
|
||||
theme->border.left = theme->border.top;
|
||||
theme->border.bottom = theme->border.top;
|
||||
theme->border.right = theme->border.top;
|
||||
|
||||
theme->padding.top = content_font_size / 6;
|
||||
theme->padding.top = content_font_size / 3;
|
||||
theme->padding.left = theme->padding.top;
|
||||
theme->padding.bottom = theme->padding.top;
|
||||
theme->padding.right = theme->padding.top;
|
||||
|
|
|
|||
|
|
@ -2,9 +2,11 @@
|
|||
#include <stdlib.h>
|
||||
|
||||
static void get_slider_size(PGPL_GuiSliderWidget *slider_widget,
|
||||
double *slider_x, double *slider_y, double x,
|
||||
double y, double max_width, double max_height) {
|
||||
PGPL_GuiTheme *theme, double *slider_x,
|
||||
double *slider_y, double x, double y,
|
||||
double max_width, double max_height) {
|
||||
double offset;
|
||||
double bar_height = theme->font_size[PGPL_GUI_FONT_SIZE_CONTENT] / 2;
|
||||
|
||||
if (slider_widget->inversed) {
|
||||
offset = 1.0 - slider_widget->current_value;
|
||||
|
|
@ -13,13 +15,11 @@ static void get_slider_size(PGPL_GuiSliderWidget *slider_widget,
|
|||
}
|
||||
|
||||
if (slider_widget->vertical) {
|
||||
*slider_x = x - slider_widget->bar_height / 2.0;
|
||||
*slider_y = y + offset * (max_height - slider_widget->bar_height) -
|
||||
slider_widget->bar_height / 2.0;
|
||||
*slider_x = x - bar_height / 2.0;
|
||||
*slider_y = y + offset * (max_height - bar_height) - bar_height / 2.0;
|
||||
} else {
|
||||
*slider_x = x + offset * (max_width - slider_widget->bar_height) -
|
||||
slider_widget->bar_height / 2.0;
|
||||
*slider_y = y - slider_widget->bar_height / 2.0;
|
||||
*slider_x = x + offset * (max_width - bar_height) - bar_height / 2.0;
|
||||
*slider_y = y - bar_height / 2.0;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -27,15 +27,16 @@ static void get_content_size(PGPL_GuiWidget *widget, PGPL_GuiTheme *theme,
|
|||
double *width, double *height, double max_width,
|
||||
double max_height) {
|
||||
PGPL_GuiSliderWidget *slider_widget = (PGPL_GuiSliderWidget *)widget;
|
||||
double bar_height = theme->font_size[PGPL_GUI_FONT_SIZE_CONTENT] / 2;
|
||||
|
||||
(void)theme;
|
||||
|
||||
if (slider_widget->vertical) {
|
||||
*width = slider_widget->bar_height;
|
||||
*width = bar_height;
|
||||
*height = max_height;
|
||||
} else {
|
||||
*width = max_width;
|
||||
*height = slider_widget->bar_height;
|
||||
*height = bar_height;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -43,6 +44,7 @@ static void render_content(PGPL_GuiWidget *widget, PGPL_Renderer *renderer,
|
|||
PGPL_GuiTheme *theme, double x, double y,
|
||||
double max_width, double max_height) {
|
||||
PGPL_GuiSliderWidget *slider_widget = (PGPL_GuiSliderWidget *)widget;
|
||||
double bar_height = theme->font_size[PGPL_GUI_FONT_SIZE_CONTENT] / 2;
|
||||
|
||||
double slider_x;
|
||||
double slider_y;
|
||||
|
|
@ -52,44 +54,42 @@ static void render_content(PGPL_GuiWidget *widget, PGPL_Renderer *renderer,
|
|||
double completion_width;
|
||||
double completion_height;
|
||||
|
||||
get_slider_size(slider_widget, &slider_x, &slider_y, x, y, max_width,
|
||||
get_slider_size(slider_widget, theme, &slider_x, &slider_y, x, y, max_width,
|
||||
max_height);
|
||||
|
||||
if (slider_widget->vertical) {
|
||||
max_width = slider_widget->bar_height;
|
||||
max_width = bar_height;
|
||||
} else {
|
||||
max_height = slider_widget->bar_height;
|
||||
max_height = bar_height;
|
||||
}
|
||||
|
||||
pgpl_render_rectangle(renderer, theme->text_color[widget->gui_color], x, y,
|
||||
max_width, max_height);
|
||||
|
||||
pgpl_render_rectangle(renderer, theme->background_color,
|
||||
x + slider_widget->bar_height / 4.0,
|
||||
y + slider_widget->bar_height / 4.0,
|
||||
max_width - slider_widget->bar_height / 2.0,
|
||||
max_height - slider_widget->bar_height / 2.0);
|
||||
pgpl_render_rectangle(renderer, theme->background_color, x + bar_height / 4.0,
|
||||
y + bar_height / 4.0, max_width - bar_height / 2.0,
|
||||
max_height - bar_height / 2.0);
|
||||
|
||||
max_width -= slider_widget->bar_height / 2.0;
|
||||
max_height -= slider_widget->bar_height / 2.0;
|
||||
max_width -= bar_height / 2.0;
|
||||
max_height -= bar_height / 2.0;
|
||||
|
||||
if (slider_widget->inversed) {
|
||||
if (slider_widget->vertical) {
|
||||
completion_x = x + slider_widget->bar_height / 4.0;
|
||||
completion_y = y + slider_widget->bar_height / 4.0 +
|
||||
completion_x = x + bar_height / 4.0;
|
||||
completion_y = y + bar_height / 4.0 +
|
||||
max_height * (1.0 - slider_widget->current_value);
|
||||
completion_width = max_width;
|
||||
completion_height = max_height * slider_widget->current_value;
|
||||
} else {
|
||||
completion_x = x + slider_widget->bar_height / 4.0 +
|
||||
completion_x = x + bar_height / 4.0 +
|
||||
max_width * (1.0 - slider_widget->current_value);
|
||||
completion_y = y + slider_widget->bar_height / 4.0;
|
||||
completion_y = y + bar_height / 4.0;
|
||||
completion_width = max_width * slider_widget->current_value;
|
||||
completion_height = max_height;
|
||||
}
|
||||
} else {
|
||||
completion_x = x + slider_widget->bar_height / 4.0;
|
||||
completion_y = y + slider_widget->bar_height / 4.0;
|
||||
completion_x = x + bar_height / 4.0;
|
||||
completion_y = y + bar_height / 4.0;
|
||||
|
||||
if (slider_widget->vertical) {
|
||||
completion_width = max_width;
|
||||
|
|
@ -105,7 +105,7 @@ static void render_content(PGPL_GuiWidget *widget, PGPL_Renderer *renderer,
|
|||
completion_y, completion_width, completion_height);
|
||||
|
||||
pgpl_render_circle(renderer, theme->text_color[widget->gui_color], slider_x,
|
||||
slider_y, slider_widget->bar_height, 32);
|
||||
slider_y, bar_height, 32);
|
||||
}
|
||||
|
||||
static void event(PGPL_GuiWidget *widget, PGPL_GuiTheme *theme, PGPL_Gui *gui,
|
||||
|
|
@ -116,20 +116,20 @@ static void event(PGPL_GuiWidget *widget, PGPL_GuiTheme *theme, PGPL_Gui *gui,
|
|||
event_type == PGPL_WINDOW_EVENT_MOUSE_RELEASE ||
|
||||
event_type == PGPL_WINDOW_EVENT_MOUSE_MOVE) {
|
||||
PGPL_GuiSliderWidget *slider_widget = (PGPL_GuiSliderWidget *)widget;
|
||||
double bar_height = theme->font_size[PGPL_GUI_FONT_SIZE_CONTENT] / 2;
|
||||
double slider_x;
|
||||
double slider_y;
|
||||
|
||||
pgpl_gui_widget_adjust_event_params(widget, theme, &x, &y, &max_width,
|
||||
&max_height);
|
||||
|
||||
get_slider_size(slider_widget, &slider_x, &slider_y, x, y, max_width,
|
||||
get_slider_size(slider_widget, theme, &slider_x, &slider_y, x, y, max_width,
|
||||
max_height);
|
||||
|
||||
if (event_type == PGPL_WINDOW_EVENT_MOUSE_PRESS) {
|
||||
if (pgpl_gui_widget_within_area(event_data->input_event.x,
|
||||
event_data->input_event.y, slider_x,
|
||||
slider_y, slider_widget->bar_height * 2,
|
||||
slider_widget->bar_height * 2)) {
|
||||
if (pgpl_gui_widget_within_area(
|
||||
event_data->input_event.x, event_data->input_event.y, slider_x,
|
||||
slider_y, bar_height * 2, bar_height * 2)) {
|
||||
slider_widget->sliding = true;
|
||||
if (slider_widget->vertical) {
|
||||
slider_widget->last_pos = event_data->input_event.y;
|
||||
|
|
@ -151,7 +151,7 @@ static void event(PGPL_GuiWidget *widget, PGPL_GuiTheme *theme, PGPL_Gui *gui,
|
|||
axis_length = max_width;
|
||||
}
|
||||
|
||||
axis_length -= slider_widget->bar_height;
|
||||
axis_length -= bar_height;
|
||||
|
||||
if (slider_widget->inversed) {
|
||||
slider_widget->current_value -=
|
||||
|
|
@ -180,7 +180,7 @@ static void destroy(PGPL_GuiWidget *widget) {
|
|||
}
|
||||
|
||||
PGPL_GuiSliderWidget *pgpl_gui_slider_widget_create(
|
||||
uint32_t bar_height, bool inversed, bool vertical, double value,
|
||||
bool inversed, bool vertical, double value,
|
||||
void (*slide_callback)(void *app_data, double value)) {
|
||||
PGPL_GuiSliderWidget *slider_widget = calloc(1, sizeof(*slider_widget));
|
||||
pgpl_gui_widget_default_config(&slider_widget->parent);
|
||||
|
|
@ -189,7 +189,6 @@ PGPL_GuiSliderWidget *pgpl_gui_slider_widget_create(
|
|||
slider_widget->parent.render_content = render_content;
|
||||
slider_widget->parent.event = event;
|
||||
slider_widget->parent.destroy = destroy;
|
||||
slider_widget->bar_height = bar_height;
|
||||
slider_widget->inversed = inversed;
|
||||
slider_widget->vertical = vertical;
|
||||
slider_widget->current_value = value;
|
||||
|
|
|
|||
|
|
@ -181,8 +181,8 @@ PGPL_Window *pgpl_window_create(const char *title, uint32_t width,
|
|||
0,
|
||||
0,
|
||||
0,
|
||||
24,
|
||||
8,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
PFD_MAIN_PLANE,
|
||||
0,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue