enlightenment/src/modules/sysinfo/thermal/thermal_config.c

357 lines
11 KiB
C

#include "thermal.h"
#define FAR_2_CEL(x) ((x - 32) / 9.0) * 5.0
#define CEL_2_FAR(x) (x * 9.0 / 5.0) + 32
static void
_config_close(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
{
Thermal_Config *tc = data;
Instance *inst = tc->inst;
E_FREE_FUNC(inst->cfg->thermal.configure, evas_object_del);
E_FREE_FUNC(tc, free);
e_config_save_queue();
}
static void
_update_high_temperature(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
{
Thermal_Config *tc = data;
Instance *inst = tc->inst;
int value = (int)elm_slider_value_get(tc->high);
inst->cfg->thermal.high = value;
e_config_save_queue();
_thermal_config_updated(inst);
}
static void
_update_low_temperature(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
{
Thermal_Config *tc = data;
Instance *inst = tc->inst;
int value = (int)elm_slider_value_get(tc->low);
inst->cfg->thermal.low = value;
e_config_save_queue();
_thermal_config_updated(inst);
}
static void
_units_changed(void *data, Evas_Object *obj, void *event_info EINA_UNUSED)
{
Thermal_Config *tc = data;
Instance *inst = tc->inst;
int value = elm_radio_value_get(obj), val;
switch (value)
{
case 0:
inst->cfg->thermal.units = CELSIUS;
break;
case 1:
inst->cfg->thermal.units = FAHRENHEIT;
break;
default:
inst->cfg->thermal.units = CELSIUS;
}
if (inst->cfg->thermal.units == FAHRENHEIT)
{
elm_slider_min_max_set(tc->low, 0, 200);
elm_slider_min_max_set(tc->high, 0, 230);
val = (int)elm_slider_value_get(tc->low);
elm_slider_value_set(tc->low, ceil(CEL_2_FAR(val)));
val = (int)elm_slider_value_get(tc->high);
elm_slider_value_set(tc->high, ceil(CEL_2_FAR(val)));
elm_slider_unit_format_set(tc->high, "%1.0f F");
elm_slider_indicator_format_set(tc->high, "%1.0f F");
elm_slider_unit_format_set(tc->low, "%1.0f F");
elm_slider_indicator_format_set(tc->low, "%1.0f F");
}
else
{
val = (int)elm_slider_value_get(tc->low);
elm_slider_value_set(tc->low, ceil(FAR_2_CEL(val)));
val = (int)elm_slider_value_get(tc->high);
elm_slider_value_set(tc->high, ceil(FAR_2_CEL(val)));
elm_slider_unit_format_set(tc->low, "%1.0f C");
elm_slider_indicator_format_set(tc->low, "%1.0f C");
elm_slider_unit_format_set(tc->high, "%1.0f C");
elm_slider_indicator_format_set(tc->high, "%1.0f C");
elm_slider_min_max_set(tc->low, 0, 95);
elm_slider_min_max_set(tc->high, 0, 110);
}
val = (int)elm_slider_value_get(tc->high);
inst->cfg->thermal.high = val;
val = (int)elm_slider_value_get(tc->low);
inst->cfg->thermal.low = val;
e_config_save_queue();
_thermal_config_updated(inst);
}
static void
_poll_changed(void *data, Evas_Object *obj, void *event_info EINA_UNUSED)
{
Thermal_Config *tc = data;
Instance *inst = tc->inst;
int value = elm_radio_value_get(obj);
switch (value)
{
case 0:
inst->cfg->thermal.poll_interval = 4;
break;
case 1:
inst->cfg->thermal.poll_interval = 8;
break;
case 2:
inst->cfg->thermal.poll_interval = 32;
break;
case 3:
inst->cfg->thermal.poll_interval = 64;
break;
case 4:
inst->cfg->thermal.poll_interval = 256;
break;
default:
inst->cfg->thermal.poll_interval = 32;
}
e_config_save_queue();
_thermal_config_updated(inst);
}
Evas_Object *
thermal_configure(Instance *inst)
{
Evas_Object *popup, *tb, *frame, *box, *o, *group, *groupu, *lbl, *slider;
E_Zone *zone = e_zone_current_get();
Thermal_Config *tc = E_NEW(Thermal_Config, 1);
tc->inst = inst;
popup = elm_popup_add(e_comp->elm);
E_EXPAND(popup);
elm_popup_allow_events_set(popup, 1);
elm_popup_scrollable_set(popup, 1);
tb = elm_table_add(popup);
E_EXPAND(tb);
evas_object_show(tb);
elm_object_content_set(popup, tb);
lbl = elm_label_add(tb);
evas_object_size_hint_weight_set(lbl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(lbl, EVAS_HINT_FILL, EVAS_HINT_FILL);
elm_object_style_set(lbl, "marker");
elm_object_text_set(lbl, _("Thermal Configuration"));
elm_table_pack(tb, lbl, 0, 0, 1, 1);
evas_object_show(lbl);
frame = elm_frame_add(tb);
elm_object_text_set(frame, _("Temperature Units"));
E_EXPAND(frame);
E_FILL(frame);
elm_table_pack(tb, frame, 0, 1, 1, 1);
evas_object_show(frame);
box = elm_box_add(frame);
elm_box_horizontal_set(box, EINA_FALSE);
E_EXPAND(box);
evas_object_show(box);
o = elm_radio_add(box);
elm_radio_state_value_set(o, 0);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Celsius"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _units_changed, tc);
evas_object_show(o);
groupu = o;
o = elm_radio_add(box);
elm_radio_state_value_set(o, 1);
elm_radio_group_add(o, groupu);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Fahrenheit"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _units_changed, tc);
evas_object_show(o);
switch(inst->cfg->thermal.units)
{
case CELSIUS:
elm_radio_value_set(groupu, 0);
break;
case FAHRENHEIT:
elm_radio_value_set(groupu, 1);
break;
default:
elm_radio_value_set(groupu, 0);
}
elm_object_content_set(frame, box);
frame = elm_frame_add(tb);
elm_object_text_set(frame, _("Update Poll Interval"));
E_EXPAND(frame);
E_FILL(frame);
elm_table_pack(tb, frame, 0, 2, 1, 1);
evas_object_show(frame);
box = elm_box_add(frame);
elm_box_horizontal_set(box, EINA_FALSE);
E_EXPAND(box);
evas_object_show(box);
o = elm_radio_add(box);
elm_radio_state_value_set(o, 0);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Fast (4 ticks)"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _poll_changed, tc);
evas_object_show(o);
group = o;
o = elm_radio_add(box);
elm_radio_state_value_set(o, 1);
elm_radio_group_add(o, group);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Medium (8 ticks)"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _poll_changed, tc);
evas_object_show(o);
o = elm_radio_add(box);
elm_radio_state_value_set(o, 2);
elm_radio_group_add(o, group);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Normal (32 ticks)"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _poll_changed, tc);
evas_object_show(o);
o = elm_radio_add(box);
elm_radio_state_value_set(o, 3);
elm_radio_group_add(o, group);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Slow (64 ticks)"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _poll_changed, tc);
evas_object_show(o);
o = elm_radio_add(box);
elm_radio_state_value_set(o, 4);
elm_radio_group_add(o, group);
E_ALIGN(o, 0.0, 0.0);
E_WEIGHT(o, EVAS_HINT_EXPAND, 0);
elm_object_text_set(o, _("Very Slow (256 ticks)"));
elm_box_pack_end(box, o);
evas_object_smart_callback_add(o, "changed", _poll_changed, tc);
evas_object_show(o);
switch(inst->cfg->thermal.poll_interval)
{
case 4:
elm_radio_value_set(group, 0);
break;
case 8:
elm_radio_value_set(group, 1);
break;
case 32:
elm_radio_value_set(group, 2);
break;
case 64:
elm_radio_value_set(group, 3);
break;
case 256:
elm_radio_value_set(group, 4);
break;
default:
elm_radio_value_set(group, 2);
}
elm_object_content_set(frame, box);
frame = elm_frame_add(tb);
elm_object_text_set(frame, _("Temperature Limits"));
E_EXPAND(frame);
E_FILL(frame);
elm_table_pack(tb, frame, 0, 3, 1, 1);
evas_object_show(frame);
box = elm_box_add(frame);
elm_box_horizontal_set(box, EINA_FALSE);
E_EXPAND(box);
evas_object_show(box);
slider = elm_slider_add(box);
elm_object_text_set(slider, _("High Temperature:"));
if (inst->cfg->thermal.units == FAHRENHEIT)
{
elm_slider_unit_format_set(slider, "%1.0f F");
elm_slider_indicator_format_set(slider, "%1.0f F");
elm_slider_min_max_set(slider, 0, 230);
}
else
{
elm_slider_unit_format_set(slider, "%1.0f C");
elm_slider_indicator_format_set(slider, "%1.0f C");
elm_slider_min_max_set(slider, 0, 110);
}
elm_slider_value_set(slider, inst->cfg->thermal.high);
elm_slider_step_set(slider, 5);
elm_slider_span_size_set(slider, 150);
evas_object_size_hint_align_set(slider, EVAS_HINT_FILL, 0.5);
evas_object_size_hint_weight_set(slider, EVAS_HINT_EXPAND, 0.0);
evas_object_smart_callback_add(slider, "delay,changed", _update_high_temperature, tc);
elm_box_pack_end(box, slider);
evas_object_show(slider);
tc->high = slider;
slider = elm_slider_add(box);
elm_object_text_set(slider, _("Low Temperature:"));
if (inst->cfg->thermal.units == FAHRENHEIT)
{
elm_slider_unit_format_set(slider, "%1.0f F");
elm_slider_indicator_format_set(slider, "%1.0f F");
elm_slider_min_max_set(slider, 0, 200);
}
else
{
elm_slider_unit_format_set(slider, "%1.0f C");
elm_slider_indicator_format_set(slider, "%1.0f C");
elm_slider_min_max_set(slider, 0, 95);
}
elm_slider_value_set(slider, inst->cfg->thermal.low);
elm_slider_step_set(slider, 5);
elm_slider_span_size_set(slider, 150);
evas_object_size_hint_align_set(slider, EVAS_HINT_FILL, 0.5);
evas_object_size_hint_weight_set(slider, EVAS_HINT_EXPAND, 0.0);
evas_object_smart_callback_add(slider, "delay,changed", _update_low_temperature, tc);
elm_box_pack_end(box, slider);
evas_object_show(slider);
tc->low = slider;
elm_object_content_set(frame, box);
popup = e_comp_object_util_add(popup, E_COMP_OBJECT_TYPE_NONE);
evas_object_layer_set(popup, E_LAYER_POPUP);
evas_object_resize(popup, zone->w / 4, zone->h / 3);
e_comp_object_util_center_on_zone(popup, zone);
evas_object_show(popup);
e_comp_object_util_autoclose(popup, NULL, e_comp_object_util_autoclose_on_escape, NULL);
evas_object_event_callback_add(popup, EVAS_CALLBACK_DEL, _config_close, tc);
return inst->cfg->thermal.configure = popup;
}