diff options
author | Pavel Grunt <pgrunt@redhat.com> | 2015-05-26 14:49:56 +0200 |
---|---|---|
committer | Pavel Grunt <pgrunt@redhat.com> | 2015-07-29 17:10:35 +0200 |
commit | 0d81ec2ef8a69fbe93de15d6125ae40d3b2bd7be (patch) | |
tree | 2415cc0881c863c97f2eaffbd4a534e7a7bf0e55 | |
parent | ae7ce62f1b64b716eb0fda937c673693db7922f3 (diff) | |
download | virt-viewer-0d81ec2ef8a69fbe93de15d6125ae40d3b2bd7be.tar.gz virt-viewer-0d81ec2ef8a69fbe93de15d6125ae40d3b2bd7be.tar.xz virt-viewer-0d81ec2ef8a69fbe93de15d6125ae40d3b2bd7be.zip |
virt-viewer-window: Change zoom with respect to real zoom
The zoom can be changed by resizing the window (VNC / Spice without
the agent). It is necessary to recalculate the zoom level before
changing it, otherwise zoom operations will not work correctly.
Resolves:
https://bugs.freedesktop.org/show_bug.cgi?id=90582
-rw-r--r-- | src/virt-viewer-window.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/src/virt-viewer-window.c b/src/virt-viewer-window.c index baf565d..e067162 100644 --- a/src/virt-viewer-window.c +++ b/src/virt-viewer-window.c @@ -368,19 +368,32 @@ virt_viewer_window_desktop_resize(VirtViewerDisplay *display G_GNUC_UNUSED, virt_viewer_window_queue_resize(self); } +static gint +virt_viewer_window_get_real_zoom_level(VirtViewerWindow *self) +{ + GtkAllocation allocation; + guint width, height; + + gtk_widget_get_allocation(GTK_WIDGET(self->priv->display), &allocation); + virt_viewer_display_get_desktop_size(self->priv->display, &width, &height); + + return round((double) NORMAL_ZOOM_LEVEL * allocation.width / width); +} G_MODULE_EXPORT void virt_viewer_window_menu_view_zoom_out(GtkWidget *menu G_GNUC_UNUSED, VirtViewerWindow *self) { - virt_viewer_window_set_zoom_level(self, self->priv->zoomlevel - ZOOM_STEP); + virt_viewer_window_set_zoom_level(self, + virt_viewer_window_get_real_zoom_level(self) - ZOOM_STEP); } G_MODULE_EXPORT void virt_viewer_window_menu_view_zoom_in(GtkWidget *menu G_GNUC_UNUSED, VirtViewerWindow *self) { - virt_viewer_window_set_zoom_level(self, self->priv->zoomlevel + ZOOM_STEP); + virt_viewer_window_set_zoom_level(self, + virt_viewer_window_get_real_zoom_level(self) + ZOOM_STEP); } G_MODULE_EXPORT void @@ -1397,7 +1410,8 @@ virt_viewer_window_set_zoom_level(VirtViewerWindow *self, gint zoom_level) priv->zoomlevel = min_zoom; } - if (priv->zoomlevel == virt_viewer_display_get_zoom_level(priv->display)) { + if (priv->zoomlevel == virt_viewer_display_get_zoom_level(priv->display) && + priv->zoomlevel == virt_viewer_window_get_real_zoom_level(self)) { g_debug("Zoom level not changed, using: %d", priv->zoomlevel); return; } |