Xinqi Bao's Git
projects
/
dwm.git
/ diff
summary
|
log
|
commit
|
diff
|
tree
raw
|
patch
|
inline
| side by side (parent:
3aabc08
)
continued, distinction of Draw and DDC is bad, needs to be merged
author
[email protected]
<unknown>
Sun, 18 Nov 2012 16:26:12 +0000
(17:26 +0100)
committer
[email protected]
<unknown>
Sun, 18 Nov 2012 16:26:12 +0000
(17:26 +0100)
draw.c
diff
|
blob
|
history
draw.h
diff
|
blob
|
history
diff --git
a/draw.c
b/draw.c
index
04e7f0d
..
df5aeec
100644
(file)
--- a/
draw.c
+++ b/
draw.c
@@
-5,12
+5,16
@@
#include "draw.h"
Draw *
#include "draw.h"
Draw *
-draw_create(Display *dpy, Window win, unsigned int w, unsigned int h) {
+draw_create(Display *dpy,
int screen,
Window win, unsigned int w, unsigned int h) {
Draw *draw = (Draw *)calloc(1, sizeof(Draw));
Draw *draw = (Draw *)calloc(1, sizeof(Draw));
+ draw->dpy = dpy;
+ draw->screen = screen;
+ draw->win = win;
draw->w = w;
draw->h = h;
draw->w = w;
draw->h = h;
- /* TODO: drawable creation */
- /* TODO: gc allocation */
+ draw->drawable = XCreatePixmap(dpy, win, w, h, DefaultDepth(dpy, screen));
+ draw->gc = XCreateGC(dpy, win, 0, NULL);
+ XSetLineAttributes(dpy, draw->gc, 1, LineSolid, CapButt, JoinMiter);
return draw;
}
return draw;
}
@@
-20,13
+24,14
@@
draw_resize(Draw *draw, unsigned int w, unsigned int h) {
return;
draw->w = w;
draw->h = h;
return;
draw->w = w;
draw->h = h;
- /* TODO: resize drawable */
+ XFreePixmap(draw->dpy, draw->drawable);
+ draw->drawable = XCreatePixmap(draw->dpy, draw->win, w, h, DefaultDepth(draw->dpy, draw->screen));
}
void
draw_free(Draw *draw) {
}
void
draw_free(Draw *draw) {
- /* TODO: deallocate DDCs */
- /* TODO: deallocate drawable */
+ XFreePixmap(draw->dpy, draw->drawable);
+ XFreeGC(draw->dpy, draw->gc);
free(draw);
}
free(draw);
}
diff --git
a/draw.h
b/draw.h
index
9aec43d
..
95242ea
100644
(file)
--- a/
draw.h
+++ b/
draw.h
@@
-7,6
+7,8
@@
typedef struct _XDraw Draw;
struct _XDraw {
unsigned int w, h;
Display *dpy;
struct _XDraw {
unsigned int w, h;
Display *dpy;
+ int screen;
+ Window win;
Drawable drawable;
GC gc;
DDC *dc;
Drawable drawable;
GC gc;
DDC *dc;
@@
-46,7
+48,7
@@
typedef struct {
} TextExtents;
/* Drawable abstraction */
} TextExtents;
/* Drawable abstraction */
-Draw *draw_create(Display *dpy, Window win, unsigned int w, unsigned int h);
+Draw *draw_create(Display *dpy,
int screen,
Window win, unsigned int w, unsigned int h);
void draw_resize(Draw *draw, unsigned int w, unsigned int h);
void draw_free(Draw *draw);
void draw_resize(Draw *draw, unsigned int w, unsigned int h);
void draw_free(Draw *draw);