small update
This commit is contained in:
parent
f0b172a3be
commit
30800c95f2
16
Readme.md
16
Readme.md
@ -225,7 +225,7 @@ code the panel was introduced. The panel groups together a number of
|
|||||||
widgets but in true immediate mode fashion does not save any state from
|
widgets but in true immediate mode fashion does not save any state from
|
||||||
widgets that have been added to the panel. In addition the panel enables a
|
widgets that have been added to the panel. In addition the panel enables a
|
||||||
number of nice features on a group of widgets like movement, scaling,
|
number of nice features on a group of widgets like movement, scaling,
|
||||||
closing and minimizing. An additional use for panel is to further extend the
|
hidding and minimizing. An additional use for panel is to further extend the
|
||||||
grouping of widgets into tabs, groups and shelfs.
|
grouping of widgets into tabs, groups and shelfs.
|
||||||
The panel is divided into a `struct gui_panel` with persistent life time and
|
The panel is divided into a `struct gui_panel` with persistent life time and
|
||||||
the `struct gui_panel_layout` structure with a temporary life time.
|
the `struct gui_panel_layout` structure with a temporary life time.
|
||||||
@ -267,11 +267,11 @@ not known beforehand since it is possible to create your own buffer type.
|
|||||||
Therefore just the sequence of panels is managed and you either have to cast
|
Therefore just the sequence of panels is managed and you either have to cast
|
||||||
from the panel to your own type, use inheritance in C++ or use the `container_of`
|
from the panel to your own type, use inheritance in C++ or use the `container_of`
|
||||||
macro from the Linux kernel. For the standard buffer there is already a type
|
macro from the Linux kernel. For the standard buffer there is already a type
|
||||||
`gui_window` which contains the panel and the buffer output `gui_command_list`,
|
`gui_panel_hook` which contains the panel and the buffer output `gui_command_list`,
|
||||||
which can be used to implement overlapping panels.
|
which can be used to implement overlapping panels.
|
||||||
|
|
||||||
```c
|
```c
|
||||||
struct gui_window window;
|
struct gui_panel_hook hook;
|
||||||
struct gui_memory memory = {...};
|
struct gui_memory memory = {...};
|
||||||
struct gui_memory_status status;
|
struct gui_memory_status status;
|
||||||
struct gui_command_buffer buffer;
|
struct gui_command_buffer buffer;
|
||||||
@ -282,9 +282,9 @@ struct gui_stack stack;
|
|||||||
|
|
||||||
gui_buffer_init_fixed(buffer, &memory);
|
gui_buffer_init_fixed(buffer, &memory);
|
||||||
gui_default_config(&config);
|
gui_default_config(&config);
|
||||||
gui_panel_init(&win.panel, 50, 50, 300, 200, 0, &config, &font);
|
gui_panel_init(&hook.panel, 50, 50, 300, 200, 0, &config, &font);
|
||||||
gui_stack_clear(&stack);
|
gui_stack_clear(&stack);
|
||||||
gui_stack_push(&stack, &win.panel);
|
gui_stack_push(&stack, &hook.panel);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
struct gui_panel_layout layout;
|
struct gui_panel_layout layout;
|
||||||
@ -301,11 +301,11 @@ while (1) {
|
|||||||
/* draw each panel */
|
/* draw each panel */
|
||||||
struct gui_panel *iter = stack.begin;
|
struct gui_panel *iter = stack.begin;
|
||||||
while (iter) {
|
while (iter) {
|
||||||
const struct gui_window *w = iter;
|
const struct gui_panel_hook *h = iter;
|
||||||
const struct gui_command *cmd = gui_list_begin(&w->list);
|
const struct gui_command *cmd = gui_list_begin(&h->list);
|
||||||
while (cmd) {
|
while (cmd) {
|
||||||
/* execute command */
|
/* execute command */
|
||||||
cmd = gui_list_next(&w->list, cmd);
|
cmd = gui_list_next(&h->list, cmd);
|
||||||
}
|
}
|
||||||
iter = iter->next;
|
iter = iter->next;
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define MAX_MEMORY (32 * 1024)
|
#define MAX_MEMORY (32 * 1024)
|
||||||
|
|
||||||
struct show_window {
|
struct show_window {
|
||||||
struct gui_window win;
|
struct gui_panel_hook win;
|
||||||
gui_char in_buf[MAX_BUFFER];
|
gui_char in_buf[MAX_BUFFER];
|
||||||
gui_size in_len;
|
gui_size in_len;
|
||||||
gui_bool in_act;
|
gui_bool in_act;
|
||||||
@ -27,7 +27,7 @@ struct show_window {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct control_window {
|
struct control_window {
|
||||||
struct gui_window win;
|
struct gui_panel_hook win;
|
||||||
gui_flags show_flags;
|
gui_flags show_flags;
|
||||||
gui_bool flag_min;
|
gui_bool flag_min;
|
||||||
gui_bool style_min;
|
gui_bool style_min;
|
||||||
|
@ -483,8 +483,8 @@ draw(struct gui_panel_stack *stack, int width, int height)
|
|||||||
struct gui_panel *iter = stack->begin;
|
struct gui_panel *iter = stack->begin;
|
||||||
if (!stack->count) return;
|
if (!stack->count) return;
|
||||||
while (iter) {
|
while (iter) {
|
||||||
struct gui_window *win = (void*)iter;
|
struct gui_panel_hook *hook = (void*)iter;
|
||||||
execute(&win->list, width, height);
|
execute(&hook->list, width, height);
|
||||||
iter = iter->next;
|
iter = iter->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -347,8 +347,8 @@ draw(XSurface *surf, struct gui_panel_stack *stack)
|
|||||||
struct gui_panel *iter = stack->begin;
|
struct gui_panel *iter = stack->begin;
|
||||||
if (!stack->count) return;
|
if (!stack->count) return;
|
||||||
while (iter) {
|
while (iter) {
|
||||||
struct gui_window *win = (void*)iter;
|
struct gui_panel_hook *hook = (void*)iter;
|
||||||
execute(surf, &win->list);
|
execute(surf, &hook->list);
|
||||||
iter = iter->next;
|
iter = iter->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
2
gui.c
2
gui.c
@ -1241,7 +1241,7 @@ gui_default_config(struct gui_config *config)
|
|||||||
col_load(config->colors[GUI_COLOR_BUTTON_HOVER], 100, 100, 100, 255);
|
col_load(config->colors[GUI_COLOR_BUTTON_HOVER], 100, 100, 100, 255);
|
||||||
col_load(config->colors[GUI_COLOR_BUTTON_TOGGLE], 75, 75, 75, 255);
|
col_load(config->colors[GUI_COLOR_BUTTON_TOGGLE], 75, 75, 75, 255);
|
||||||
col_load(config->colors[GUI_COLOR_BUTTON_HOVER_FONT], 45, 45, 45, 255);
|
col_load(config->colors[GUI_COLOR_BUTTON_HOVER_FONT], 45, 45, 45, 255);
|
||||||
col_load(config->colors[GUI_COLOR_BUTTON_BORDER], 80, 80, 80, 255);
|
col_load(config->colors[GUI_COLOR_BUTTON_BORDER], 100, 100, 100, 255);
|
||||||
col_load(config->colors[GUI_COLOR_CHECK], 100, 100, 100, 255);
|
col_load(config->colors[GUI_COLOR_CHECK], 100, 100, 100, 255);
|
||||||
col_load(config->colors[GUI_COLOR_CHECK_BACKGROUND], 45, 45, 45, 255);
|
col_load(config->colors[GUI_COLOR_CHECK_BACKGROUND], 45, 45, 45, 255);
|
||||||
col_load(config->colors[GUI_COLOR_CHECK_ACTIVE], 45, 45, 45, 255);
|
col_load(config->colors[GUI_COLOR_CHECK_ACTIVE], 45, 45, 45, 255);
|
||||||
|
2
gui.h
2
gui.h
@ -427,7 +427,7 @@ struct gui_panel_stack {
|
|||||||
struct gui_panel *end;
|
struct gui_panel *end;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct gui_window {
|
struct gui_panel_hook {
|
||||||
struct gui_panel panel;
|
struct gui_panel panel;
|
||||||
struct gui_command_list list;
|
struct gui_command_list list;
|
||||||
};
|
};
|
||||||
|
BIN
screen/demo.png
BIN
screen/demo.png
Binary file not shown.
Before Width: | Height: | Size: 7.8 KiB After Width: | Height: | Size: 8.0 KiB |
Loading…
Reference in New Issue
Block a user