From 70a3fd8ca932aba8f3046f83a1d63c76cda94714 Mon Sep 17 00:00:00 2001 From: Robert Timm Date: Mon, 19 Sep 2016 00:31:51 +0200 Subject: [PATCH] Adds default-zoom setting --- README.md | 1 + src/setting.c | 13 +++++++++++++ 2 files changed, 14 insertions(+) diff --git a/README.md b/README.md index c80bd9a..c79c9a6 100644 --- a/README.md +++ b/README.md @@ -85,6 +85,7 @@ project directory. instances and to work also if the page was reloaded or changed like the marks in vim) - [x] zooming + - [x] default zoom - [ ] yanking - [x] keymapping - [ ] URL handler diff --git a/src/setting.c b/src/setting.c index a3ad8a6..373a9db 100644 --- a/src/setting.c +++ b/src/setting.c @@ -49,6 +49,7 @@ static void setting_print(Client *c, Setting *s); static void setting_free(Setting *s); static int cookie_accept(Client *c, const char *name, DataType type, void *value, void *data); +static int default_zoom(Client *c, const char *name, DataType type, void *value, void *data); static int fullscreen(Client *c, const char *name, DataType type, void *value, void *data); static int input_autohide(Client *c, const char *name, DataType type, void *value, void *data); static int internal(Client *c, const char *name, DataType type, void *value, void *data); @@ -137,6 +138,8 @@ void setting_init(Client *c) setting_add(c, "timeoutlen", TYPE_INTEGER, &i, internal, 0, &c->map.timeoutlen); setting_add(c, "input-autohide", TYPE_BOOLEAN, &off, input_autohide, 0, &c->config.input_autohide); setting_add(c, "fullscreen", TYPE_BOOLEAN, &off, fullscreen, 0, NULL); + i = 100; + setting_add(c, "default-zoom", TYPE_INTEGER, &i, default_zoom, 0, NULL); /* initialize the shortcuts and set the default shortcuts */ shortcut_init(c); @@ -464,6 +467,16 @@ static int cookie_accept(Client *c, const char *name, DataType type, void *value return CMD_SUCCESS; } +static int default_zoom(Client *c, const char *name, DataType type, void *value, void *data) +{ + float zoom = (float)*(int*)value / 100.0; + + webkit_settings_set_zoom_text_only(webkit_web_view_get_settings(c->webview), FALSE); + webkit_web_view_set_zoom_level(c->webview, zoom); + + return CMD_SUCCESS; +} + static int fullscreen(Client *c, const char *name, DataType type, void *value, void *data) { if (*(gboolean*)value) { -- 2.20.1