mirror of
https://github.com/brl/mutter.git
synced 2024-11-29 19:40:43 -05:00
Allow disabling motion event throttling
It might be desirable for some applications and/or platforms to get every motion event that was delivered to Clutter from the windowing backend. By adding a per-stage flag we can bypass the throttling done when processing the events. http://bugzilla.openedhand.com/show_bug.cgi?id=1665
This commit is contained in:
parent
f7850b516c
commit
56ef6727b5
@ -95,6 +95,7 @@ struct _ClutterStagePrivate
|
||||
guint is_cursor_visible : 1;
|
||||
guint is_user_resizable : 1;
|
||||
guint use_fog : 1;
|
||||
guint throttle_motion_events : 1;
|
||||
};
|
||||
|
||||
enum
|
||||
@ -465,7 +466,8 @@ _clutter_stage_process_queued_events (ClutterStage *stage)
|
||||
next_event = l->next ? l->next->data : NULL;
|
||||
|
||||
/* Skip consecutive motion events */
|
||||
if (next_event &&
|
||||
if (priv->throttle_motion_events &&
|
||||
next_event &&
|
||||
event->type == CLUTTER_MOTION &&
|
||||
(next_event->type == CLUTTER_MOTION ||
|
||||
next_event->type == CLUTTER_LEAVE))
|
||||
@ -1020,6 +1022,7 @@ clutter_stage_init (ClutterStage *self)
|
||||
priv->is_user_resizable = FALSE;
|
||||
priv->is_cursor_visible = TRUE;
|
||||
priv->use_fog = FALSE;
|
||||
priv->throttle_motion_events = TRUE;
|
||||
|
||||
priv->color = default_stage_color;
|
||||
|
||||
@ -2055,3 +2058,52 @@ _clutter_stage_get_default_window (void)
|
||||
|
||||
return _clutter_stage_get_window (CLUTTER_STAGE (stage));
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_stage_set_throttle_motion_events:
|
||||
* @stage: a #ClutterStage
|
||||
* @throttle: %TRUE to throttle motion events
|
||||
*
|
||||
* Sets whether motion events received between redraws should
|
||||
* be throttled or not. If motion events are throttled, those
|
||||
* events received by the windowing system between redraws will
|
||||
* be compressed so that only the last event will be propagated
|
||||
* to the @stage and its actors.
|
||||
*
|
||||
* This function should only be used if you want to have all
|
||||
* the motion events delivered to your application code.
|
||||
*
|
||||
* Since: 1.0
|
||||
*/
|
||||
void
|
||||
clutter_stage_set_throttle_motion_events (ClutterStage *stage,
|
||||
gboolean throttle)
|
||||
{
|
||||
ClutterStagePrivate *priv;
|
||||
|
||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||
|
||||
priv = stage->priv;
|
||||
|
||||
if (priv->throttle_motion_events != throttle)
|
||||
priv->throttle_motion_events = throttle;
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_stage_get_throttle_motion_events:
|
||||
* @stage: a #ClutterStage
|
||||
*
|
||||
* Retrieves the value set with clutter_stage_set_throttle_motion_events()
|
||||
*
|
||||
* Return value: %TRUE if the motion events are being throttled,
|
||||
* and %FALSE otherwise
|
||||
*
|
||||
* Since: 1.0
|
||||
*/
|
||||
gboolean
|
||||
clutter_stage_get_throttle_motion_events (ClutterStage *stage)
|
||||
{
|
||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE);
|
||||
|
||||
return stage->priv->throttle_motion_events;
|
||||
}
|
||||
|
@ -237,15 +237,17 @@ void clutter_stage_get_fog (ClutterStage *stage,
|
||||
void clutter_stage_set_key_focus (ClutterStage *stage,
|
||||
ClutterActor *actor);
|
||||
ClutterActor * clutter_stage_get_key_focus (ClutterStage *stage);
|
||||
|
||||
/* New experiental calls */
|
||||
void clutter_stage_ensure_current (ClutterStage *stage);
|
||||
void clutter_stage_queue_redraw (ClutterStage *stage);
|
||||
gboolean clutter_stage_is_default (ClutterStage *stage);
|
||||
void clutter_stage_ensure_viewport (ClutterStage *stage);
|
||||
void clutter_stage_ensure_redraw (ClutterStage *stage);
|
||||
|
||||
/* Commodity macro */
|
||||
void clutter_stage_set_throttle_motion_events (ClutterStage *stage,
|
||||
gboolean throttle);
|
||||
gboolean clutter_stage_get_throttle_motion_events (ClutterStage *stage);
|
||||
|
||||
/* Commodity macro, for mallum only */
|
||||
#define clutter_stage_add(stage,actor) G_STMT_START { \
|
||||
if (CLUTTER_IS_STAGE ((stage)) && CLUTTER_IS_ACTOR ((actor))) \
|
||||
{ \
|
||||
|
@ -510,6 +510,8 @@ clutter_stage_event
|
||||
clutter_stage_set_key_focus
|
||||
clutter_stage_get_key_focus
|
||||
clutter_stage_read_pixels
|
||||
clutter_stage_set_throttle_motion_events
|
||||
clutter_stage_get_throttle_motion_events
|
||||
|
||||
<SUBSECTION>
|
||||
ClutterPerspective
|
||||
|
Loading…
Reference in New Issue
Block a user