summaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2015-11-19 08:34:23 -0500
committerDrew DeVault <sir@cmpwn.com>2015-11-19 08:34:32 -0500
commit7ce149d75395766be4d7e549918f0d3457873b64 (patch)
treeb645729ea25c93aa6df2e34006f42704943d814b /main.c
parentea2826a8d84eba3332107b74b033a00dae6c4265 (diff)
downloadswaybg-7ce149d75395766be4d7e549918f0d3457873b64.tar.gz
swaybg-7ce149d75395766be4d7e549918f0d3457873b64.tar.bz2
Stretch image to fit output resolution
Diffstat (limited to 'main.c')
-rw-r--r--main.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/main.c b/main.c
index fd5e34c..080422e 100644
--- a/main.c
+++ b/main.c
@@ -50,19 +50,21 @@ int main(int argc, char **argv) {
}
cairo_surface_t *image = cairo_image_surface_create_from_png(argv[1]);
+ double width = cairo_image_surface_get_width(image);
+ double height = cairo_image_surface_get_height(image);
- do {
- for (i = 0; i < surfaces->length; ++i) {
- struct window *window = surfaces->items[i];
- if (window_prerender(window) && window->cairo) {
- cairo_set_source_surface(window->cairo, image, 0, 0);
- cairo_rectangle(window->cairo, 0, 0, window->width, window->height);
- cairo_fill(window->cairo);
+ for (i = 0; i < surfaces->length; ++i) {
+ struct window *window = surfaces->items[i];
+ if (window_prerender(window) && window->cairo) {
+ cairo_scale(window->cairo, window->width / width, window->height / height);
+ cairo_set_source_surface(window->cairo, image, 0, 0);
+ cairo_paint(window->cairo);
- window_render(window);
- }
+ window_render(window);
}
- } while (wl_display_dispatch(registry->display) != -1);
+ }
+
+ while (wl_display_dispatch(registry->display) != -1);
for (i = 0; i < surfaces->length; ++i) {
struct window *window = surfaces->items[i];