Remove the hacks for asking the X server for screenshots and use gtk.Widget.get_snapshot() instead.
This commit is contained in:
parent
1fd893f86e
commit
44cabc891b
@ -56,9 +56,7 @@ _sugarext_la_SOURCES = \
|
|||||||
sugar-key-grabber.c \
|
sugar-key-grabber.c \
|
||||||
sugar-key-grabber.h \
|
sugar-key-grabber.h \
|
||||||
sugar-menu.h \
|
sugar-menu.h \
|
||||||
sugar-menu.c \
|
sugar-menu.c
|
||||||
sugar-preview.h \
|
|
||||||
sugar-preview.c
|
|
||||||
|
|
||||||
BUILT_SOURCES = \
|
BUILT_SOURCES = \
|
||||||
_sugarext.c \
|
_sugarext.c \
|
||||||
|
@ -29,13 +29,6 @@
|
|||||||
(gtype-id "SUGAR_TYPE_GRID")
|
(gtype-id "SUGAR_TYPE_GRID")
|
||||||
)
|
)
|
||||||
|
|
||||||
(define-object Preview
|
|
||||||
(in-module "Sugar")
|
|
||||||
(parent "GObject")
|
|
||||||
(c-name "SugarPreview")
|
|
||||||
(gtype-id "SUGAR_TYPE_PREVIEW")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-object IconEntry
|
(define-object IconEntry
|
||||||
(in-module "Sexy")
|
(in-module "Sexy")
|
||||||
(parent "GtkEntry")
|
(parent "GtkEntry")
|
||||||
@ -248,44 +241,6 @@
|
|||||||
(return-type "none")
|
(return-type "none")
|
||||||
)
|
)
|
||||||
|
|
||||||
;; From sugar-preview.h
|
|
||||||
|
|
||||||
(define-function sugar_preview_get_type
|
|
||||||
(c-name "sugar_preview_get_type")
|
|
||||||
(return-type "GType")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method take_screenshot
|
|
||||||
(of-object "SugarPreview")
|
|
||||||
(c-name "sugar_preview_take_screenshot")
|
|
||||||
(return-type "none")
|
|
||||||
(parameters
|
|
||||||
'("GtkWidget" "widget")
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method set_size
|
|
||||||
(of-object "SugarPreview")
|
|
||||||
(c-name "sugar_preview_set_size")
|
|
||||||
(return-type "none")
|
|
||||||
(parameters
|
|
||||||
'("int" "width")
|
|
||||||
'("int" "height")
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method clear
|
|
||||||
(of-object "SugarPreview")
|
|
||||||
(c-name "sugar_preview_clear")
|
|
||||||
(return-type "none")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method get_pixbuf
|
|
||||||
(of-object "SugarPreview")
|
|
||||||
(c-name "sugar_preview_get_pixbuf")
|
|
||||||
(return-type "GdkPixbuf*")
|
|
||||||
)
|
|
||||||
|
|
||||||
;; From eggsmclient.h
|
;; From eggsmclient.h
|
||||||
|
|
||||||
(define-function egg_sm_client_get_type
|
(define-function egg_sm_client_get_type
|
||||||
|
@ -8,7 +8,6 @@ headers
|
|||||||
#include "sugar-grid.h"
|
#include "sugar-grid.h"
|
||||||
#include "sugar-key-grabber.h"
|
#include "sugar-key-grabber.h"
|
||||||
#include "sugar-menu.h"
|
#include "sugar-menu.h"
|
||||||
#include "sugar-preview.h"
|
|
||||||
#include "sexy-icon-entry.h"
|
#include "sexy-icon-entry.h"
|
||||||
#include "gsm-session.h"
|
#include "gsm-session.h"
|
||||||
#include "gsm-xsmp.h"
|
#include "gsm-xsmp.h"
|
||||||
|
@ -469,20 +469,12 @@ class Activity(Window, gtk.Container):
|
|||||||
self.connect('realize', self.__realize_cb)
|
self.connect('realize', self.__realize_cb)
|
||||||
self.connect('delete-event', self.__delete_event_cb)
|
self.connect('delete-event', self.__delete_event_cb)
|
||||||
|
|
||||||
# watch visibility-notify-events to know when we can safely
|
|
||||||
# take a screenshot of the activity
|
|
||||||
self.add_events(gtk.gdk.VISIBILITY_NOTIFY_MASK)
|
|
||||||
self.connect('visibility-notify-event',
|
|
||||||
self.__visibility_notify_event_cb)
|
|
||||||
self._fully_obscured = True
|
|
||||||
|
|
||||||
self._active = False
|
self._active = False
|
||||||
self._activity_id = handle.activity_id
|
self._activity_id = handle.activity_id
|
||||||
self._pservice = presenceservice.get_instance()
|
self._pservice = presenceservice.get_instance()
|
||||||
self.shared_activity = None
|
self.shared_activity = None
|
||||||
self._share_id = None
|
self._share_id = None
|
||||||
self._join_id = None
|
self._join_id = None
|
||||||
self._preview = _sugarext.Preview()
|
|
||||||
self._updating_jobject = False
|
self._updating_jobject = False
|
||||||
self._closing = False
|
self._closing = False
|
||||||
self._quit_requested = False
|
self._quit_requested = False
|
||||||
@ -721,10 +713,15 @@ class Activity(Window, gtk.Container):
|
|||||||
self._jobject = None
|
self._jobject = None
|
||||||
|
|
||||||
def _get_preview(self):
|
def _get_preview(self):
|
||||||
pixbuf = self._preview.get_pixbuf()
|
|
||||||
if pixbuf is None:
|
|
||||||
return None
|
|
||||||
|
|
||||||
|
if self.canvas is None or not hasattr(self.canvas, 'get_snapshot'):
|
||||||
|
return None
|
||||||
|
pixmap = self.canvas.get_snapshot((-1, -1, 0, 0))
|
||||||
|
|
||||||
|
width, height = pixmap.get_size()
|
||||||
|
pixbuf = gtk.gdk.Pixbuf(gtk.gdk.COLORSPACE_RGB, 0, 8, width, height)
|
||||||
|
pixbuf = pixbuf.get_from_drawable(pixmap, pixmap.get_colormap(),
|
||||||
|
0, 0, 0, 0, width, height)
|
||||||
pixbuf = pixbuf.scale_simple(style.zoom(300), style.zoom(225),
|
pixbuf = pixbuf.scale_simple(style.zoom(300), style.zoom(225),
|
||||||
gtk.gdk.INTERP_BILINEAR)
|
gtk.gdk.INTERP_BILINEAR)
|
||||||
|
|
||||||
@ -735,8 +732,6 @@ class Activity(Window, gtk.Container):
|
|||||||
pixbuf.save_to_callback(save_func, 'png', user_data=preview_data)
|
pixbuf.save_to_callback(save_func, 'png', user_data=preview_data)
|
||||||
preview_data = ''.join(preview_data)
|
preview_data = ''.join(preview_data)
|
||||||
|
|
||||||
self._preview.clear()
|
|
||||||
|
|
||||||
return preview_data
|
return preview_data
|
||||||
|
|
||||||
def _get_buddies(self):
|
def _get_buddies(self):
|
||||||
@ -750,10 +745,6 @@ class Activity(Window, gtk.Container):
|
|||||||
else:
|
else:
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
def take_screenshot(self):
|
|
||||||
if self.canvas:
|
|
||||||
self._preview.take_screenshot(self.canvas)
|
|
||||||
|
|
||||||
def save(self):
|
def save(self):
|
||||||
"""Request that the activity is saved to the Journal.
|
"""Request that the activity is saved to the Journal.
|
||||||
|
|
||||||
@ -779,7 +770,7 @@ class Activity(Window, gtk.Container):
|
|||||||
self.metadata['buddies'] = cjson.encode(self._get_buddies())
|
self.metadata['buddies'] = cjson.encode(self._get_buddies())
|
||||||
|
|
||||||
preview = self._get_preview()
|
preview = self._get_preview()
|
||||||
if self._preview:
|
if preview is not None:
|
||||||
self.metadata['preview'] = dbus.ByteArray(preview)
|
self.metadata['preview'] = dbus.ByteArray(preview)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -810,8 +801,6 @@ class Activity(Window, gtk.Container):
|
|||||||
copy work that needs to be done in write_file()
|
copy work that needs to be done in write_file()
|
||||||
"""
|
"""
|
||||||
logging.debug('Activity.copy: %r' % self._jobject.object_id)
|
logging.debug('Activity.copy: %r' % self._jobject.object_id)
|
||||||
if not self._fully_obscured:
|
|
||||||
self.take_screenshot()
|
|
||||||
self.save()
|
self.save()
|
||||||
self._jobject.object_id = None
|
self._jobject.object_id = None
|
||||||
|
|
||||||
@ -974,9 +963,6 @@ class Activity(Window, gtk.Container):
|
|||||||
write_file() to do any state saving instead. If the application wants
|
write_file() to do any state saving instead. If the application wants
|
||||||
to control wether it can close, it should override can_close().
|
to control wether it can close, it should override can_close().
|
||||||
"""
|
"""
|
||||||
if not self._fully_obscured:
|
|
||||||
self.take_screenshot()
|
|
||||||
|
|
||||||
if not self.can_close():
|
if not self.can_close():
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -995,15 +981,6 @@ class Activity(Window, gtk.Container):
|
|||||||
self.close()
|
self.close()
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def __visibility_notify_event_cb(self, widget, event):
|
|
||||||
"""Visibility state is used when deciding if we can take screenshots.
|
|
||||||
Currently we allow screenshots whenever the activity window is fully
|
|
||||||
visible or partially obscured."""
|
|
||||||
if event.state is gtk.gdk.VISIBILITY_FULLY_OBSCURED:
|
|
||||||
self._fully_obscured = True
|
|
||||||
else:
|
|
||||||
self._fully_obscured = False
|
|
||||||
|
|
||||||
def get_metadata(self):
|
def get_metadata(self):
|
||||||
"""Returns the jobject metadata or None if there is no jobject.
|
"""Returns the jobject metadata or None if there is no jobject.
|
||||||
|
|
||||||
|
@ -1,139 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2007, Red Hat, Inc.
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <gdk/gdkx.h>
|
|
||||||
#include <gtk/gtkwindow.h>
|
|
||||||
#include <X11/extensions/XShm.h>
|
|
||||||
|
|
||||||
#include "sugar-preview.h"
|
|
||||||
|
|
||||||
static void sugar_preview_class_init (SugarPreviewClass *menu_class);
|
|
||||||
static void sugar_preview_init (SugarPreview *menu);
|
|
||||||
|
|
||||||
G_DEFINE_TYPE(SugarPreview, sugar_preview, G_TYPE_OBJECT)
|
|
||||||
|
|
||||||
void
|
|
||||||
sugar_preview_set_size(SugarPreview *preview, int width, int height)
|
|
||||||
{
|
|
||||||
preview->width = width;
|
|
||||||
preview->height = height;
|
|
||||||
}
|
|
||||||
|
|
||||||
GdkPixbuf *
|
|
||||||
sugar_preview_get_pixbuf(SugarPreview *preview)
|
|
||||||
{
|
|
||||||
if (preview->pixbuf != NULL) {
|
|
||||||
return preview->pixbuf;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (preview->image == NULL) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
preview->pixbuf = gdk_pixbuf_get_from_image(NULL, preview->image, NULL,
|
|
||||||
0, 0, 0, 0,
|
|
||||||
preview->image->width,
|
|
||||||
preview->image->height);
|
|
||||||
g_object_unref(G_OBJECT(preview->image));
|
|
||||||
preview->image = NULL;
|
|
||||||
|
|
||||||
return preview->pixbuf;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
sugar_preview_clear(SugarPreview *preview)
|
|
||||||
{
|
|
||||||
if (preview->image != NULL) {
|
|
||||||
g_object_unref(G_OBJECT(preview->image));
|
|
||||||
preview->image = NULL;
|
|
||||||
}
|
|
||||||
if (preview->pixbuf != NULL) {
|
|
||||||
g_object_unref(G_OBJECT(preview->pixbuf));
|
|
||||||
preview->pixbuf = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
widget_is_off_screen(GtkWidget *widget)
|
|
||||||
{
|
|
||||||
GdkScreen *screen;
|
|
||||||
gint x, y, width, height;
|
|
||||||
|
|
||||||
screen = gtk_widget_get_screen(widget);
|
|
||||||
|
|
||||||
gdk_window_get_geometry(widget->window, &x, &y, &width, &height, NULL);
|
|
||||||
|
|
||||||
return (x < 0 || y < 0 ||
|
|
||||||
x + width > gdk_screen_get_width(screen) ||
|
|
||||||
y + height > gdk_screen_get_height(screen));
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
sugar_preview_take_screenshot(SugarPreview *preview, GtkWidget *widget)
|
|
||||||
{
|
|
||||||
GdkDrawable *drawable;
|
|
||||||
GdkScreen *screen;
|
|
||||||
GdkVisual *visual;
|
|
||||||
GdkColormap *colormap;
|
|
||||||
gint width, height;
|
|
||||||
|
|
||||||
if (widget->window == NULL || widget_is_off_screen(widget)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
sugar_preview_clear(preview);
|
|
||||||
|
|
||||||
drawable = GDK_DRAWABLE(widget->window);
|
|
||||||
|
|
||||||
gdk_drawable_get_size(drawable, &width, &height);
|
|
||||||
|
|
||||||
screen = gdk_drawable_get_screen(drawable);
|
|
||||||
visual = gdk_drawable_get_visual(drawable);
|
|
||||||
colormap = gdk_drawable_get_colormap(drawable);
|
|
||||||
|
|
||||||
preview->image = gdk_image_new(GDK_IMAGE_SHARED, visual, width, height);
|
|
||||||
gdk_image_set_colormap(preview->image, colormap);
|
|
||||||
|
|
||||||
XShmGetImage(GDK_SCREEN_XDISPLAY(screen),
|
|
||||||
GDK_DRAWABLE_XID(drawable),
|
|
||||||
gdk_x11_image_get_ximage(preview->image),
|
|
||||||
0, 0, AllPlanes);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
sugar_preview_dispose(GObject *object)
|
|
||||||
{
|
|
||||||
SugarPreview *preview = SUGAR_PREVIEW(object);
|
|
||||||
sugar_preview_clear(preview);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
sugar_preview_class_init(SugarPreviewClass *preview_class)
|
|
||||||
{
|
|
||||||
GObjectClass *g_object_class = G_OBJECT_CLASS (preview_class);
|
|
||||||
|
|
||||||
g_object_class->dispose = sugar_preview_dispose;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
sugar_preview_init(SugarPreview *preview)
|
|
||||||
{
|
|
||||||
preview->image = NULL;
|
|
||||||
preview->pixbuf = NULL;
|
|
||||||
}
|
|
@ -1,62 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2007, Red Hat, Inc.
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __SUGAR_PREVIEW_H__
|
|
||||||
#define __SUGAR_PREVIEW_H__
|
|
||||||
|
|
||||||
#include <gdk/gdkdrawable.h>
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
|
||||||
|
|
||||||
typedef struct _SugarPreview SugarPreview;
|
|
||||||
typedef struct _SugarPreviewClass SugarPreviewClass;
|
|
||||||
|
|
||||||
#define SUGAR_TYPE_PREVIEW (sugar_preview_get_type())
|
|
||||||
#define SUGAR_PREVIEW(object) (G_TYPE_CHECK_INSTANCE_CAST((object), SUGAR_TYPE_PREVIEW, SugarPreview))
|
|
||||||
#define SUGAR_PREVIEW_CLASS(klass) (G_TYPE_CHACK_CLASS_CAST((klass), SUGAR_TYPE_PREVIEW, SugarPreviewClass))
|
|
||||||
#define SUGAR_IS_PREVIEW(object) (G_TYPE_CHECK_INSTANCE_TYPE((object), SUGAR_TYPE_PREVIEW))
|
|
||||||
#define SUGAR_IS_PREVIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), SUGAR_TYPE_PREVIEW))
|
|
||||||
#define SUGAR_PREVIEW_GET_CLASS(object) (G_TYPE_INSTANCE_GET_CLASS((object), SUGAR_TYPE_PREVIEW, SugarPreviewClass))
|
|
||||||
|
|
||||||
struct _SugarPreview {
|
|
||||||
GObject base_instance;
|
|
||||||
|
|
||||||
GdkImage *image;
|
|
||||||
GdkPixbuf *pixbuf;
|
|
||||||
|
|
||||||
int width;
|
|
||||||
int height;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _SugarPreviewClass {
|
|
||||||
GObjectClass base_class;
|
|
||||||
};
|
|
||||||
|
|
||||||
GType sugar_preview_get_type (void);
|
|
||||||
void sugar_preview_take_screenshot (SugarPreview *preview,
|
|
||||||
GtkWidget *widget);
|
|
||||||
void sugar_preview_set_size (SugarPreview *preview,
|
|
||||||
int width,
|
|
||||||
int height);
|
|
||||||
GdkPixbuf *sugar_preview_get_pixbuf (SugarPreview *preview);
|
|
||||||
void sugar_preview_clear (SugarPreview *preview);
|
|
||||||
|
|
||||||
G_END_DECLS
|
|
||||||
|
|
||||||
#endif /* __SUGAR_PREVIEW_H__ */
|
|
@ -1,43 +0,0 @@
|
|||||||
# Copyright (C) 2007, Red Hat, Inc.
|
|
||||||
#
|
|
||||||
# This library is free software; you can redistribute it and/or
|
|
||||||
# modify it under the terms of the GNU Lesser General Public
|
|
||||||
# License as published by the Free Software Foundation; either
|
|
||||||
# version 2 of the License, or (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This library is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
# Lesser General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU Lesser General Public
|
|
||||||
# License along with this library; if not, write to the
|
|
||||||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
# Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
"""
|
|
||||||
"""
|
|
||||||
|
|
||||||
import gtk
|
|
||||||
import gobject
|
|
||||||
|
|
||||||
from sugar import _sugarext
|
|
||||||
|
|
||||||
import common
|
|
||||||
|
|
||||||
def _preview_timeout_cb():
|
|
||||||
preview = _sugarext.Preview()
|
|
||||||
preview.take_screenshot(button.window)
|
|
||||||
preview.get_pixbuf().save('/home/marco/test.png','png')
|
|
||||||
preview.clear()
|
|
||||||
|
|
||||||
test = common.Test()
|
|
||||||
|
|
||||||
button = gtk.Button('Hello')
|
|
||||||
test.pack_start(button)
|
|
||||||
button.show()
|
|
||||||
|
|
||||||
gobject.timeout_add(2000, _preview_timeout_cb)
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
common.main(test)
|
|
Loading…
Reference in New Issue
Block a user