mirror of
https://github.com/swaywm/sway.git
synced 2025-11-02 09:01:40 -05:00
Implement borders
Implements rendering of borders. Title text is still to do. Implements the following configuration directives: * client.focused * client.focused_inactive * client.unfocused * client.urgent * border * default_border
This commit is contained in:
parent
b84dfa794c
commit
e67f354333
15 changed files with 447 additions and 74 deletions
|
|
@ -204,11 +204,11 @@ struct bar_config {
|
|||
};
|
||||
|
||||
struct border_colors {
|
||||
uint32_t border;
|
||||
uint32_t background;
|
||||
uint32_t text;
|
||||
uint32_t indicator;
|
||||
uint32_t child_border;
|
||||
float border[4];
|
||||
float background[4];
|
||||
float text[4];
|
||||
float indicator[4];
|
||||
float child_border[4];
|
||||
};
|
||||
|
||||
enum edge_border_types {
|
||||
|
|
@ -338,7 +338,7 @@ struct sway_config {
|
|||
struct border_colors unfocused;
|
||||
struct border_colors urgent;
|
||||
struct border_colors placeholder;
|
||||
uint32_t background;
|
||||
float background[4];
|
||||
} border_colors;
|
||||
|
||||
// floating view
|
||||
|
|
|
|||
|
|
@ -72,8 +72,8 @@ struct sway_container {
|
|||
// For C_ROOT, this has no meaning
|
||||
// For C_OUTPUT, this is the output position in layout coordinates
|
||||
// For other types, this is the position in output-local coordinates
|
||||
// Includes borders
|
||||
double x, y;
|
||||
// does not include borders or gaps.
|
||||
double width, height;
|
||||
double saved_width, saved_height;
|
||||
|
||||
|
|
|
|||
|
|
@ -41,9 +41,16 @@ struct sway_view {
|
|||
|
||||
struct sway_container *swayc; // NULL for unmapped views
|
||||
struct wlr_surface *surface; // NULL for unmapped views
|
||||
|
||||
// Geometry of the view itself (excludes borders)
|
||||
double x, y;
|
||||
int width, height;
|
||||
|
||||
bool is_fullscreen;
|
||||
|
||||
enum sway_container_border border;
|
||||
int border_thickness;
|
||||
|
||||
union {
|
||||
struct wlr_xdg_surface_v6 *wlr_xdg_surface_v6;
|
||||
struct wlr_xwayland_surface *wlr_xwayland_surface;
|
||||
|
|
@ -160,6 +167,8 @@ const char *view_get_instance(struct sway_view *view);
|
|||
void view_configure(struct sway_view *view, double ox, double oy, int width,
|
||||
int height);
|
||||
|
||||
void view_autoconfigure(struct sway_view *view);
|
||||
|
||||
void view_set_activated(struct sway_view *view, bool activated);
|
||||
|
||||
void view_set_fullscreen_raw(struct sway_view *view, bool fullscreen);
|
||||
|
|
@ -184,8 +193,6 @@ void view_map(struct sway_view *view, struct wlr_surface *wlr_surface);
|
|||
|
||||
void view_unmap(struct sway_view *view);
|
||||
|
||||
void view_update_position(struct sway_view *view, double ox, double oy);
|
||||
|
||||
void view_update_size(struct sway_view *view, int width, int height);
|
||||
|
||||
void view_child_init(struct sway_view_child *child,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue