Преглед изворни кода

White background for images with alpha

master
Bert пре 14 година
родитељ
комит
d982b06eed
4 измењених фајлова са 35 додато и 17 уклоњено
  1. +3
    -0
      image.c
  2. +13
    -1
      thumbs.c
  3. +15
    -15
      window.c
  4. +4
    -1
      window.h

+ 3
- 0
image.c Прегледај датотеку

@@ -210,6 +210,9 @@ void img_render(img_t *img, win_t *win) {
imlib_context_set_image(img->im); imlib_context_set_image(img->im);
else else
imlib_context_set_image(im_broken); imlib_context_set_image(im_broken);

if (imlib_image_has_alpha())
win_draw_rect(win, win->pm, dx, dy, dw, dh, True, 0, win->white);
imlib_context_set_drawable(win->pm); imlib_context_set_drawable(win->pm);
imlib_render_image_part_on_drawable_at_size(sx, sy, sw, sh, dx, dy, dw, dh); imlib_render_image_part_on_drawable_at_size(sx, sy, sw, sh, dx, dy, dw, dh);


+ 13
- 1
thumbs.c Прегледај датотеку

@@ -88,6 +88,8 @@ void tns_load(tns_t *tns, win_t *win, int n, const char *filename) {
t->pm = win_create_pixmap(win, t->w, t->h); t->pm = win_create_pixmap(win, t->w, t->h);
imlib_context_set_drawable(t->pm); imlib_context_set_drawable(t->pm);
imlib_context_set_anti_alias(1); imlib_context_set_anti_alias(1);
if (imlib_image_has_alpha())
win_draw_rect(win, t->pm, 0, 0, t->w, t->h, True, 0, win->white);
imlib_render_image_part_on_drawable_at_size(0, 0, w, h, imlib_render_image_part_on_drawable_at_size(0, 0, w, h,
0, 0, t->w, t->h); 0, 0, t->w, t->h);
tns->dirty = 1; tns->dirty = 1;
@@ -170,13 +172,23 @@ void tns_render(tns_t *tns, win_t *win) {


void tns_highlight(tns_t *tns, win_t *win, int n, Bool hl) { void tns_highlight(tns_t *tns, win_t *win, int n, Bool hl) {
thumb_t *t; thumb_t *t;
unsigned long col;


if (!tns || !win) if (!tns || !win)
return; return;


if (n >= 0 && n < tns->cnt) { if (n >= 0 && n < tns->cnt) {
t = &tns->thumbs[n]; t = &tns->thumbs[n];
win_draw_rect(win, t->x - 2, t->y - 2, t->w + 4, t->h + 4, hl); if (hl)
col = win->selcol;
else if (win->fullscreen)
col = win->black;
else
col = win->bgcol;

win_draw_rect(win, win->pm, t->x - 2, t->y - 2, t->w + 4, t->h + 4,
False, 2, col);
} }


win_draw(win); win_draw(win);


+ 15
- 15
window.c Прегледај датотеку

@@ -52,7 +52,6 @@ void win_open(win_t *win) {
win_env_t *e; win_env_t *e;
XClassHint classhint; XClassHint classhint;
XColor col; XColor col;
XGCValues gcval;
char none_data[] = {0, 0, 0, 0, 0, 0, 0, 0}; char none_data[] = {0, 0, 0, 0, 0, 0, 0, 0};
Pixmap none; Pixmap none;
int gmask; int gmask;
@@ -71,6 +70,9 @@ void win_open(win_t *win) {
e->cmap = DefaultColormap(e->dpy, e->scr); e->cmap = DefaultColormap(e->dpy, e->scr);
e->depth = DefaultDepth(e->dpy, e->scr); e->depth = DefaultDepth(e->dpy, e->scr);


win->black = BlackPixel(e->dpy, e->scr);
win->white = WhitePixel(e->dpy, e->scr);

if (XAllocNamedColor(e->dpy, DefaultColormap(e->dpy, e->scr), BG_COLOR, if (XAllocNamedColor(e->dpy, DefaultColormap(e->dpy, e->scr), BG_COLOR,
&col, &col)) &col, &col))
win->bgcol = col.pixel; win->bgcol = col.pixel;
@@ -127,8 +129,7 @@ void win_open(win_t *win) {
none = XCreateBitmapFromData(e->dpy, win->xwin, none_data, 8, 8); none = XCreateBitmapFromData(e->dpy, win->xwin, none_data, 8, 8);
cnone = XCreatePixmapCursor(e->dpy, none, none, &col, &col, 0, 0); cnone = XCreatePixmapCursor(e->dpy, none, none, &col, &col, 0, 0);


gcval.line_width = 2; gc = XCreateGC(e->dpy, win->xwin, 0, None);
gc = XCreateGC(e->dpy, win->xwin, GCLineWidth, &gcval);


win_set_title(win, "sxiv"); win_set_title(win, "sxiv");


@@ -251,8 +252,8 @@ void win_clear(win_t *win) {
return; return;


e = &win->env; e = &win->env;
gcval.foreground = win->fullscreen ? BlackPixel(e->dpy, e->scr) : gcval.foreground = win->fullscreen ? win->black : win->bgcol;
win->bgcol;
if (win->pm) if (win->pm)
XFreePixmap(e->dpy, win->pm); XFreePixmap(e->dpy, win->pm);
win->pm = XCreatePixmap(e->dpy, win->xwin, e->scrw, e->scrh, e->depth); win->pm = XCreatePixmap(e->dpy, win->xwin, e->scrw, e->scrh, e->depth);
@@ -266,22 +267,21 @@ void win_draw_pixmap(win_t *win, Pixmap pm, int x, int y, int w, int h) {
XCopyArea(win->env.dpy, pm, win->pm, gc, 0, 0, w, h, x, y); XCopyArea(win->env.dpy, pm, win->pm, gc, 0, 0, w, h, x, y);
} }


void win_draw_rect(win_t *win, int x, int y, int w, int h, Bool sel) { void win_draw_rect(win_t *win, Pixmap pm, int x, int y, int w, int h,
win_env_t *e; Bool fill, int lw, unsigned long col) {
XGCValues gcval; XGCValues gcval;


if (!win) if (!win || !pm)
return; return;


e = &win->env; gcval.line_width = lw;
gcval.foreground = col;
XChangeGC(win->env.dpy, gc, GCForeground | GCLineWidth, &gcval);


if (sel) if (fill)
gcval.foreground = win->selcol; XFillRectangle(win->env.dpy, pm, gc, x, y, w, h);
else else
gcval.foreground = win->fullscreen ? BlackPixel(e->dpy, e->scr) : XDrawRectangle(win->env.dpy, pm, gc, x, y, w, h);
win->bgcol;
XChangeGC(e->dpy, gc, GCForeground, &gcval);
XDrawRectangle(e->dpy, win->pm, gc, x, y, w, h);
} }


void win_draw(win_t *win) { void win_draw(win_t *win) {


+ 4
- 1
window.h Прегледај датотеку

@@ -43,6 +43,8 @@ typedef struct {
Window xwin; Window xwin;
win_env_t env; win_env_t env;


unsigned long black;
unsigned long white;
unsigned long bgcol; unsigned long bgcol;
unsigned long selcol; unsigned long selcol;
Pixmap pm; Pixmap pm;
@@ -71,7 +73,8 @@ void win_free_pixmap(win_t*, Pixmap);


void win_clear(win_t*); void win_clear(win_t*);
void win_draw_pixmap(win_t*, Pixmap, int, int, int, int); void win_draw_pixmap(win_t*, Pixmap, int, int, int, int);
void win_draw_rect(win_t*, int, int, int, int, Bool); void win_draw_rect(win_t*, Pixmap, int, int, int, int, Bool, int,
unsigned long);
void win_draw(win_t*); void win_draw(win_t*);


void win_set_title(win_t*, const char*); void win_set_title(win_t*, const char*);


||||||
x
 
000:0
Loading…
Откажи
Сачувај