8a537b6299
* clutter/Makefile.am: * clutter/clutter.h: Add ClutterBindingPool to the build. * clutter/clutter-binding-pool.c: * clutter/clutter-binding-pool.h: Add ClutterBindingPool, a data structure meant to hold (key symbol, modifiers) pairs and associate them to a closure. The ClutterBindingPool can be used to install key bindings for actors and then execute closures inside the key-press-event signal handlers, removing the need for big switch() or if() blocks for each key. * clutter/clutter-event.c: Consistently use "key symbol" instead of "key value". * clutter/clutter-event.h: Add more modifier masks. * clutter/clutter-marshal.list: * tests/conform/Makefile.am: * tests/conform/test-binding-pool.c: * tests/conform/test-conform-main.c: Add ClutterBindingPool conformance test. * tests/interactive/Makefile.am: * tests/interactive/test-binding-pool.c: Add interactive test (and example code) for the ClutterBindingPool usage.
97 lines
4.6 KiB
C
97 lines
4.6 KiB
C
/*
|
|
* Clutter.
|
|
*
|
|
* An OpenGL based 'interactive canvas' library.
|
|
*
|
|
* Copyright (C) 2008 Intel Corporation.
|
|
*
|
|
* Authored By: Emmanuele Bassi <ebassi@linux.intel.com>
|
|
*
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION)
|
|
#error "Only <clutter/clutter.h> can be included directly."
|
|
#endif
|
|
|
|
#ifndef __CLUTTER_BINDING_POOL_H__
|
|
#define __CLUTTER_BINDING_POOL_H__
|
|
|
|
#include <glib-object.h>
|
|
#include <clutter/clutter-event.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
typedef struct _ClutterBindingPool ClutterBindingPool;
|
|
|
|
/**
|
|
* ClutterBindingActionFunc:
|
|
* @gobject: a #GObject
|
|
* @action_name: the name of the action
|
|
* @key_val: the key symbol
|
|
* @modifiers: bitmask of the modifier flags
|
|
*
|
|
* The prototype for the callback function registered with
|
|
* clutter_binding_pool_install_action() and invoked by
|
|
* clutter_binding_pool_activate().
|
|
*
|
|
* The function should return %TRUE if the key binding was
|
|
* handled, and return %FALSE otherwise.
|
|
*
|
|
* Since: 1.0
|
|
*/
|
|
typedef gboolean (* ClutterBindingActionFunc) (GObject *gobject,
|
|
const gchar *action_name,
|
|
guint key_val,
|
|
ClutterModifierType modifiers);
|
|
|
|
ClutterBindingPool * clutter_binding_pool_new (const gchar *name);
|
|
ClutterBindingPool * clutter_binding_pool_get_for_class (gpointer klass);
|
|
ClutterBindingPool * clutter_binding_pool_find (const gchar *name);
|
|
|
|
void clutter_binding_pool_install_action (ClutterBindingPool *pool,
|
|
const gchar *action_name,
|
|
guint key_val,
|
|
ClutterModifierType modifiers,
|
|
GCallback callback,
|
|
gpointer data,
|
|
GDestroyNotify notify);
|
|
void clutter_binding_pool_install_closure (ClutterBindingPool *pool,
|
|
const gchar *action_name,
|
|
guint key_val,
|
|
ClutterModifierType modifiers,
|
|
GClosure *closure);
|
|
|
|
gchar ** clutter_binding_pool_list_actions (ClutterBindingPool *pool);
|
|
G_CONST_RETURN gchar *clutter_binding_pool_find_action (ClutterBindingPool *pool,
|
|
guint key_val,
|
|
ClutterModifierType modifiers);
|
|
void clutter_binding_pool_remove_action (ClutterBindingPool *pool,
|
|
guint key_val,
|
|
ClutterModifierType modifiers);
|
|
|
|
gboolean clutter_binding_pool_activate (ClutterBindingPool *pool,
|
|
guint key_val,
|
|
ClutterModifierType modifiers,
|
|
GObject *gobject);
|
|
|
|
void clutter_binding_pool_block_action (ClutterBindingPool *pool,
|
|
const gchar *action_name);
|
|
void clutter_binding_pool_unblock_action (ClutterBindingPool *pool,
|
|
const gchar *action_name);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __CLUTTER_BINDING_POOL_H__ */
|