awesome/common/draw.h

233 lines
5.6 KiB
C
Raw Normal View History

/*
2007-09-12 14:29:51 +02:00
* draw.h - draw functions header
*
2008-01-02 16:59:43 +01:00
* Copyright © 2007-2008 Julien Danjou <julien@danjou.info>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
2007-09-12 14:29:51 +02:00
*/
2007-09-05 20:15:00 +02:00
2008-01-26 18:00:47 +01:00
#ifndef AWESOME_COMMON_DRAW_H
#define AWESOME_COMMON_DRAW_H
2007-09-05 20:15:00 +02:00
#include <cairo.h>
2008-03-21 16:50:17 +01:00
#include <pango/pangocairo.h>
2008-03-13 17:57:38 +01:00
2008-03-21 16:50:17 +01:00
#include <xcb/xcb.h>
#include "common/array.h"
#include "common/list.h"
#include "common/buffer.h"
typedef struct
{
/** Color name */
char *name;
uint32_t pixel;
uint16_t red;
uint16_t green;
uint16_t blue;
uint16_t alpha;
} xcolor_t;
2008-01-04 19:17:20 +01:00
typedef enum
{
AlignLeft = 0,
2008-01-04 19:17:20 +01:00
AlignRight,
AlignCenter,
2008-01-04 19:17:20 +01:00
AlignFlex,
AlignAuto
} alignment_t;
2008-01-03 15:57:07 +01:00
2008-03-14 09:37:25 +01:00
typedef struct area_t area_t;
struct area_t
{
/** Co-ords of upper left corner */
int16_t x;
int16_t y;
uint16_t width;
uint16_t height;
};
DO_ARRAY(area_t, area, DO_NOTHING);
#define AREA_LEFT(a) ((a).x)
#define AREA_TOP(a) ((a).y)
#define AREA_RIGHT(a) ((a).x + (a).width)
#define AREA_BOTTOM(a) ((a).y + (a).height)
2008-03-21 16:50:17 +01:00
static inline bool
2008-03-14 09:37:25 +01:00
area_intersect_area(area_t a, area_t b)
{
return (b.x < a.x + a.width
&& b.x + b.width > a.x
&& b.y < a.y + a.height
&& b.y + b.height > a.y);
}
2008-03-14 09:37:25 +01:00
static inline area_t
area_get_intersect_area(area_t a, area_t b)
{
2008-03-14 09:37:25 +01:00
area_t g;
g.x = MAX(a.x, b.x);
g.y = MAX(a.y, b.y);
g.width = MIN(a.x + a.width, b.x + b.width) - g.x;
g.height = MIN(a.y + a.height, b.y + b.height) - g.y;
return g;
}
typedef struct
{
PangoFontDescription *desc;
int height;
} font_t;
2007-12-27 17:12:49 +01:00
typedef struct
{
2008-03-21 16:50:17 +01:00
xcb_connection_t *connection;
xcb_pixmap_t pixmap;
2008-03-21 16:50:17 +01:00
xcb_visualtype_t *visual;
int width;
int height;
int phys_screen;
int depth;
2008-01-31 18:18:15 +01:00
cairo_t *cr;
cairo_surface_t *surface;
PangoLayout *layout;
xcolor_t fg;
xcolor_t bg;
} draw_context_t;
typedef struct
{
void *data;
size_t width;
size_t height;
} draw_image_t;
draw_context_t *draw_context_new(xcb_connection_t *, int, int, int, xcb_drawable_t, xcolor_t, xcolor_t);
2008-06-26 16:47:17 +02:00
/** Delete a draw context.
* \param ctx The draw_context_t to delete.
*/
static inline void
draw_context_delete(draw_context_t **ctx)
{
if(*ctx)
{
if((*ctx)->layout)
g_object_unref((*ctx)->layout);
if((*ctx)->surface)
cairo_surface_destroy((*ctx)->surface);
if((*ctx)->cr)
cairo_destroy((*ctx)->cr);
p_delete(ctx);
}
}
2008-01-31 18:18:15 +01:00
font_t *draw_font_new(xcb_connection_t *, int, const char *);
void draw_font_delete(font_t **);
char * draw_iso2utf8(const char *, size_t);
static inline bool
a_iso2utf8(char **dest, const char *str, ssize_t len)
{
char *utf8;
if((utf8 = draw_iso2utf8(str, len)))
{
*dest = utf8;
return true;
}
*dest = a_strdup(str);
return false;
}
typedef struct
{
xcb_connection_t *connection;
int phys_screen;
buffer_t text;
alignment_t align;
struct
{
int left, right;
} margin;
bool has_bg_color;
xcolor_t bg_color;
draw_image_t *bg_image;
alignment_t bg_align;
bool bg_resize;
struct
{
int offset;
xcolor_t color;
} shadow;
} draw_parser_data_t;
void draw_parser_data_init(draw_parser_data_t *);
void draw_parser_data_wipe(draw_parser_data_t *);
void draw_text(draw_context_t *, font_t *, area_t, const char *, draw_parser_data_t *);
void draw_rectangle(draw_context_t *, area_t, float, bool, xcolor_t);
void draw_rectangle_gradient(draw_context_t *, area_t, float, bool, area_t, xcolor_t *, xcolor_t *, xcolor_t *);
void draw_graph_setup(draw_context_t *);
void draw_graph(draw_context_t *, area_t, int *, int *, int, position_t, area_t, xcolor_t *, xcolor_t *, xcolor_t *);
void draw_graph_line(draw_context_t *, area_t, int *, int, position_t, area_t, xcolor_t *, xcolor_t *, xcolor_t *);
void draw_circle(draw_context_t *, int, int, int, bool, xcolor_t);
draw_image_t *draw_image_new(const char *);
void draw_image_delete(draw_image_t **);
void draw_image(draw_context_t *, int, int, int, draw_image_t *);
void draw_image_from_argb_data(draw_context_t *, int, int, int, int, int, unsigned char *);
void draw_rotate(draw_context_t *, xcb_drawable_t, xcb_drawable_t, int, int, int, int, double, int, int);
area_t draw_text_extents(xcb_connection_t *, int, font_t *, const char *, draw_parser_data_t *);
alignment_t draw_align_fromstr(const char *, ssize_t);
/** Wipe a color resources.
* \param color The color to wipe out.
*/
static inline void
xcolor_wipe(xcolor_t *color)
{
if(color)
{
p_delete(&color->name);
p_clear(color, 1);
}
}
static inline xcolor_t
xcolor_copy(xcolor_t *color)
{
xcolor_t c;
assert(color);
c = *color;
c.name = a_strdup(color->name);
return c;
}
bool xcolor_new(xcb_connection_t *, int, const char *, xcolor_t *);
2007-12-27 17:12:49 +01:00
void area_array_remove(area_array_t *, area_t);
2007-09-05 20:15:00 +02:00
#endif
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80