2006-06-22 Iain Holmes <iain@openedhand.com>
* gtk/gtk-clutter.[ch]: Rewrite to use clutter_stage_set_xwindow_foreign rather than GtkSocket. * gtk/gtk-clutter-test.c: Add fading!1!!!!11! OMGWTFBBQ!!!
This commit is contained in:
parent
1b7b2bc573
commit
e34b2f77c6
@ -1,3 +1,10 @@
|
|||||||
|
2006-06-22 Iain Holmes <iain@openedhand.com>
|
||||||
|
|
||||||
|
* gtk/gtk-clutter.[ch]: Rewrite to use
|
||||||
|
clutter_stage_set_xwindow_foreign rather than GtkSocket.
|
||||||
|
|
||||||
|
* gtk/gtk-clutter-test.c: Add fading!1!!!!11! OMGWTFBBQ!!!
|
||||||
|
|
||||||
2006-06-21 Emmanuele Bassi <ebassi@openedhand.com>
|
2006-06-21 Emmanuele Bassi <ebassi@openedhand.com>
|
||||||
|
|
||||||
* examples/video-cube.c (main): Quit on key press.
|
* examples/video-cube.c (main): Quit on key press.
|
||||||
|
@ -18,6 +18,8 @@ typedef struct SuperOH
|
|||||||
|
|
||||||
} SuperOH;
|
} SuperOH;
|
||||||
|
|
||||||
|
gboolean fade = FALSE;
|
||||||
|
|
||||||
/* input handler */
|
/* input handler */
|
||||||
void
|
void
|
||||||
input_cb (ClutterStage *stage,
|
input_cb (ClutterStage *stage,
|
||||||
@ -86,8 +88,12 @@ frame_cb (ClutterTimeline *timeline,
|
|||||||
- 6.0 * frame_num,
|
- 6.0 * frame_num,
|
||||||
clutter_actor_get_width (oh->hand[i])/2,
|
clutter_actor_get_width (oh->hand[i])/2,
|
||||||
clutter_actor_get_height (oh->hand[i])/2);
|
clutter_actor_get_height (oh->hand[i])/2);
|
||||||
|
if (fade == TRUE) {
|
||||||
|
clutter_actor_set_opacity (oh->hand[i], (255 - (frame_num % 255)));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
clutter_actor_rotate_x (CLUTTER_ACTOR(oh->group),
|
clutter_actor_rotate_x (CLUTTER_ACTOR(oh->group),
|
||||||
75.0,
|
75.0,
|
||||||
@ -95,13 +101,20 @@ frame_cb (ClutterTimeline *timeline,
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
clickity (GtkButton *button,
|
||||||
|
gpointer ud)
|
||||||
|
{
|
||||||
|
fade = !fade;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
ClutterTimeline *timeline;
|
ClutterTimeline *timeline;
|
||||||
ClutterActor *stage;
|
ClutterActor *stage;
|
||||||
ClutterColor stage_color = { 0x61, 0x64, 0x8c, 0xff };
|
ClutterColor stage_color = { 0x61, 0x64, 0x8c, 0xff };
|
||||||
GtkWidget *window, *plug, *clutter;
|
GtkWidget *window, *clutter;
|
||||||
GtkWidget *label, *button, *vbox;
|
GtkWidget *label, *button, *vbox;
|
||||||
GdkPixbuf *pixbuf;
|
GdkPixbuf *pixbuf;
|
||||||
SuperOH *oh;
|
SuperOH *oh;
|
||||||
@ -116,11 +129,6 @@ main (int argc, char *argv[])
|
|||||||
if (!pixbuf)
|
if (!pixbuf)
|
||||||
g_error("pixbuf load failed");
|
g_error("pixbuf load failed");
|
||||||
|
|
||||||
clutter = g_object_new (GTK_TYPE_CLUTTER, NULL);
|
|
||||||
stage = gtk_clutter_get_stage (GTK_CLUTTER (clutter));
|
|
||||||
|
|
||||||
/* Set our stage size */
|
|
||||||
clutter_actor_set_size (stage, WINWIDTH, WINHEIGHT);
|
|
||||||
|
|
||||||
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
||||||
g_signal_connect (window, "destroy",
|
g_signal_connect (window, "destroy",
|
||||||
@ -128,13 +136,21 @@ main (int argc, char *argv[])
|
|||||||
|
|
||||||
vbox = gtk_vbox_new (FALSE, 6);
|
vbox = gtk_vbox_new (FALSE, 6);
|
||||||
gtk_container_add (GTK_CONTAINER (window), vbox);
|
gtk_container_add (GTK_CONTAINER (window), vbox);
|
||||||
|
|
||||||
|
clutter = g_object_new (GTK_TYPE_CLUTTER, NULL);
|
||||||
|
stage = gtk_clutter_get_stage (GTK_CLUTTER (clutter));
|
||||||
|
|
||||||
gtk_container_add (GTK_CONTAINER (vbox), clutter);
|
gtk_container_add (GTK_CONTAINER (vbox), clutter);
|
||||||
|
|
||||||
|
/* Set our stage size */
|
||||||
|
/* clutter_actor_set_size (stage, WINWIDTH, WINHEIGHT); */
|
||||||
|
|
||||||
label = gtk_label_new ("This is a label");
|
label = gtk_label_new ("This is a label");
|
||||||
gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
|
gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
|
||||||
|
|
||||||
button = gtk_button_new_with_label ("This is a button...clicky");
|
button = gtk_button_new_with_label ("This is a button...clicky");
|
||||||
|
g_signal_connect (button, "clicked",
|
||||||
|
G_CALLBACK (clickity), NULL);
|
||||||
gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
|
gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
|
||||||
|
|
||||||
/* and its background color */
|
/* and its background color */
|
||||||
@ -157,13 +173,18 @@ main (int argc, char *argv[])
|
|||||||
for (i = 0; i < NHANDS; i++)
|
for (i = 0; i < NHANDS; i++)
|
||||||
{
|
{
|
||||||
gint x, y, w, h;
|
gint x, y, w, h;
|
||||||
|
ClutterColor colour = { 255, 0, 0, 255 };
|
||||||
|
#if 1
|
||||||
/* Create a texture from pixbuf, then clone in to same resources */
|
/* Create a texture from pixbuf, then clone in to same resources */
|
||||||
if (i == 0)
|
if (i == 0)
|
||||||
oh->hand[i] = clutter_texture_new_from_pixbuf (pixbuf);
|
oh->hand[i] = clutter_texture_new_from_pixbuf (pixbuf);
|
||||||
else
|
else
|
||||||
oh->hand[i] = clutter_clone_texture_new (CLUTTER_TEXTURE(oh->hand[0]));
|
oh->hand[i] = clutter_clone_texture_new (CLUTTER_TEXTURE(oh->hand[0]));
|
||||||
|
#else
|
||||||
|
|
||||||
|
oh->hand[i] = clutter_rectangle_new_with_color (&colour);
|
||||||
|
clutter_actor_set_size (oh->hand[i], 50, 50);
|
||||||
|
#endif
|
||||||
/* Place around a circle */
|
/* Place around a circle */
|
||||||
w = clutter_actor_get_width (oh->hand[0]);
|
w = clutter_actor_get_width (oh->hand[0]);
|
||||||
h = clutter_actor_get_height (oh->hand[0]);
|
h = clutter_actor_get_height (oh->hand[0]);
|
||||||
|
@ -25,9 +25,12 @@
|
|||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include <gtk/gtksocket.h>
|
#include <gdk/gdkx.h>
|
||||||
|
|
||||||
|
#include <gtk/gtkdrawingarea.h>
|
||||||
#include <gtk/gtkwidget.h>
|
#include <gtk/gtkwidget.h>
|
||||||
|
|
||||||
|
#include <clutter/clutter-main.h>
|
||||||
#include <clutter/clutter-stage.h>
|
#include <clutter/clutter-stage.h>
|
||||||
|
|
||||||
#include "gtk-clutter.h"
|
#include "gtk-clutter.h"
|
||||||
@ -37,10 +40,9 @@
|
|||||||
|
|
||||||
struct _GtkClutterPrivate {
|
struct _GtkClutterPrivate {
|
||||||
ClutterActor *stage;
|
ClutterActor *stage;
|
||||||
gboolean anchored;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static GtkSocketClass *parent_class;
|
static GtkDrawingAreaClass *parent_class;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dispose (GObject *object)
|
dispose (GObject *object)
|
||||||
@ -69,27 +71,42 @@ size_request (GtkWidget *widget,
|
|||||||
clutter = GTK_CLUTTER (widget);
|
clutter = GTK_CLUTTER (widget);
|
||||||
priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
||||||
|
|
||||||
req->width = clutter_actor_get_width (priv->stage);
|
req->width = 800;
|
||||||
req->height = clutter_actor_get_height (priv->stage);
|
req->height = 600;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
hierarchy_changed (GtkWidget *widget,
|
realize (GtkWidget *widget)
|
||||||
GtkWidget *parent)
|
|
||||||
{
|
{
|
||||||
GtkClutter *clutter;
|
GtkClutter *clutter;
|
||||||
GtkClutterPrivate *priv;
|
GtkClutterPrivate *priv;
|
||||||
|
XVisualInfo *xvinfo;
|
||||||
|
GdkVisual *visual;
|
||||||
|
GdkColormap *colormap;
|
||||||
|
gboolean foreign_success;
|
||||||
|
|
||||||
clutter = GTK_CLUTTER (widget);
|
clutter = GTK_CLUTTER (widget);
|
||||||
priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
||||||
|
|
||||||
if (!priv->anchored) {
|
/* We need to use the colormap from the Clutter visual */
|
||||||
/* Now we can add our stage to the socket */
|
xvinfo = clutter_stage_get_xvisual (CLUTTER_STAGE (priv->stage));
|
||||||
gtk_socket_add_id
|
visual = gdk_x11_screen_lookup_visual (gdk_screen_get_default (),
|
||||||
(GTK_SOCKET (clutter), (GdkNativeWindow) clutter_stage_get_xwindow (CLUTTER_STAGE (priv->stage)));
|
xvinfo->visualid);
|
||||||
|
colormap = gdk_colormap_new (visual, FALSE);
|
||||||
|
gtk_widget_set_colormap (widget, colormap);
|
||||||
|
|
||||||
priv->anchored = TRUE;
|
/* And turn off double buffering, cos GL doesn't like it */
|
||||||
}
|
gtk_widget_set_double_buffered (widget, FALSE);
|
||||||
|
|
||||||
|
GTK_WIDGET_CLASS (parent_class)->realize (widget);
|
||||||
|
|
||||||
|
gdk_window_set_back_pixmap (widget->window, NULL, FALSE);
|
||||||
|
|
||||||
|
clutter = GTK_CLUTTER (widget);
|
||||||
|
priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
||||||
|
|
||||||
|
clutter_stage_set_xwindow_foreign (CLUTTER_STAGE (priv->stage),
|
||||||
|
GDK_WINDOW_XID (widget->window));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -101,7 +118,7 @@ gtk_clutter_class_init (GtkClutterClass *klass)
|
|||||||
gobject_class->dispose = dispose;
|
gobject_class->dispose = dispose;
|
||||||
|
|
||||||
widget_class->size_request = size_request;
|
widget_class->size_request = size_request;
|
||||||
widget_class->hierarchy_changed = hierarchy_changed;
|
widget_class->realize = realize;
|
||||||
|
|
||||||
g_type_class_add_private (gobject_class, sizeof (GtkClutterPrivate));
|
g_type_class_add_private (gobject_class, sizeof (GtkClutterPrivate));
|
||||||
|
|
||||||
@ -114,13 +131,22 @@ gtk_clutter_init (GtkClutter *clutter)
|
|||||||
GtkClutterPrivate *priv;
|
GtkClutterPrivate *priv;
|
||||||
|
|
||||||
clutter->priv = priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
clutter->priv = priv = GTK_CLUTTER_GET_PRIVATE (clutter);
|
||||||
|
|
||||||
|
gtk_widget_set_double_buffered (GTK_WIDGET (clutter), FALSE);
|
||||||
|
|
||||||
priv->stage = clutter_stage_get_default ();
|
priv->stage = clutter_stage_get_default ();
|
||||||
priv->anchored = FALSE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
G_DEFINE_TYPE (GtkClutter, gtk_clutter, GTK_TYPE_SOCKET);
|
G_DEFINE_TYPE (GtkClutter, gtk_clutter, GTK_TYPE_DRAWING_AREA);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gtk_clutter_get_stage:
|
||||||
|
* @clutter: A #GtkClutter object.
|
||||||
|
*
|
||||||
|
* Obtains the #ClutterStage associated with this object.
|
||||||
|
*
|
||||||
|
* Return value: A #ClutterActor.
|
||||||
|
*/
|
||||||
ClutterActor *
|
ClutterActor *
|
||||||
gtk_clutter_get_stage (GtkClutter *clutter)
|
gtk_clutter_get_stage (GtkClutter *clutter)
|
||||||
{
|
{
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
#ifndef _HAVE_GTK_CLUTTER_H
|
#ifndef _HAVE_GTK_CLUTTER_H
|
||||||
#define _HAVE_GTK_CLUTTER_H
|
#define _HAVE_GTK_CLUTTER_H
|
||||||
|
|
||||||
#include <gtk/gtksocket.h>
|
#include <gtk/gtkdrawingarea.h>
|
||||||
|
|
||||||
#include <clutter/clutter-actor.h>
|
#include <clutter/clutter-actor.h>
|
||||||
|
|
||||||
@ -60,7 +60,7 @@ typedef struct _GtkClutterClass GtkClutterClass;
|
|||||||
|
|
||||||
struct _GtkClutter
|
struct _GtkClutter
|
||||||
{
|
{
|
||||||
GtkSocket parent;
|
GtkDrawingArea parent;
|
||||||
|
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
GtkClutterPrivate *priv;
|
GtkClutterPrivate *priv;
|
||||||
@ -68,7 +68,7 @@ struct _GtkClutter
|
|||||||
|
|
||||||
struct _GtkClutterClass
|
struct _GtkClutterClass
|
||||||
{
|
{
|
||||||
GtkSocketClass parent_class;
|
GtkDrawingAreaClass parent_class;
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gtk_clutter_get_type (void);
|
GType gtk_clutter_get_type (void);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user