fixed issue 49 and some systray code (not yet)

git-svn-id: http://tint2.googlecode.com/svn/trunk@63 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
This commit is contained in:
lorthiois@bbsoft.fr
2009-02-27 22:18:30 +00:00
parent a08622a70d
commit 2121a32916
11 changed files with 170 additions and 102 deletions

View File

@@ -29,25 +29,22 @@
#include "server.h"
#include "panel.h"
// 1) resize child
// 2) resize parent
// 3) redraw parent
// 4) redraw child
void refresh (Area *a)
{
if (!a->visible) return;
if (a->resize) {
// resize can generate a redraw
if (a->_resize) {
//printf("resize area posx %d, width %d\n", a->posx, a->width);
a->_resize(a);
}
a->resize = 0;
}
size(a);
if (a->redraw) {
a->redraw = 0;
//printf("draw area posx %d, width %d\n", a->posx, a->width);
draw(a, 0);
if (a->use_active)
draw(a, 1);
a->redraw = 0;
}
// draw current Area
@@ -55,12 +52,29 @@ void refresh (Area *a)
XCopyArea (server.dsp, *pmap, ((Panel *)a->panel)->temp_pmap, server.gc, 0, 0, a->width, a->height, a->posx, a->posy);
// and then refresh child object
GSList *l = a->list;
for (; l ; l = l->next)
GSList *l;
for (l = a->list; l ; l = l->next)
refresh(l->data);
}
void size (Area *a)
{
GSList *l;
if (a->resize) {
a->resize = 0;
for (l = a->list; l ; l = l->next)
size(l->data);
// resize can generate a redraw
if (a->_resize) {
a->_resize(a);
}
}
}
void set_redraw (Area *a)
{
a->redraw = 1;