diff options
author | Drew DeVault <sir@cmpwn.com> | 2017-02-22 02:26:19 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-22 02:26:19 -0500 |
commit | 7f58ea5ec23ffded76a147a243aede34405e417b (patch) | |
tree | 5b8222416cf425c2c2dee123a13dd774fd2a368c /include/swaylock/swaylock.h | |
parent | f68d2fb33c433d13def0921db561eb23d400683c (diff) | |
parent | 692768230385d7d63938d7a40e9253c0f028d1cb (diff) | |
download | sway-7f58ea5ec23ffded76a147a243aede34405e417b.tar.xz |
Merge pull request #1081 from 4e554c4c/swaylock_colors
Feature for #1078: Configurable swaylock colors
Diffstat (limited to 'include/swaylock/swaylock.h')
-rw-r--r-- | include/swaylock/swaylock.h | 68 |
1 files changed, 47 insertions, 21 deletions
diff --git a/include/swaylock/swaylock.h b/include/swaylock/swaylock.h index 1cf66e89..06533108 100644 --- a/include/swaylock/swaylock.h +++ b/include/swaylock/swaylock.h @@ -4,34 +4,60 @@ #include "client/cairo.h" enum scaling_mode { - SCALING_MODE_STRETCH, - SCALING_MODE_FILL, - SCALING_MODE_FIT, - SCALING_MODE_CENTER, - SCALING_MODE_TILE, + SCALING_MODE_STRETCH, + SCALING_MODE_FILL, + SCALING_MODE_FIT, + SCALING_MODE_CENTER, + SCALING_MODE_TILE, }; enum auth_state { - AUTH_STATE_IDLE, - AUTH_STATE_INPUT, - AUTH_STATE_BACKSPACE, - AUTH_STATE_VALIDATING, - AUTH_STATE_INVALID, + AUTH_STATE_IDLE, + AUTH_STATE_INPUT, + AUTH_STATE_BACKSPACE, + AUTH_STATE_VALIDATING, + AUTH_STATE_INVALID, +}; + +enum line_source { + LINE_SOURCE_DEFAULT, + LINE_SOURCE_RING, + LINE_SOURCE_INSIDE, }; struct render_data { - list_t *surfaces; - // Output specific images - cairo_surface_t **images; - // OR one image for all outputs: - cairo_surface_t *image; - int num_images; - int color_set; - uint32_t color; - enum scaling_mode scaling_mode; - enum auth_state auth_state; + list_t *surfaces; + // Output specific images + cairo_surface_t **images; + // OR one image for all outputs: + cairo_surface_t *image; + int num_images; + int color_set; + uint32_t color; + enum scaling_mode scaling_mode; + enum auth_state auth_state; +}; + +struct lock_colors { + uint32_t inner_ring; + uint32_t outer_ring; +}; + +struct lock_config { + char *font; + + struct { + uint32_t text; + uint32_t line; + uint32_t separator; + uint32_t input_cursor; + uint32_t backspace_cursor; + struct lock_colors normal; + struct lock_colors validating; + struct lock_colors invalid; + } colors; }; -void render(struct render_data* render_data); +void render(struct render_data* render_data, struct lock_config *config); #endif |