screenshot: Hide cursor while magnifier is active
As with the screen recorder, the magnifier already adds its own copy of the system cursor, so we should not add it again. Just as in the screen recorder case, we don't address the case where the cursor should not be included in the screenshot, but the magnifier adds it anyway. https://bugzilla.gnome.org/show_bug.cgi?id=700488
This commit is contained in:
parent
c7eed59562
commit
12c2939b64
@ -15,6 +15,9 @@
|
|||||||
#include "shell-global.h"
|
#include "shell-global.h"
|
||||||
#include "shell-screenshot.h"
|
#include "shell-screenshot.h"
|
||||||
|
|
||||||
|
#define A11Y_APPS_SCHEMA "org.gnome.desktop.a11y.applications"
|
||||||
|
#define MAGNIFIER_ACTIVE_KEY "screen-magnifier-enabled"
|
||||||
|
|
||||||
struct _ShellScreenshotClass
|
struct _ShellScreenshotClass
|
||||||
{
|
{
|
||||||
GObjectClass parent_class;
|
GObjectClass parent_class;
|
||||||
@ -304,6 +307,7 @@ grab_screenshot (ClutterActor *stage,
|
|||||||
MetaScreen *screen = shell_global_get_screen (screenshot_data->screenshot->global);
|
MetaScreen *screen = shell_global_get_screen (screenshot_data->screenshot->global);
|
||||||
int width, height;
|
int width, height;
|
||||||
GSimpleAsyncResult *result;
|
GSimpleAsyncResult *result;
|
||||||
|
GSettings *settings;
|
||||||
|
|
||||||
meta_screen_get_size (screen, &width, &height);
|
meta_screen_get_size (screen, &width, &height);
|
||||||
|
|
||||||
@ -352,8 +356,11 @@ grab_screenshot (ClutterActor *stage,
|
|||||||
screenshot_data->screenshot_area.width = width;
|
screenshot_data->screenshot_area.width = width;
|
||||||
screenshot_data->screenshot_area.height = height;
|
screenshot_data->screenshot_area.height = height;
|
||||||
|
|
||||||
if (screenshot_data->include_cursor)
|
settings = g_settings_new (A11Y_APPS_SCHEMA);
|
||||||
|
if (screenshot_data->include_cursor &&
|
||||||
|
!g_settings_get_boolean (settings, MAGNIFIER_ACTIVE_KEY))
|
||||||
_draw_cursor_image (screenshot_data->image, screenshot_data->screenshot_area);
|
_draw_cursor_image (screenshot_data->image, screenshot_data->screenshot_area);
|
||||||
|
g_object_unref (settings);
|
||||||
|
|
||||||
g_signal_handlers_disconnect_by_func (stage, (void *)grab_screenshot, (gpointer)screenshot_data);
|
g_signal_handlers_disconnect_by_func (stage, (void *)grab_screenshot, (gpointer)screenshot_data);
|
||||||
|
|
||||||
@ -476,6 +483,7 @@ shell_screenshot_screenshot_window (ShellScreenshot *screenshot,
|
|||||||
ShellScreenshotCallback callback)
|
ShellScreenshotCallback callback)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *result;
|
GSimpleAsyncResult *result;
|
||||||
|
GSettings *settings;
|
||||||
|
|
||||||
_screenshot_data *screenshot_data = g_new0 (_screenshot_data, 1);
|
_screenshot_data *screenshot_data = g_new0 (_screenshot_data, 1);
|
||||||
|
|
||||||
@ -533,8 +541,10 @@ shell_screenshot_screenshot_window (ShellScreenshot *screenshot,
|
|||||||
stex = META_SHAPED_TEXTURE (meta_window_actor_get_texture (META_WINDOW_ACTOR (window_actor)));
|
stex = META_SHAPED_TEXTURE (meta_window_actor_get_texture (META_WINDOW_ACTOR (window_actor)));
|
||||||
screenshot_data->image = meta_shaped_texture_get_image (stex, &clip);
|
screenshot_data->image = meta_shaped_texture_get_image (stex, &clip);
|
||||||
|
|
||||||
if (include_cursor)
|
settings = g_settings_new (A11Y_APPS_SCHEMA);
|
||||||
|
if (include_cursor && !g_settings_get_boolean (settings, MAGNIFIER_ACTIVE_KEY))
|
||||||
_draw_cursor_image (screenshot_data->image, screenshot_data->screenshot_area);
|
_draw_cursor_image (screenshot_data->image, screenshot_data->screenshot_area);
|
||||||
|
g_object_unref (settings);
|
||||||
|
|
||||||
result = g_simple_async_result_new (NULL, on_screenshot_written, (gpointer)screenshot_data, shell_screenshot_screenshot_window);
|
result = g_simple_async_result_new (NULL, on_screenshot_written, (gpointer)screenshot_data, shell_screenshot_screenshot_window);
|
||||||
g_simple_async_result_run_in_thread (result, write_screenshot_thread, G_PRIORITY_DEFAULT, NULL);
|
g_simple_async_result_run_in_thread (result, write_screenshot_thread, G_PRIORITY_DEFAULT, NULL);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user