store widget height
[awesome.git] / widgets / progressbar.c
blob139eb9c84782457db5ecdaecf139d0e140649d99
1 /*
2 * progressbar.c - progress bar widget
4 * Copyright © 2007-2008 Julien Danjou <julien@danjou.info>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #include <string.h>
23 #include "util.h"
24 #include "draw.h"
25 #include "widget.h"
26 #include "xutil.h"
27 #include "screen.h"
29 extern AwesomeConf globalconf;
31 typedef struct
33 /** Percent 0 to 100 */
34 int *percent;
35 /** Width of the bars */
36 int width;
37 /** Left padding */
38 int lpadding;
39 /** Pixel between bars */
40 int gap;
41 /** Number of bars */
42 int bars;
43 /** Height 0-1, where 1 is height of statusbar */
44 float height;
45 /** Foreground color */
46 XColor *fg;
47 /** Background color */
48 XColor *bg;
49 /** Border color */
50 XColor *bcolor;
51 } Data;
53 static int
54 progressbar_draw(Widget *widget, DrawCtx *ctx, int offset,
55 int used __attribute__ ((unused)))
57 int i, width, pwidth, margin_top, pb_height, left_offset;
59 Data *d = widget->data;
61 if (!(d->bars))
62 return 0;
64 width = d->width - d->lpadding;
66 if(!widget->user_supplied_x)
67 widget->area.x = widget_calculate_offset(widget->statusbar->width,
68 d->width,
69 offset,
70 widget->alignment);
72 if(!widget->user_supplied_y)
73 widget->area.y = 0;
75 margin_top = (int) (widget->statusbar->height * (1 - d->height)) / 2 + 0.5 + widget->area.y;
76 pb_height = (int) (widget->statusbar->height * d->height - (d->gap * (d->bars - 1))) / d->bars + 0.5;
77 left_offset = widget->area.x + d->lpadding;
79 for(i = 0; i < d->bars; i++)
81 pwidth = (int) d->percent[i] ? ((width - 2) * d->percent[i]) / 100 : 0;
83 draw_rectangle(ctx,
84 left_offset, margin_top,
85 width, pb_height,
86 False, d->bcolor[i]);
88 if(pwidth > 0)
89 draw_rectangle(ctx,
90 left_offset + 1, margin_top + 1,
91 pwidth, pb_height - 2,
92 True, d->fg[i]);
94 if(width - 2 - pwidth > 0) /* not filled area */
95 draw_rectangle(ctx,
96 left_offset + 1 + pwidth, margin_top + 1,
97 width - 2 - pwidth, pb_height - 2,
98 True, d->bg[i]);
100 margin_top += (pb_height + d->gap);
103 widget->area.width = d->width;
104 widget->area.height = widget->statusbar->height;
105 return widget->area.width;
108 static void
109 progressbar_tell(Widget *widget, char *command)
111 Data *d = widget->data;
112 int i = 0, percent;
113 char * tok;
115 if(!command || !d->bars)
116 return;
118 for (tok = strtok(command, ","); tok && i < d->bars; tok = strtok(NULL, ","), i++)
120 percent = atoi(tok);
121 if(percent <= 100 && percent >= 0)
122 d->percent[i] = percent;
126 Widget *
127 progressbar_new(Statusbar *statusbar, cfg_t *config)
129 Widget *w;
130 Data *d;
131 char *color;
132 int i, phys_screen = get_phys_screen(statusbar->screen);
133 cfg_t *cfg;
136 w = p_new(Widget, 1);
137 widget_common_new(w, statusbar, config);
138 w->draw = progressbar_draw;
139 w->tell = progressbar_tell;
140 d = w->data = p_new(Data, 1);
141 d->width = cfg_getint(config, "width");
143 if(!(d->bars = cfg_size(config, "bar")))
145 warn("progressbar widget needs at least one bar section\n");
146 return w;
149 d->bg = p_new(XColor, d->bars);
150 d->fg = p_new(XColor, d->bars);
151 d->bcolor = p_new(XColor, d->bars);
152 d->percent = p_new(int, d->bars);
154 for(i = 0; i < d->bars; i++)
156 cfg = cfg_getnsec(config, "bar", i);
158 if((color = cfg_getstr(cfg, "fg")))
159 d->fg[i] = initxcolor(phys_screen, color);
160 else
161 d->fg[i] = globalconf.screens[statusbar->screen].colors_normal[ColFG];
163 if((color = cfg_getstr(cfg, "bg")))
164 d->bg[i] = initxcolor(phys_screen, color);
165 else
166 d->bg[i] = globalconf.screens[statusbar->screen].colors_normal[ColBG];
168 if((color = cfg_getstr(cfg, "bcolor")))
169 d->bcolor[i] = initxcolor(phys_screen, color);
170 else
171 d->bcolor[i] = d->fg[i];
176 d->height = cfg_getfloat(config, "height");
177 d->gap = cfg_getint(config, "gap");
178 d->lpadding = cfg_getint(config, "lpadding");
180 return w;
182 // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80