2006-05-29 08:59:36 +00:00
|
|
|
#include <clutter/clutter.h>
|
2007-06-13 23:24:59 +00:00
|
|
|
|
2006-05-29 08:59:36 +00:00
|
|
|
#include <math.h>
|
2006-06-15 22:04:19 +00:00
|
|
|
#include <errno.h>
|
|
|
|
#include <stdlib.h>
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
#include <glib.h>
|
2008-11-07 19:32:28 +00:00
|
|
|
#include <gmodule.h>
|
2006-05-29 08:59:36 +00:00
|
|
|
|
|
|
|
#define NHANDS 6
|
|
|
|
|
|
|
|
typedef struct SuperOH
|
|
|
|
{
|
2010-10-11 17:45:30 +01:00
|
|
|
ClutterActor **hand;
|
|
|
|
ClutterActor *bgtex;
|
2009-01-27 15:18:45 +00:00
|
|
|
ClutterActor *real_hand;
|
|
|
|
ClutterActor *group;
|
|
|
|
ClutterActor *stage;
|
|
|
|
|
|
|
|
gint stage_width;
|
|
|
|
gint stage_height;
|
|
|
|
gfloat radius;
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
ClutterBehaviour *scaler_1;
|
|
|
|
ClutterBehaviour *scaler_2;
|
|
|
|
ClutterTimeline *timeline;
|
2008-01-30 12:13:26 +00:00
|
|
|
} SuperOH;
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
static gint n_hands = NHANDS;
|
|
|
|
|
2019-01-20 09:03:50 +01:00
|
|
|
int
|
|
|
|
test_actors_main (int argc, char *argv[]);
|
|
|
|
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
static GOptionEntry super_oh_entries[] = {
|
|
|
|
{
|
|
|
|
"num-hands", 'n',
|
|
|
|
0,
|
|
|
|
G_OPTION_ARG_INT, &n_hands,
|
|
|
|
"Number of hands", "HANDS"
|
|
|
|
},
|
|
|
|
{ NULL }
|
|
|
|
};
|
|
|
|
|
2011-02-09 13:05:12 +00:00
|
|
|
static void
|
|
|
|
on_group_destroy (ClutterActor *actor,
|
|
|
|
SuperOH *oh)
|
|
|
|
{
|
|
|
|
oh->group = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
on_hand_destroy (ClutterActor *actor,
|
|
|
|
SuperOH *oh)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < n_hands; i++)
|
|
|
|
{
|
|
|
|
if (oh->hand[i] == actor)
|
|
|
|
oh->hand[i] = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-01-30 12:13:26 +00:00
|
|
|
static gboolean
|
2009-06-11 16:23:26 +01:00
|
|
|
on_button_press_event (ClutterActor *actor,
|
|
|
|
ClutterEvent *event,
|
|
|
|
SuperOH *oh)
|
2006-05-29 08:59:36 +00:00
|
|
|
{
|
2009-06-11 16:23:26 +01:00
|
|
|
gfloat x, y;
|
2008-06-06 16:22:55 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
clutter_event_get_coords (event, &x, &y);
|
2007-03-22 18:21:59 +00:00
|
|
|
|
2010-08-26 17:31:32 +01:00
|
|
|
g_print ("*** button press event (button:%d) at %.2f, %.2f on %s ***\n",
|
2009-06-11 16:23:26 +01:00
|
|
|
clutter_event_get_button (event),
|
2010-08-26 17:31:32 +01:00
|
|
|
x, y,
|
|
|
|
clutter_actor_get_name (actor));
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
clutter_actor_hide (actor);
|
2006-06-05 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-color.h:
* clutter-color.c: Reimplement ClutterColor as a boxed type;
add convenience API for color handling, like: add, subtract,
shade, HSL color-space conversion, packing and unpacking.
* clutter-private.h: Update ClutterMainContext, and export the
main context pointer here.
* clutter-rectangle.h:
* clutter-rectangle.c: Update the color-related code; make
clutter_rectangle_new() and empty constructor and provide
clutter_rectangle_new_with_color(); provide color setter
and getter API.
* clutter-label.h:
* clutter-label.c: Rename the "font" property to "font-name";
update the color-related code to the new ClutterColor object;
rename clutter_label_new() to clutter_label_new_with_text(),
and add setters and getters for the properties.
* clutter-marshal.list: Add VOID:OBJECT and VOID:BOXED marshallers
generators.
* clutter-stage.h:
* clutter-stage.c: Rework the API: provide a default constructor
for a singleton object, named clutter_stage_get_default(), which
supercedes the clutter_stage() function in clutter-main; provide
new events: button-press-event, button-release-event,
key-press-event and key-release-event; update the color-related
code;
(clutter_stage_snapshot): Allow negative width and height when
taking a snapshot (meaning: use full width/height).
(clutter_stage_get_element_at_pos): Rename clutter_stage_pick().
* clutter-element.c (clutter_element_paint): Clean up the
stage and color related code.
* clutter-event.h:
* clutter-event.c: Add generic ClutterAnyEvent type; add
clutter_event_new(), clutter_event_copy() and clutter_event_free();
make ClutterEvent a boxed type.
* clutter-main.h:
* clutter-main.c: Remove clutter_stage(); add clutter_main_quit(),
for cleanly quitting from clutter_main(); add multiple mainloops
support; allocate the ClutterCntx instead of adding it to the
stack; re-work the ClutterEvent dispatching.
* clutter-group.c (clutter_group_add), (clutter_group_remove): Keep
a reference on the element when added to a ClutterGroup.
* examples/rects.py
* examples/test.c:
* examples/test-text.c:
* examples/video-cube.c:
* examples/super-oh.c:
* examples/test-video.c: Update.
2006-06-05 13:38:31 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
return TRUE;
|
|
|
|
}
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
static gboolean
|
|
|
|
input_cb (ClutterActor *stage,
|
|
|
|
ClutterEvent *event,
|
|
|
|
gpointer data)
|
|
|
|
{
|
|
|
|
SuperOH *oh = data;
|
|
|
|
|
|
|
|
if (event->type == CLUTTER_KEY_RELEASE)
|
2006-06-05 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-color.h:
* clutter-color.c: Reimplement ClutterColor as a boxed type;
add convenience API for color handling, like: add, subtract,
shade, HSL color-space conversion, packing and unpacking.
* clutter-private.h: Update ClutterMainContext, and export the
main context pointer here.
* clutter-rectangle.h:
* clutter-rectangle.c: Update the color-related code; make
clutter_rectangle_new() and empty constructor and provide
clutter_rectangle_new_with_color(); provide color setter
and getter API.
* clutter-label.h:
* clutter-label.c: Rename the "font" property to "font-name";
update the color-related code to the new ClutterColor object;
rename clutter_label_new() to clutter_label_new_with_text(),
and add setters and getters for the properties.
* clutter-marshal.list: Add VOID:OBJECT and VOID:BOXED marshallers
generators.
* clutter-stage.h:
* clutter-stage.c: Rework the API: provide a default constructor
for a singleton object, named clutter_stage_get_default(), which
supercedes the clutter_stage() function in clutter-main; provide
new events: button-press-event, button-release-event,
key-press-event and key-release-event; update the color-related
code;
(clutter_stage_snapshot): Allow negative width and height when
taking a snapshot (meaning: use full width/height).
(clutter_stage_get_element_at_pos): Rename clutter_stage_pick().
* clutter-element.c (clutter_element_paint): Clean up the
stage and color related code.
* clutter-event.h:
* clutter-event.c: Add generic ClutterAnyEvent type; add
clutter_event_new(), clutter_event_copy() and clutter_event_free();
make ClutterEvent a boxed type.
* clutter-main.h:
* clutter-main.c: Remove clutter_stage(); add clutter_main_quit(),
for cleanly quitting from clutter_main(); add multiple mainloops
support; allocate the ClutterCntx instead of adding it to the
stack; re-work the ClutterEvent dispatching.
* clutter-group.c (clutter_group_add), (clutter_group_remove): Keep
a reference on the element when added to a ClutterGroup.
* examples/rects.py
* examples/test.c:
* examples/test-text.c:
* examples/video-cube.c:
* examples/super-oh.c:
* examples/test-video.c: Update.
2006-06-05 13:38:31 +00:00
|
|
|
{
|
|
|
|
g_print ("*** key press event (key:%c) ***\n",
|
2009-06-06 15:27:37 +01:00
|
|
|
clutter_event_get_key_symbol (event));
|
2008-01-30 12:13:26 +00:00
|
|
|
|
2010-09-10 13:41:49 +01:00
|
|
|
if (clutter_event_get_key_symbol (event) == CLUTTER_KEY_q)
|
2008-01-18 18:11:33 +00:00
|
|
|
{
|
|
|
|
clutter_main_quit ();
|
2009-06-11 16:23:26 +01:00
|
|
|
|
2008-01-18 18:11:33 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
2010-09-10 13:41:49 +01:00
|
|
|
else if (clutter_event_get_key_symbol (event) == CLUTTER_KEY_r)
|
2008-06-06 16:22:55 +00:00
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
for (i = 0; i < n_hands; i++)
|
2011-02-09 13:05:12 +00:00
|
|
|
{
|
|
|
|
if (oh->hand[i] != NULL)
|
|
|
|
clutter_actor_show (oh->hand[i]);
|
|
|
|
}
|
2008-06-06 16:22:55 +00:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
2006-06-05 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-color.h:
* clutter-color.c: Reimplement ClutterColor as a boxed type;
add convenience API for color handling, like: add, subtract,
shade, HSL color-space conversion, packing and unpacking.
* clutter-private.h: Update ClutterMainContext, and export the
main context pointer here.
* clutter-rectangle.h:
* clutter-rectangle.c: Update the color-related code; make
clutter_rectangle_new() and empty constructor and provide
clutter_rectangle_new_with_color(); provide color setter
and getter API.
* clutter-label.h:
* clutter-label.c: Rename the "font" property to "font-name";
update the color-related code to the new ClutterColor object;
rename clutter_label_new() to clutter_label_new_with_text(),
and add setters and getters for the properties.
* clutter-marshal.list: Add VOID:OBJECT and VOID:BOXED marshallers
generators.
* clutter-stage.h:
* clutter-stage.c: Rework the API: provide a default constructor
for a singleton object, named clutter_stage_get_default(), which
supercedes the clutter_stage() function in clutter-main; provide
new events: button-press-event, button-release-event,
key-press-event and key-release-event; update the color-related
code;
(clutter_stage_snapshot): Allow negative width and height when
taking a snapshot (meaning: use full width/height).
(clutter_stage_get_element_at_pos): Rename clutter_stage_pick().
* clutter-element.c (clutter_element_paint): Clean up the
stage and color related code.
* clutter-event.h:
* clutter-event.c: Add generic ClutterAnyEvent type; add
clutter_event_new(), clutter_event_copy() and clutter_event_free();
make ClutterEvent a boxed type.
* clutter-main.h:
* clutter-main.c: Remove clutter_stage(); add clutter_main_quit(),
for cleanly quitting from clutter_main(); add multiple mainloops
support; allocate the ClutterCntx instead of adding it to the
stack; re-work the ClutterEvent dispatching.
* clutter-group.c (clutter_group_add), (clutter_group_remove): Keep
a reference on the element when added to a ClutterGroup.
* examples/rects.py
* examples/test.c:
* examples/test-text.c:
* examples/video-cube.c:
* examples/super-oh.c:
* examples/test-video.c: Update.
2006-06-05 13:38:31 +00:00
|
|
|
}
|
2008-01-18 18:11:33 +00:00
|
|
|
|
|
|
|
return FALSE;
|
2006-05-29 08:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Timeline handler */
|
2008-01-18 18:11:33 +00:00
|
|
|
static void
|
2008-01-30 12:13:26 +00:00
|
|
|
frame_cb (ClutterTimeline *timeline,
|
2009-06-04 13:05:12 +01:00
|
|
|
gint msecs,
|
2006-05-29 08:59:36 +00:00
|
|
|
gpointer data)
|
|
|
|
{
|
2008-06-06 16:22:55 +00:00
|
|
|
SuperOH *oh = data;
|
2009-01-27 15:18:45 +00:00
|
|
|
gint i;
|
2009-06-04 13:05:12 +01:00
|
|
|
float rotation = clutter_timeline_get_progress (timeline) * 360.0f;
|
2006-05-29 08:59:36 +00:00
|
|
|
|
|
|
|
/* Rotate everything clockwise about stage center*/
|
2011-02-09 13:05:12 +00:00
|
|
|
if (oh->group != NULL)
|
|
|
|
clutter_actor_set_rotation (oh->group,
|
|
|
|
CLUTTER_Z_AXIS,
|
|
|
|
rotation,
|
|
|
|
oh->stage_width / 2,
|
|
|
|
oh->stage_height / 2,
|
|
|
|
0);
|
2007-06-13 23:24:59 +00:00
|
|
|
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
for (i = 0; i < n_hands; i++)
|
2006-05-29 08:59:36 +00:00
|
|
|
{
|
2007-06-13 23:24:59 +00:00
|
|
|
/* Rotate each hand around there centers - to get this we need
|
|
|
|
* to take into account any scaling.
|
2008-02-07 15:06:31 +00:00
|
|
|
*/
|
2011-02-09 13:05:12 +00:00
|
|
|
if (oh->hand[i] != NULL)
|
|
|
|
clutter_actor_set_rotation (oh->hand[i],
|
|
|
|
CLUTTER_Z_AXIS,
|
|
|
|
-6.0 * rotation,
|
|
|
|
0, 0, 0);
|
2007-06-13 23:24:59 +00:00
|
|
|
}
|
|
|
|
}
|
2006-06-15 22:04:19 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
static void
|
|
|
|
stop_and_quit (ClutterActor *stage,
|
|
|
|
SuperOH *data)
|
|
|
|
{
|
|
|
|
clutter_timeline_stop (data->timeline);
|
|
|
|
|
|
|
|
clutter_main_quit ();
|
|
|
|
}
|
|
|
|
|
2009-01-20 16:42:49 +00:00
|
|
|
static gdouble
|
|
|
|
my_sine_wave (ClutterAlpha *alpha,
|
|
|
|
gpointer dummy G_GNUC_UNUSED)
|
|
|
|
{
|
|
|
|
ClutterTimeline *timeline = clutter_alpha_get_timeline (alpha);
|
|
|
|
gdouble progress = clutter_timeline_get_progress (timeline);
|
|
|
|
|
|
|
|
return sin (progress * G_PI);
|
|
|
|
}
|
|
|
|
|
2008-11-07 19:32:28 +00:00
|
|
|
G_MODULE_EXPORT int
|
|
|
|
test_actors_main (int argc, char *argv[])
|
2006-05-29 08:59:36 +00:00
|
|
|
{
|
2009-01-27 15:18:45 +00:00
|
|
|
ClutterAlpha *alpha;
|
|
|
|
SuperOH *oh;
|
|
|
|
gint i;
|
|
|
|
GError *error;
|
|
|
|
ClutterActor *real_hand;
|
2009-11-05 17:30:33 +00:00
|
|
|
gchar *file;
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
|
|
|
|
error = NULL;
|
2007-06-13 23:24:59 +00:00
|
|
|
|
2011-02-22 12:53:15 +00:00
|
|
|
if (clutter_init_with_args (&argc, &argv,
|
|
|
|
NULL,
|
|
|
|
super_oh_entries,
|
|
|
|
NULL,
|
|
|
|
&error) != CLUTTER_INIT_SUCCESS)
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
{
|
|
|
|
g_warning ("Unable to initialise Clutter:\n%s",
|
|
|
|
error->message);
|
|
|
|
g_error_free (error);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
return EXIT_FAILURE;
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
}
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
oh = g_new (SuperOH, 1);
|
2006-06-05 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-color.h:
* clutter-color.c: Reimplement ClutterColor as a boxed type;
add convenience API for color handling, like: add, subtract,
shade, HSL color-space conversion, packing and unpacking.
* clutter-private.h: Update ClutterMainContext, and export the
main context pointer here.
* clutter-rectangle.h:
* clutter-rectangle.c: Update the color-related code; make
clutter_rectangle_new() and empty constructor and provide
clutter_rectangle_new_with_color(); provide color setter
and getter API.
* clutter-label.h:
* clutter-label.c: Rename the "font" property to "font-name";
update the color-related code to the new ClutterColor object;
rename clutter_label_new() to clutter_label_new_with_text(),
and add setters and getters for the properties.
* clutter-marshal.list: Add VOID:OBJECT and VOID:BOXED marshallers
generators.
* clutter-stage.h:
* clutter-stage.c: Rework the API: provide a default constructor
for a singleton object, named clutter_stage_get_default(), which
supercedes the clutter_stage() function in clutter-main; provide
new events: button-press-event, button-release-event,
key-press-event and key-release-event; update the color-related
code;
(clutter_stage_snapshot): Allow negative width and height when
taking a snapshot (meaning: use full width/height).
(clutter_stage_get_element_at_pos): Rename clutter_stage_pick().
* clutter-element.c (clutter_element_paint): Clean up the
stage and color related code.
* clutter-event.h:
* clutter-event.c: Add generic ClutterAnyEvent type; add
clutter_event_new(), clutter_event_copy() and clutter_event_free();
make ClutterEvent a boxed type.
* clutter-main.h:
* clutter-main.c: Remove clutter_stage(); add clutter_main_quit(),
for cleanly quitting from clutter_main(); add multiple mainloops
support; allocate the ClutterCntx instead of adding it to the
stack; re-work the ClutterEvent dispatching.
* clutter-group.c (clutter_group_add), (clutter_group_remove): Keep
a reference on the element when added to a ClutterGroup.
* examples/rects.py
* examples/test.c:
* examples/test-text.c:
* examples/video-cube.c:
* examples/super-oh.c:
* examples/test-video.c: Update.
2006-06-05 13:38:31 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
oh->stage = clutter_stage_new ();
|
|
|
|
clutter_actor_set_size (oh->stage, 800, 600);
|
|
|
|
clutter_actor_set_name (oh->stage, "Default Stage");
|
2012-02-13 16:47:17 +00:00
|
|
|
clutter_actor_set_background_color (oh->stage, CLUTTER_COLOR_LightSkyBlue);
|
2012-01-20 18:05:53 +00:00
|
|
|
g_signal_connect (oh->stage, "destroy", G_CALLBACK (stop_and_quit), oh);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
clutter_stage_set_title (CLUTTER_STAGE (oh->stage), "Actors");
|
|
|
|
clutter_stage_set_user_resizable (CLUTTER_STAGE (oh->stage), TRUE);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2007-06-13 23:24:59 +00:00
|
|
|
/* Create a timeline to manage animation */
|
2009-06-04 13:05:12 +01:00
|
|
|
oh->timeline = clutter_timeline_new (6000);
|
2012-02-13 16:47:17 +00:00
|
|
|
clutter_timeline_set_repeat_count (oh->timeline, -1);
|
2007-06-13 23:24:59 +00:00
|
|
|
|
|
|
|
/* fire a callback for frame change */
|
2009-01-27 15:18:45 +00:00
|
|
|
g_signal_connect (oh->timeline, "new-frame", G_CALLBACK (frame_cb), oh);
|
2007-06-13 23:24:59 +00:00
|
|
|
|
|
|
|
/* Set up some behaviours to handle scaling */
|
2009-01-27 16:12:30 +00:00
|
|
|
alpha = clutter_alpha_new_with_func (oh->timeline, my_sine_wave, NULL, NULL);
|
2007-06-13 23:24:59 +00:00
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
oh->scaler_1 = clutter_behaviour_scale_new (alpha, 0.5, 0.5, 1.0, 1.0);
|
|
|
|
oh->scaler_2 = clutter_behaviour_scale_new (alpha, 1.0, 1.0, 0.5, 0.5);
|
2007-06-13 23:24:59 +00:00
|
|
|
|
2009-11-05 17:30:33 +00:00
|
|
|
file = g_build_filename (TESTS_DATADIR, "redhand.png", NULL);
|
|
|
|
real_hand = clutter_texture_new_from_file (file, &error);
|
2009-01-27 15:18:45 +00:00
|
|
|
if (real_hand == NULL)
|
2009-11-05 17:30:33 +00:00
|
|
|
g_error ("image load failed: %s", error->message);
|
|
|
|
|
|
|
|
g_free (file);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
/* create a new actor to hold other actors */
|
2012-01-17 16:20:41 +00:00
|
|
|
oh->group = clutter_actor_new ();
|
2012-01-20 18:05:53 +00:00
|
|
|
clutter_actor_set_layout_manager (oh->group, clutter_fixed_layout_new ());
|
2010-08-26 17:31:32 +01:00
|
|
|
clutter_actor_set_name (oh->group, "Group");
|
2011-02-09 13:05:12 +00:00
|
|
|
g_signal_connect (oh->group, "destroy", G_CALLBACK (on_group_destroy), oh);
|
2012-01-20 18:05:53 +00:00
|
|
|
clutter_actor_add_constraint (oh->group, clutter_align_constraint_new (oh->stage, CLUTTER_ALIGN_BOTH, 0.5));
|
|
|
|
clutter_actor_add_constraint (oh->group, clutter_bind_constraint_new (oh->stage, CLUTTER_BIND_SIZE, 0.0f));
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
|
|
|
|
oh->hand = g_new (ClutterActor*, n_hands);
|
2009-01-27 15:18:45 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
oh->stage_width = clutter_actor_get_width (oh->stage);
|
|
|
|
oh->stage_height = clutter_actor_get_height (oh->stage);
|
2009-01-27 15:18:45 +00:00
|
|
|
oh->radius = (oh->stage_width + oh->stage_height)
|
|
|
|
/ n_hands;
|
|
|
|
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
for (i = 0; i < n_hands; i++)
|
2006-05-29 08:59:36 +00:00
|
|
|
{
|
|
|
|
gint x, y, w, h;
|
|
|
|
|
|
|
|
if (i == 0)
|
2010-08-26 17:31:32 +01:00
|
|
|
{
|
|
|
|
oh->hand[i] = real_hand;
|
|
|
|
clutter_actor_set_name (oh->hand[i], "Real Hand");
|
|
|
|
}
|
2006-08-29 19:09:43 +00:00
|
|
|
else
|
2010-08-26 17:31:32 +01:00
|
|
|
{
|
|
|
|
oh->hand[i] = clutter_clone_new (real_hand);
|
|
|
|
clutter_actor_set_name (oh->hand[i], "Clone Hand");
|
|
|
|
}
|
2009-01-27 15:18:45 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
clutter_actor_set_reactive (oh->hand[i], TRUE);
|
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
clutter_actor_set_size (oh->hand[i], 200, 213);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
|
|
|
/* Place around a circle */
|
2009-01-27 15:18:45 +00:00
|
|
|
w = clutter_actor_get_width (oh->hand[i]);
|
|
|
|
h = clutter_actor_get_height (oh->hand[i]);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
x = oh->stage_width / 2
|
|
|
|
+ oh->radius
|
|
|
|
* cos (i * G_PI / (n_hands / 2))
|
2008-02-07 17:04:43 +00:00
|
|
|
- w / 2;
|
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
y = oh->stage_height / 2
|
|
|
|
+ oh->radius
|
|
|
|
* sin (i * G_PI / (n_hands / 2))
|
2008-02-07 17:04:43 +00:00
|
|
|
- h / 2;
|
|
|
|
|
|
|
|
clutter_actor_set_position (oh->hand[i], x, y);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2008-02-07 15:01:03 +00:00
|
|
|
clutter_actor_move_anchor_point_from_gravity (oh->hand[i],
|
2008-01-30 12:13:26 +00:00
|
|
|
CLUTTER_GRAVITY_CENTER);
|
|
|
|
|
2006-05-29 08:59:36 +00:00
|
|
|
/* Add to our group group */
|
2007-06-07 14:41:35 +00:00
|
|
|
clutter_container_add_actor (CLUTTER_CONTAINER (oh->group), oh->hand[i]);
|
2006-10-03 21:59:30 +00:00
|
|
|
|
2009-06-11 16:23:26 +01:00
|
|
|
g_signal_connect (oh->hand[i], "button-press-event",
|
|
|
|
G_CALLBACK (on_button_press_event),
|
|
|
|
oh);
|
|
|
|
|
2011-02-09 13:05:12 +00:00
|
|
|
g_signal_connect (oh->hand[i], "destroy",
|
|
|
|
G_CALLBACK (on_hand_destroy),
|
|
|
|
oh);
|
|
|
|
|
2007-06-13 23:24:59 +00:00
|
|
|
if (i % 2)
|
2009-01-27 15:18:45 +00:00
|
|
|
clutter_behaviour_apply (oh->scaler_1, oh->hand[i]);
|
2007-06-13 23:24:59 +00:00
|
|
|
else
|
2009-01-27 15:18:45 +00:00
|
|
|
clutter_behaviour_apply (oh->scaler_2, oh->hand[i]);
|
2007-06-13 23:24:59 +00:00
|
|
|
}
|
2006-08-29 19:09:43 +00:00
|
|
|
|
2006-05-29 08:59:36 +00:00
|
|
|
/* Add the group to the stage */
|
2012-01-20 18:05:53 +00:00
|
|
|
clutter_container_add_actor (CLUTTER_CONTAINER (oh->stage), oh->group);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
/* Show everying */
|
2012-01-20 18:05:53 +00:00
|
|
|
clutter_actor_show (oh->stage);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2012-01-20 18:05:53 +00:00
|
|
|
g_signal_connect (oh->stage, "key-release-event",
|
2006-06-05 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-color.h:
* clutter-color.c: Reimplement ClutterColor as a boxed type;
add convenience API for color handling, like: add, subtract,
shade, HSL color-space conversion, packing and unpacking.
* clutter-private.h: Update ClutterMainContext, and export the
main context pointer here.
* clutter-rectangle.h:
* clutter-rectangle.c: Update the color-related code; make
clutter_rectangle_new() and empty constructor and provide
clutter_rectangle_new_with_color(); provide color setter
and getter API.
* clutter-label.h:
* clutter-label.c: Rename the "font" property to "font-name";
update the color-related code to the new ClutterColor object;
rename clutter_label_new() to clutter_label_new_with_text(),
and add setters and getters for the properties.
* clutter-marshal.list: Add VOID:OBJECT and VOID:BOXED marshallers
generators.
* clutter-stage.h:
* clutter-stage.c: Rework the API: provide a default constructor
for a singleton object, named clutter_stage_get_default(), which
supercedes the clutter_stage() function in clutter-main; provide
new events: button-press-event, button-release-event,
key-press-event and key-release-event; update the color-related
code;
(clutter_stage_snapshot): Allow negative width and height when
taking a snapshot (meaning: use full width/height).
(clutter_stage_get_element_at_pos): Rename clutter_stage_pick().
* clutter-element.c (clutter_element_paint): Clean up the
stage and color related code.
* clutter-event.h:
* clutter-event.c: Add generic ClutterAnyEvent type; add
clutter_event_new(), clutter_event_copy() and clutter_event_free();
make ClutterEvent a boxed type.
* clutter-main.h:
* clutter-main.c: Remove clutter_stage(); add clutter_main_quit(),
for cleanly quitting from clutter_main(); add multiple mainloops
support; allocate the ClutterCntx instead of adding it to the
stack; re-work the ClutterEvent dispatching.
* clutter-group.c (clutter_group_add), (clutter_group_remove): Keep
a reference on the element when added to a ClutterGroup.
* examples/rects.py
* examples/test.c:
* examples/test-text.c:
* examples/video-cube.c:
* examples/super-oh.c:
* examples/test-video.c: Update.
2006-06-05 13:38:31 +00:00
|
|
|
G_CALLBACK (input_cb),
|
|
|
|
oh);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
|
|
|
/* and start it */
|
2009-01-27 15:18:45 +00:00
|
|
|
clutter_timeline_start (oh->timeline);
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2007-08-08 10:20:14 +00:00
|
|
|
clutter_main ();
|
2006-05-29 08:59:36 +00:00
|
|
|
|
2011-02-09 13:05:12 +00:00
|
|
|
clutter_timeline_stop (oh->timeline);
|
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
/* clean up */
|
|
|
|
g_object_unref (oh->scaler_1);
|
|
|
|
g_object_unref (oh->scaler_2);
|
|
|
|
g_object_unref (oh->timeline);
|
2006-11-21 Emmanuele Bassi <ebassi@openedhand.com>
* configure.ac: Enable debug messages also when
--enable-debug is set to "minimum".
* clutter/Makefile.am:
* clutter/clutter-debug.h: Move all debugging macros inside
this private header; make all debug macros depend on the
CLUTTER_ENABLE_DEBUG compile time define, controlled by
the --enable-debug configure switch; add G_LOG_DOMAIN define.
* clutter/clutter-main.c: Clean up the debug stuff; add
command line argument parsing using GOption; the debug
messages now are triggered like this:
CLUTTER_DEBUG=section:section:... clutter-app
or like this:
clutter-app --clutter-debug=section:section:...
where "section" is one of the sections listed in clutter-main.c,
or "all", for all sections; each section is bound to a flag,
which can be used to define a domain when adding a debug note
using the CLUTTER_NOTE() macro; the old CLUTTER_DBG() macro is
just a wrapper around that, under the CLUTTER_DEBUG_MISC domain;
CLUTTER_NOTE() is used like this:
CLUTTER_NOTE (DOMAIN, log-function);
where log function is g_printerr(), g_message(), g_warning(),
g_critical() or directly g_log() - for instance:
CLUTTER_NOTE (PANGO, g_warning ("Cache miss: %d", glyph));
will print the warning only if the "pango" flag has been
set to the CLUTTER_DEBUG envvar or passed to the --clutter-debug
command line argument.
similar to CLUTTER_SHOW_FPS, there's also the --clutter-show-fps
command line switch; also, the --display and --screen command
line switches have been added: the first overrides the DISPLAY
envvar and the second controls the X screen used by Clutter to
get the root window on the display.
* clutter/clutter-main.h:
* clutter/clutter-main.c: Add extended support for GOption
in Clutter; use clutter_init_with_args() to let Clutter
parse your own command line arguments; use instead
clutter_get_option_group() to get the GOptionGroup used by
Clutter if you want to do the parsing yourself with
g_option_context_parse(). The init sequence has been verified,
updated and moved into common functions where possible.
* clutter/pango/pangoclutter-render.c:
* clutter/*.c: Include "clutter-debug.h" where needed; use
CLUTTER_NOTE() instead of CLUTTER_DBG().
* examples/super-oh.c: Use the new clutter_init_with_args()
function, and add a --num-hands command line switch to
the SuperOH example code controlling the number of hands at
runtime.
2006-11-21 21:27:53 +00:00
|
|
|
g_free (oh->hand);
|
|
|
|
g_free (oh);
|
|
|
|
|
2009-01-27 15:18:45 +00:00
|
|
|
return EXIT_SUCCESS;
|
2006-05-29 08:59:36 +00:00
|
|
|
}
|