[swindow] Add border manipulation function
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
7f284ba15a
commit
f42f75468c
|
@ -24,15 +24,16 @@
|
|||
|
||||
#include "common/swindow.h"
|
||||
|
||||
/** Create a simple window
|
||||
* \param conn Connection ref
|
||||
* \param phys_screen physical screen id
|
||||
* \param x x coordinate
|
||||
* \param y y coordinate
|
||||
* \param w width
|
||||
* \param h height
|
||||
* \param border_width window's border width
|
||||
* \return pointer to a simple_window_t
|
||||
/** Create a simple window.
|
||||
* \param conn Connection ref.
|
||||
* \param phys_screen Physical screen number.
|
||||
* \param x x coordinate.
|
||||
* \param y y coordinate.
|
||||
* \param w Width.
|
||||
* \param h Height.
|
||||
* \param border_width Window border width.
|
||||
* \return A pointer to a newly allocated simple window, which must be deleted
|
||||
* with simplewindow_delete().
|
||||
*/
|
||||
simple_window_t *
|
||||
simplewindow_new(xcb_connection_t *conn, int phys_screen, int x, int y,
|
||||
|
@ -76,13 +77,13 @@ simplewindow_new(xcb_connection_t *conn, int phys_screen, int x, int y,
|
|||
sw->gc = xcb_generate_id(sw->connection);
|
||||
xcb_create_gc(sw->connection, sw->gc, gc_draw, gc_mask, gc_values);
|
||||
|
||||
sw->border = border_width;
|
||||
sw->border_width = border_width;
|
||||
|
||||
return sw;
|
||||
}
|
||||
|
||||
/** Destroy a simple window and all its resources
|
||||
* \param sw the simple_window_t to delete
|
||||
/** Destroy a simple window and all its resources.
|
||||
* \param sw The simple_window_t to delete.
|
||||
*/
|
||||
void
|
||||
simplewindow_delete(simple_window_t **sw)
|
||||
|
@ -93,10 +94,10 @@ simplewindow_delete(simple_window_t **sw)
|
|||
p_delete(sw);
|
||||
}
|
||||
|
||||
/** Move a simple window
|
||||
* \param sw the simple_window_t to move
|
||||
* \param x x coordinate
|
||||
* \param y y coordinate
|
||||
/** Move a simple window.
|
||||
* \param sw The simple window to move.
|
||||
* \param x New x coordinate.
|
||||
* \param y New y coordinate.
|
||||
*/
|
||||
void
|
||||
simplewindow_move(simple_window_t *sw, int x, int y)
|
||||
|
@ -110,10 +111,10 @@ simplewindow_move(simple_window_t *sw, int x, int y)
|
|||
move_win_vals);
|
||||
}
|
||||
|
||||
/** Resize a simple window
|
||||
* \param sw the simple_window_t to resize
|
||||
* \param w new width
|
||||
* \param h new height
|
||||
/** Resize a simple window.
|
||||
* \param sw The simple_window_t to resize.
|
||||
* \param w New width.
|
||||
* \param h New height.
|
||||
*/
|
||||
void
|
||||
simplewindow_resize(simple_window_t *sw, unsigned int w, unsigned int h)
|
||||
|
|
|
@ -24,16 +24,23 @@
|
|||
|
||||
#include "common/draw.h"
|
||||
|
||||
/** A simple window */
|
||||
/** A simple window. */
|
||||
typedef struct simple_window_t
|
||||
{
|
||||
/** The display connection. */
|
||||
xcb_connection_t *connection;
|
||||
/** The physical screen number the window is on. */
|
||||
int phys_screen;
|
||||
/** The window object. */
|
||||
xcb_window_t window;
|
||||
/** The drawable copied to the window object. */
|
||||
xcb_drawable_t drawable;
|
||||
/** The graphic context. */
|
||||
xcb_gcontext_t gc;
|
||||
/** The window geometry. */
|
||||
area_t geometry;
|
||||
int border;
|
||||
/** The window border width */
|
||||
int border_width;
|
||||
} simple_window_t;
|
||||
|
||||
simple_window_t * simplewindow_new(xcb_connection_t *, int, int, int, unsigned int, unsigned int, unsigned int);
|
||||
|
@ -41,6 +48,13 @@ void simplewindow_delete(simple_window_t **);
|
|||
void simplewindow_move(simple_window_t *, int, int);
|
||||
void simplewindow_resize(simple_window_t *, unsigned int, unsigned int);
|
||||
|
||||
/** Move and resize a window in one call.
|
||||
* \param sw The simple window to move and resize.
|
||||
* \param x The new x coordinate.
|
||||
* \param y The new y coordinate.
|
||||
* \param w The new width.
|
||||
* \param h The new height.
|
||||
*/
|
||||
static inline void
|
||||
simplewindow_move_resize(simple_window_t *sw, int x, int y,
|
||||
unsigned int w, unsigned int h)
|
||||
|
@ -49,9 +63,8 @@ simplewindow_move_resize(simple_window_t *sw, int x, int y,
|
|||
simplewindow_resize(sw, w, h);
|
||||
}
|
||||
|
||||
/** Refresh the window content
|
||||
* \param sw the simple_window_t to refresh
|
||||
* \param phys_screen physical screen id
|
||||
/** Refresh the window content by copying its drawable data to its window.
|
||||
* \param sw The simple window to refresh.
|
||||
*/
|
||||
static inline void
|
||||
simplewindow_refresh_drawable(simple_window_t *sw)
|
||||
|
@ -62,5 +75,28 @@ simplewindow_refresh_drawable(simple_window_t *sw)
|
|||
sw->geometry.height);
|
||||
}
|
||||
|
||||
/** Set a simple window border width.
|
||||
* \param sw The simple window to change border width.
|
||||
* \param border_width The border width in pixel.
|
||||
*/
|
||||
static inline void
|
||||
simplewindow_border_width_set(simple_window_t *sw, uint32_t border_width)
|
||||
{
|
||||
xcb_configure_window(sw->connection, sw->window, XCB_CONFIG_WINDOW_BORDER_WIDTH,
|
||||
&border_width);
|
||||
sw->border_width = border_width;
|
||||
}
|
||||
|
||||
/** Set a simple window border color.
|
||||
* \param sw The simple window to change border width.
|
||||
* \param border_color The border color.
|
||||
*/
|
||||
static inline void
|
||||
simplewindow_border_color_set(simple_window_t *sw, xcolor_t *color)
|
||||
{
|
||||
xcb_change_window_attributes(sw->connection, sw->window,
|
||||
XCB_CW_BORDER_PIXEL, &color->pixel);
|
||||
}
|
||||
|
||||
#endif
|
||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
||||
|
|
Loading…
Reference in New Issue