s->color->f_red,
s->color->f_green,
s->color->f_blue);
+ cairo_set_line_join(cr, CAIRO_LINE_JOIN_ROUND);
cairo_set_line_width(cr, 1);
for (i = 0; i < s->values_max_length; i++) {
double v;
t = s->measures[i].time.tv_sec;
- v = s->measures[i].value;
+ v = s->measures[i].value.d_num;
- if (v == UNKNOWN_VALUE || !t || (t - bt) < 0)
+ if (v == UNKNOWN_DBL_VALUE || !t || (t - bt) < 0)
continue;
x = (t - bt) * g_width / (et - bt) + g_xoff;
void
graph_update(struct psensor **sensors,
- GtkWidget *w_graph, struct config *config)
+ GtkWidget *w_graph,
+ struct config *config)
{
struct color *fgcolor = config->graph_fgcolor;
- int et, bt;
- double min_rpm = get_min_rpm(sensors);
- double max_rpm = get_max_rpm(sensors);
-
- double mint = get_min_temp(sensors);
- char *strmin = psensor_value_to_string(SENSOR_TYPE_TEMP, mint);
-
- double maxt = get_max_temp(sensors);
- char *strmax = psensor_value_to_string(SENSOR_TYPE_TEMP, maxt);
-
- int width = w_graph->allocation.width;
- int height = w_graph->allocation.height;
-
- int g_width, g_height;
-
+ int et, bt, width, height, g_width, g_height;
+ double min_rpm, max_rpm, mint, maxt;
+ char *strmin, *strmax;
/* horizontal and vertical offset of the graph */
int g_xoff, g_yoff;
+ cairo_surface_t *cst;
+ cairo_t *cr, *cr_pixmap;
+ char *str_btime, *str_etime;
+ cairo_text_extents_t te_btime, te_etime, te_max, te_min;
+ struct psensor **sensor_cur;
+ GtkAllocation galloc;
- cairo_surface_t *cst = cairo_image_surface_create(CAIRO_FORMAT_ARGB32,
- width,
- height);
- cairo_t *cr = cairo_create(cst);
- cairo_t *cr_pixmap;
+ if (!gtk_widget_is_drawable(w_graph))
+ return ;
- char *str_btime = time_to_str(get_graph_begin_time_s(config));
- cairo_text_extents_t te_btime;
+ min_rpm = get_min_rpm(sensors);
+ max_rpm = get_max_rpm(sensors);
- char *str_etime = time_to_str(get_graph_end_time_s());
- cairo_text_extents_t te_etime;
+ mint = get_min_temp(sensors);
+ strmin = psensor_value_to_string(SENSOR_TYPE_TEMP, mint);
- cairo_text_extents_t te_max, te_min;
+ maxt = get_max_temp(sensors);
+ strmax = psensor_value_to_string(SENSOR_TYPE_TEMP, maxt);
- struct psensor **sensor_cur;
+ str_btime = time_to_str(get_graph_begin_time_s(config));
+ str_etime = time_to_str(get_graph_end_time_s());
+
+ gtk_widget_get_allocation(w_graph, &galloc);
+ width = galloc.width;
+ height = galloc.height;
+
+ cst = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, width, height);
+ cr = cairo_create(cst);
draw_graph_background(cr, width, height, config);
if (is_fan_type(s->type)) {
min = min_rpm;
max = max_rpm;
+ } else if (s->type & SENSOR_TYPE_CPU_USAGE) {
+ min = 0;
+ max = get_max_value
+ (sensors,
+ SENSOR_TYPE_CPU_USAGE);
} else {
min = mint;
max = maxt;
}
}
- cr_pixmap = gdk_cairo_create(w_graph->window);
+ cr_pixmap = gdk_cairo_create(gtk_widget_get_window(w_graph));
if (cr_pixmap) {