summaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2015-11-19 08:20:07 -0500
committerDrew DeVault <sir@cmpwn.com>2015-11-19 08:20:07 -0500
commitea2826a8d84eba3332107b74b033a00dae6c4265 (patch)
tree6d09b0d6c3a45f9e85ce4f283b64cbc9feac8f21 /main.c
parentecc8b780ce6a9ced056e65235bd8d634f7487382 (diff)
downloadswaybg-ea2826a8d84eba3332107b74b033a00dae6c4265.tar.gz
swaybg-ea2826a8d84eba3332107b74b033a00dae6c4265.tar.bz2
Basic image rendering for swaybg
Diffstat (limited to 'main.c')
-rw-r--r--main.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/main.c b/main.c
index 56fdc06..fd5e34c 100644
--- a/main.c
+++ b/main.c
@@ -28,6 +28,10 @@ int main(int argc, char **argv) {
surfaces = create_list();
registry = registry_poll();
+ if (argc < 2) {
+ sway_abort("Usage: swaybg path/to/file.png");
+ }
+
if (!registry->desktop_shell) {
sway_abort("swaybg requires the compositor to support the desktop-shell extension.");
}
@@ -45,19 +49,18 @@ int main(int argc, char **argv) {
list_add(surfaces, window);
}
- uint8_t r = 0, g = 0, b = 0;
+ cairo_surface_t *image = cairo_image_surface_create_from_png(argv[1]);
do {
for (i = 0; i < surfaces->length; ++i) {
struct window *window = surfaces->items[i];
if (window_prerender(window) && window->cairo) {
- cairo_set_source_rgb(window->cairo, r / 256.0, g / 256.0, b / 256.0);
+ cairo_set_source_surface(window->cairo, image, 0, 0);
cairo_rectangle(window->cairo, 0, 0, window->width, window->height);
cairo_fill(window->cairo);
window_render(window);
}
- r++; g += 2; b += 4;
}
} while (wl_display_dispatch(registry->display) != -1);