ui: not done, dont moan until i am done.

Then you can moan. :)
This commit is contained in:
Alastair Poole 2020-12-23 23:14:11 +00:00
parent f4abba9a65
commit 57663dd0b2
2 changed files with 56 additions and 33 deletions

View File

@ -14,23 +14,26 @@ typedef struct {
Evas_Object *swap; Evas_Object *swap;
Evas_Object *video[MEM_VIDEO_CARD_MAX]; Evas_Object *video[MEM_VIDEO_CARD_MAX];
double scale; int pos;
Ui *ui; Ui *ui;
} Ui_Data; } Ui_Data;
static Eina_Bool starting = 1;
#define STEP 1
#define MAX_HIST 2048 #define MAX_HIST 2048
#define UPOLLTIME 100000 #define UPOLLTIME 250000
#define GR_USED 0 #define GR_USED 0
#define GR_CACHED 1 #define GR_CACHED 1
#define GR_BUFFER 2 #define GR_BUFFER 2
#define GR_SHARED 3 #define GR_SHARED 3
#define COLOR_USED 229, 64, 89, 255 #define COLOR_USED 206, 70, 93, 255
#define COLOR_CACHED 253, 179, 106, 255 #define COLOR_CACHED 135, 190, 85, 255
#define COLOR_BUFFER 142, 31, 81, 255 #define COLOR_BUFFER 100, 177, 242, 255
#define COLOR_SHARED 89, 229, 64, 255 #define COLOR_SHARED 225, 107, 62, 255
#define COLOR_NONE 0, 0, 0, 0 #define COLOR_NONE 0, 0, 0, 0
static Eina_Lock _lock; static Eina_Lock _lock;
@ -79,8 +82,8 @@ vg_add(Evas_Object *w)
o = evas_object_vg_add(evas_object_evas_get(w)); o = evas_object_vg_add(evas_object_evas_get(w));
con = evas_vg_container_add(o); con = evas_vg_container_add(o);
sh = evas_vg_shape_add(con); sh = evas_vg_shape_add(con);
evas_object_vg_root_node_set(o, con);
evas_object_show(o); evas_object_show(o);
evas_object_vg_root_node_set(o, con);
evas_object_data_set(o, "con", con); evas_object_data_set(o, "con", con);
evas_object_data_set(o, "shape", sh); evas_object_data_set(o, "shape", sh);
return o; return o;
@ -92,17 +95,12 @@ vg_fill(Evas_Object *o, Ui_Data *pd, int w, int h, double *pt, int r, int g, int
Evas_Vg_Shape *sh; Evas_Vg_Shape *sh;
int i; int i;
double v; double v;
Evas_Vg_Node *n;
evas_object_resize(o, w, h); evas_object_resize(o, w, h);
sh = evas_object_data_get(o, "shape"); sh = evas_object_data_get(o, "shape");
evas_vg_shape_reset(sh); evas_vg_shape_reset(sh);
if (pd->scale > 1.0) evas_vg_shape_append_move_to(sh, 0, h);
evas_vg_shape_stroke_width_set(sh, 2);
else
evas_vg_shape_stroke_width_set(sh, 1);
evas_vg_shape_stroke_color_set(sh, r, g, b, a);
evas_vg_shape_append_move_to(sh, 0, 1 + h - ((h / 100) * pt[0]));
for (i = 0; i < w; i++) for (i = 0; i < w; i++)
{ {
v = (h / 100) * pt[i]; v = (h / 100) * pt[i];
@ -110,7 +108,11 @@ vg_fill(Evas_Object *o, Ui_Data *pd, int w, int h, double *pt, int r, int g, int
else if (v > h) v = h; else if (v > h) v = h;
evas_vg_shape_append_line_to(sh, i, h - v); evas_vg_shape_append_line_to(sh, i, h - v);
} }
evas_vg_node_origin_set(evas_object_data_get(0, "shape"), 0, 0); evas_vg_shape_append_line_to(sh, pd->pos, h);
n = evas_object_data_get(sh, "shape");
evas_vg_shape_fill_set(sh, n);
evas_vg_node_color_set(sh, r, g, b, a);
evas_vg_node_origin_set(n, 0, 0);
} }
static void static void
@ -149,7 +151,7 @@ position_gr_list(Eina_List *list, int w, int h, int offset)
evas_object_move(o, x, 0); evas_object_move(o, x, 0);
evas_object_resize(o, w, h); evas_object_resize(o, w, h);
} }
x -= (w - 1); x -= (w - STEP);
} }
} }
@ -243,26 +245,43 @@ _update_widgets(Ui_Data *pd, meminfo_t *memory)
} }
} }
static void
_reverse(double *arr, int n)
{
for (int i = 0, j = n - 1; i < j; i++, j--)
{
double tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
}
static void static void
_update_graph(Graph *graph, double perc, Ui_Data *pd, Evas_Coord w, Evas_Coord h) _update_graph(Graph *graph, double perc, Ui_Data *pd, Evas_Coord w, Evas_Coord h)
{ {
int i, r, g, b; int i, r, g, b, a;
Evas_Object *o; Evas_Object *o;
r = graph->r; g = graph->g; b = graph->b; r = graph->r; g = graph->g; b = graph->b; a = graph->a;
if (graph->pos == 0) if (graph->pos == 0)
{ {
for (i = 0; i < MAX_HIST; i++) graph->history[i] = perc; if (starting)
for (i = 0; i < MAX_HIST; i++)
graph->history[i] = 0;
else
_reverse(graph->history, MAX_HIST);
o = vg_add(pd->bg); o = vg_add(pd->bg);
graph->blocks = eina_list_prepend(graph->blocks, o); graph->blocks = eina_list_prepend(graph->blocks, o);
} }
o = graph->blocks->data; o = graph->blocks->data;
graph->history[graph->pos] = perc; graph->history[graph->pos] = perc;
vg_fill(o, pd, w, h, graph->history, r, g, b, 255); pd->pos = graph->pos;
vg_fill(o, pd, w, h, graph->history, r, g, b, a);
position_gr_list(graph->blocks, w, h, graph->pos); position_gr_list(graph->blocks, w, h, graph->pos);
graph->pos++; graph->pos += STEP;
if (graph->pos >= w) graph->pos = 0; if (graph->pos >= w) graph->pos = 0;
} }
@ -293,6 +312,7 @@ _mem_usage_feedback_cb(void *data, Ecore_Thread *thread EINA_UNUSED, void *msgda
_update_graph(&graphs[GR_BUFFER], memory->buffered / ratio, pd, w, h); _update_graph(&graphs[GR_BUFFER], memory->buffered / ratio, pd, w, h);
_update_graph(&graphs[GR_SHARED], memory->shared / ratio, pd, w, h); _update_graph(&graphs[GR_SHARED], memory->shared / ratio, pd, w, h);
if (starting) starting = 0;
eina_lock_release(&_lock); eina_lock_release(&_lock);
} }
@ -326,8 +346,6 @@ _elm_config_changed_cb(void *data, int type EINA_UNUSED, void *event EINA_UNUSED
{ {
Ui_Data *pd = data; Ui_Data *pd = data;
pd->scale = elm_config_scale_get();
return EINA_TRUE; return EINA_TRUE;
} }

View File

@ -22,6 +22,8 @@ typedef struct
Eina_List *cpu_times; Eina_List *cpu_times;
Eina_List *cpu_list; Eina_List *cpu_list;
Ecore_Event_Handler *handler[2];
Ui *ui; Ui *ui;
pid_t selected_pid; pid_t selected_pid;
@ -776,31 +778,31 @@ _process_list_update(Ui_Data *pd)
} }
static void static void
_btn_icon_state_update(Evas_Object *button, Eina_Bool reverse) _btn_icon_state_update(Evas_Object *btn, Eina_Bool reverse)
{ {
Evas_Object *icon = elm_icon_add(button); Evas_Object *icon = elm_icon_add(btn);
if (reverse) if (reverse)
elm_icon_standard_set(icon, evisum_icon_path_get("go-down")); elm_icon_standard_set(icon, evisum_icon_path_get("go-down"));
else else
elm_icon_standard_set(icon, evisum_icon_path_get("go-up")); elm_icon_standard_set(icon, evisum_icon_path_get("go-up"));
elm_object_part_content_set(button, "icon", icon); elm_object_part_content_set(btn, "icon", icon);
evas_object_show(icon); evas_object_show(icon);
} }
static void static void
_btn_icon_state_init(Evas_Object *button, Eina_Bool reverse, _btn_icon_state_init(Evas_Object *btn, Eina_Bool reverse,
Eina_Bool selected EINA_UNUSED) Eina_Bool selected EINA_UNUSED)
{ {
Evas_Object *icon = elm_icon_add(button); Evas_Object *icon = elm_icon_add(btn);
if (reverse) if (reverse)
elm_icon_standard_set(icon, evisum_icon_path_get("go-down")); elm_icon_standard_set(icon, evisum_icon_path_get("go-down"));
else else
elm_icon_standard_set(icon, evisum_icon_path_get("go-up")); elm_icon_standard_set(icon, evisum_icon_path_get("go-up"));
elm_object_part_content_set(button, "icon", icon); elm_object_part_content_set(btn, "icon", icon);
evas_object_show(icon); evas_object_show(icon);
} }
@ -1474,6 +1476,9 @@ _win_del_cb(void *data EINA_UNUSED, Evas *e EINA_UNUSED, Evas_Object *obj EINA_U
if (pd->thread) if (pd->thread)
ecore_thread_wait(pd->thread, 0.2); ecore_thread_wait(pd->thread, 0.2);
ecore_event_handler_del(pd->handler[0]);
ecore_event_handler_del(pd->handler[1]);
pd->thread = NULL; pd->thread = NULL;
ui->win = NULL; ui->win = NULL;
@ -1506,10 +1511,10 @@ ui_process_list_win_add(Ui *ui)
pd->selected_pid = -1; pd->selected_pid = -1;
pd->ui = ui; pd->ui = ui;
ecore_event_handler_add(ELM_EVENT_CONFIG_ALL_CHANGED, pd->handler[0] = ecore_event_handler_add(ELM_EVENT_CONFIG_ALL_CHANGED,
_elm_config_changed_cb, pd); _elm_config_changed_cb, pd);
ecore_event_handler_add(EVISUM_EVENT_CONFIG_CHANGED, pd->handler[1] = ecore_event_handler_add(EVISUM_EVENT_CONFIG_CHANGED,
_evisum_config_changed_cb, pd); _evisum_config_changed_cb, pd);
ui->win = pd->win = win = elm_win_util_standard_add("evisum", "evisum"); ui->win = pd->win = win = elm_win_util_standard_add("evisum", "evisum");
elm_win_autodel_set(win, EINA_TRUE); elm_win_autodel_set(win, EINA_TRUE);