enventor/src/bin/statusbar.c

109 lines
2.6 KiB
C
Raw Normal View History

2013-07-20 01:51:56 -07:00
#include <Elementary.h>
#include "common.h"
typedef struct statusbar_s
2013-07-20 01:51:56 -07:00
{
Evas_Object *layout;
Eina_Stringshare *group_name;
int cur_line;
int max_line;
} stats_data;
stats_data *g_sd = NULL;
2013-07-20 01:51:56 -07:00
void
stats_line_num_update(int cur_line, int max_line)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = g_sd;
2013-07-20 01:51:56 -07:00
char buf[128];
snprintf(buf, sizeof(buf),
"<align=right>Line [<style=glow><color=#3399ff>%d</color></style>:<style=glow><color=#3399ff>%d</color></style>]</align>", cur_line, max_line);
2013-07-20 01:51:56 -07:00
elm_object_part_text_set(sd->layout, "elm.text.line", buf);
sd->cur_line = cur_line;
sd->max_line = max_line;
2013-07-20 01:51:56 -07:00
}
void
stats_edc_group_update(Eina_Stringshare *group_name)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = g_sd;
char buf[1028];
snprintf(buf, sizeof(buf), "<align=right>Group [<style=glow><color=#3399ff>%s</color></style></align>", group_name);
elm_object_part_text_set(sd->layout, "elm.text.group_name", buf);
sd->group_name = eina_stringshare_add(group_name);
2013-07-20 01:51:56 -07:00
}
Evas_Object *
stats_init(Evas_Object *parent)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = calloc(1, sizeof(stats_data));
if (!sd)
{
EINA_LOG_ERR("Failed to allocate Memory!");
return NULL;
}
g_sd = sd;
2013-07-20 01:51:56 -07:00
Evas_Object *layout = elm_layout_add(parent);
elm_layout_file_set(layout, EDJE_PATH, "statusbar_layout");
sd->layout = layout;
stats_cursor_pos_update(0, 0, 0, 0);
stats_edc_group_update(NULL);
2013-07-20 01:51:56 -07:00
return layout;
2013-07-20 01:51:56 -07:00
}
Eina_Stringshare *stats_group_name_get(void)
{
stats_data *sd = g_sd;
return sd->group_name;
}
2013-07-20 01:51:56 -07:00
void
stats_term(void)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = g_sd;
eina_stringshare_del(sd->group_name);
2013-07-20 01:51:56 -07:00
free(sd);
}
void
stats_info_msg_update(const char *msg)
2013-07-20 01:51:56 -07:00
{
if (!config_stats_bar_get()) return;
stats_data *sd = g_sd;
2013-07-20 01:51:56 -07:00
elm_object_part_text_set(sd->layout, "elm.text.info_msg", msg);
elm_object_signal_emit(sd->layout, "elm,action,info_msg,show", "");
}
void
stats_view_size_update(void)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = g_sd;
2013-07-20 01:51:56 -07:00
Evas_Coord w, h;
config_view_size_get(&w, &h);
2013-07-20 01:51:56 -07:00
char buf[128];
snprintf(buf, sizeof(buf),
"Size [<style=glow><color=#3399ff>%d</color></style>x<style=glow><color=#3399ff>%d</color></style>]", w, h);
2013-09-20 04:20:26 -07:00
2013-07-20 01:51:56 -07:00
elm_object_part_text_set(sd->layout, "elm.text.view_size", buf);
}
void
stats_cursor_pos_update(Evas_Coord x, Evas_Coord y, float rel_x, float rel_y)
2013-07-20 01:51:56 -07:00
{
stats_data *sd = g_sd;
2013-09-20 09:33:42 -07:00
char buf[250];
snprintf(buf, sizeof(buf),
"Cursor [<style=glow><color=#3399ff>%d</color></style>,<style=glow><color=#3399ff>%d</color></style>] [<style=glow><color=#3399ff>%0.2f</color></style>,<style=glow><color=#3399ff>%0.2f</color></style>]", x, y, rel_x, rel_y);
2013-09-20 04:20:26 -07:00
2013-07-20 01:51:56 -07:00
elm_object_part_text_set(sd->layout, "elm.text.cur_pos", buf);
}