Compare commits
	
		
			268 Commits
		
	
	
		
			3.34.2
			...
			wip/carlos
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 1c31fe8e65 | ||
|   | 819ea8c0a6 | ||
|   | f0241114f6 | ||
|   | 987cd7e821 | ||
|   | a4a7f9a660 | ||
|   | 993b0b2758 | ||
|   | 9bddda584b | ||
|   | 81b0802eab | ||
|   | 5de6d032d6 | ||
|   | a4d39bdabc | ||
|   | 4e12be36d1 | ||
|   | 1c70f6894f | ||
|   | ef2acde122 | ||
|   | a8c6fab3b8 | ||
|   | b8c8b59dc8 | ||
|   | efe698f6e1 | ||
|   | 75ad578a7d | ||
|   | 77d0ec12b1 | ||
|   | 11f3db6693 | ||
|   | c5b89d9a86 | ||
|   | ed4c96c751 | ||
|   | 2001bdd863 | ||
|   | 9577475453 | ||
|   | ea099a871c | ||
|   | 454e104d6f | ||
|   | 127df62a02 | ||
|   | f4bf48a7d7 | ||
|   | 353d7909f6 | ||
|   | a586f6a152 | ||
|   | e44bd2edb4 | ||
|   | 8598b654ba | ||
|   | a1116bc6c8 | ||
|   | 8e172aeecb | ||
|   | 51f68f1054 | ||
|   | 92375c75f8 | ||
|   | 22d1febf3c | ||
|   | 5aa971b177 | ||
|   | e922c640ef | ||
|   | f5050a4f80 | ||
|   | 8cac82318f | ||
|   | 23e9fd3dfa | ||
|   | 13fd213064 | ||
|   | c69dc7566b | ||
|   | c6f5b7f1a1 | ||
|   | 1076b31464 | ||
|   | 0d006bc8d9 | ||
|   | 794d3239c7 | ||
|   | e5af790acb | ||
|   | 48639ac5da | ||
|   | e7b2f9603e | ||
|   | 46b3811e22 | ||
|   | 7adaaab2d6 | ||
|   | 289e24f1f7 | ||
|   | c4d1e150ba | ||
|   | 293ec0a1cb | ||
|   | 24b38a5059 | ||
|   | c74f4f6340 | ||
|   | 3e9f8471fc | ||
|   | 0a41f0f855 | ||
|   | 375d35be60 | ||
|   | 6da568e29a | ||
|   | c039764d52 | ||
|   | d3afe4308a | ||
|   | d48fec8855 | ||
|   | d992722c24 | ||
|   | 81bb4f0051 | ||
|   | b078917500 | ||
|   | ec1c94d4a7 | ||
|   | faad63adce | ||
|   | 244f55df28 | ||
|   | f7ad7e6c0f | ||
|   | e0ebc4de60 | ||
|   | 14bb104ef0 | ||
|   | f3b9fc8159 | ||
|   | 8907a29912 | ||
|   | a5f986259f | ||
|   | bcc519e4ee | ||
|   | 044238b503 | ||
|   | 03b59f9e19 | ||
|   | 7193938d27 | ||
|   | 5afec87b96 | ||
|   | a4f51da184 | ||
|   | 0545b93232 | ||
|   | 9cbf83d59c | ||
|   | 07ca100130 | ||
|   | 6944839ab6 | ||
|   | 4a76f66a54 | ||
|   | bacbbbd628 | ||
|   | c85fb107c0 | ||
|   | 13f10e36e4 | ||
|   | 2644e54c51 | ||
|   | 0e5a5df5fe | ||
|   | 806ebc464a | ||
|   | 54ac1f6b59 | ||
|   | 9b16b74b5d | ||
|   | 9172901458 | ||
|   | ffa0a24848 | ||
|   | efe5bed5b4 | ||
|   | e865fcc460 | ||
|   | 16eb461054 | ||
|   | c11ef6ef07 | ||
|   | 95eda361c1 | ||
|   | 662c76c4fc | ||
|   | ff799a1abe | ||
|   | 155b7bf569 | ||
|   | 47155ed524 | ||
|   | db91439bb0 | ||
|   | 77aad0869f | ||
|   | dc1a28c42a | ||
|   | 955b27637c | ||
|   | 1f5b403524 | ||
|   | 5e87d67e5f | ||
|   | f133de2dd4 | ||
|   | 60800d2313 | ||
|   | db90c0d509 | ||
|   | e5b0f474ab | ||
|   | 1688cf7c44 | ||
|   | 2202c0d02e | ||
|   | dbb95cbe5f | ||
|   | ae238d1d4d | ||
|   | 6051712919 | ||
|   | 6bfa61a3a7 | ||
|   | cf89e4d2cd | ||
|   | d47324e8d7 | ||
|   | ee4638ef5c | ||
|   | 6ee7c0f486 | ||
|   | f4f7e31303 | ||
|   | 7c036c5896 | ||
|   | 793c2ac58d | ||
|   | 13d9e4db30 | ||
|   | e84dbd7faf | ||
|   | 711023ea93 | ||
|   | 468dc99dc9 | ||
|   | 6b8ee80fd0 | ||
|   | 17e39ad79c | ||
|   | 46aeb9634f | ||
|   | 3f9c5d04d4 | ||
|   | 40a76590dd | ||
|   | f2b3dd318f | ||
|   | 942883577e | ||
|   | 23fa59b77c | ||
|   | 9678fd5306 | ||
|   | 563e7139b6 | ||
|   | 2e9faaf67a | ||
|   | 4918893326 | ||
|   | 3e5960b5a2 | ||
|   | b294e62aed | ||
|   | c63f54b7a7 | ||
|   | 3186e45ae5 | ||
|   | ed7afd9e80 | ||
|   | 683f18639e | ||
|   | e17494f3bd | ||
|   | c36c865987 | ||
|   | a99f579127 | ||
|   | acc7b83322 | ||
|   | 95662fd3d8 | ||
|   | b3980f7a94 | ||
|   | ac626f7334 | ||
|   | b622a8b55d | ||
|   | b6170dbe7b | ||
|   | d6bf4800ed | ||
|   | a60457c2d8 | ||
|   | 33d1bae03f | ||
|   | 013b336690 | ||
|   | 096d78479b | ||
|   | 68fca552d7 | ||
|   | 18e0a8f7bf | ||
|   | cd2ee44216 | ||
|   | ebf9ac091d | ||
|   | cf791c09f0 | ||
|   | 1d8807a171 | ||
|   | f18e2d2e62 | ||
|   | 71c3f4af31 | ||
|   | 3078394951 | ||
|   | a7f4f5b291 | ||
|   | bd1630a12c | ||
|   | 67d5ebb187 | ||
|   | ba7b8a5de3 | ||
|   | d54c548aac | ||
|   | f01db80387 | ||
|   | 5e0989532e | ||
|   | 673f4295e8 | ||
|   | 1f04b1ae69 | ||
|   | 26a7387f40 | ||
|   | bd5266a05e | ||
|   | eb3ffeff0a | ||
|   | 0731eb629c | ||
|   | 34a38827b7 | ||
|   | 3076895e98 | ||
|   | 0e4c23c985 | ||
|   | fb49e9def7 | ||
|   | 45e77c1d87 | ||
|   | cf107c89b8 | ||
|   | 6a8830a551 | ||
|   | 4523251849 | ||
|   | 5f4e8789df | ||
|   | eaf0aa1f07 | ||
|   | 96da0c60bd | ||
|   | da36575d7f | ||
|   | 7716a418ce | ||
|   | 6ab2e30fff | ||
|   | 8b0289a5ba | ||
|   | d810c0576d | ||
|   | 82f56054d4 | ||
|   | de362537c6 | ||
|   | ba9fb16048 | ||
|   | 148cba3270 | ||
|   | c5bb2e3f56 | ||
|   | 049e7882b7 | ||
|   | f297a5faa5 | ||
|   | 40e6aa7d94 | ||
|   | 668be1f4bd | ||
|   | a444a4c5f5 | ||
|   | 05da4a6094 | ||
|   | db8fcc0537 | ||
|   | 86a5358812 | ||
|   | ff8ed70f84 | ||
|   | 179d5ba6a6 | ||
|   | 98892391d7 | ||
|   | 45a8806e65 | ||
|   | e1fa0734a9 | ||
|   | 8665084df1 | ||
|   | 62072838c9 | ||
|   | c5b7d73ce2 | ||
|   | 0556138b9f | ||
|   | d57dbe1d4c | ||
|   | 5d646a5d6f | ||
|   | e82a657cd9 | ||
|   | 8c89ea5f0a | ||
|   | 8cfa8dc0c1 | ||
|   | bdf5e3f357 | ||
|   | 94682e69aa | ||
|   | 160cc9182d | ||
|   | cd293f764e | ||
|   | a5d0cfe8fb | ||
|   | ba0f17f5b1 | ||
|   | 16875340cb | ||
|   | 959a418cc3 | ||
|   | 7c7ccb2e43 | ||
|   | cada2b54fe | ||
|   | 3ecae81809 | ||
|   | 4f2b217a6a | ||
|   | b1a1d4e13d | ||
|   | f7315c9a36 | ||
|   | 9ac52f0340 | ||
|   | f059466337 | ||
|   | dcd0f4322a | ||
|   | 65d8f27b6b | ||
|   | bdceb3acdb | ||
|   | 8e204e036a | ||
|   | 553211dd81 | ||
|   | 97010ac64d | ||
|   | c2d03bf73e | ||
|   | 22c8f179d2 | ||
|   | d4ff5e2d31 | ||
|   | 2773e8adf8 | ||
|   | e17d70a592 | ||
|   | da213febdc | ||
|   | 7c2e926c44 | ||
|   | c474ad6a53 | ||
|   | 877ecc1bb4 | ||
|   | 0d0286d59e | ||
|   | 23f77a1b63 | ||
|   | 317ce05a27 | ||
|   | a8155a0471 | ||
|   | 5e7fa20f06 | ||
|   | 3a688988e0 | ||
|   | 34ff206604 | 
| @@ -1,4 +1,4 @@ | ||||
| image: registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||
| image: registry.gitlab.gnome.org/gnome/mutter/master:v3 | ||||
|  | ||||
| stages: | ||||
|  - review | ||||
|   | ||||
| @@ -1,39 +1,28 @@ | ||||
| # Rebuild and push with | ||||
| # | ||||
| #     cd .gitlab-ci/ | ||||
| #     docker build --no-cache -t registry.gitlab.gnome.org/gnome/mutter/master:v2 . | ||||
| #     docker push registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||
| #     docker build --no-cache -t registry.gitlab.gnome.org/gnome/mutter/master:v3 . | ||||
| #     docker push registry.gitlab.gnome.org/gnome/mutter/master:v3 | ||||
| # | ||||
|  | ||||
| FROM fedora:30 | ||||
| FROM fedora:31 | ||||
|  | ||||
| RUN dnf -y update && dnf -y upgrade && \ | ||||
|     dnf install -y 'dnf-command(builddep)' && \ | ||||
|     dnf install -y 'dnf-command(copr)' && \ | ||||
|     dnf copr enable -y fmuellner/gnome-shell-ci && \ | ||||
|     dnf copr enable -y jadahl/mutter-ci && \ | ||||
|     dnf copr enable -y hergertme/sysprof-3 && \ | ||||
|     dnf -y update && dnf -y upgrade && \ | ||||
|  | ||||
|     dnf builddep -y mutter && \ | ||||
|  | ||||
|     # Until Fedora catches up with meson build-deps | ||||
|     dnf install -y meson xorg-x11-server-Xorg gnome-settings-daemon-devel egl-wayland-devel xorg-x11-server-Xwayland && \ | ||||
|  | ||||
|     # Until Fedora catches up with mesa bug fixes | ||||
|     dnf upgrade -y mesa-dri-drivers mesa-libEGL && \ | ||||
|     # Until Fedora catches up with new build-deps | ||||
|     dnf install -y 'pkgconfig(graphene-gobject-1.0)' 'pkgconfig(sysprof-capture-3)' && \ | ||||
|  | ||||
|     # For running unit tests | ||||
|     dnf install -y xorg-x11-server-Xvfb mesa-dri-drivers dbus dbus-x11 '*/xvfb-run' gdm-lib accountsservice-libs && \ | ||||
|  | ||||
|     dnf install -y sysprof-devel && \ | ||||
|  | ||||
|     dnf install -y intltool redhat-rpm-config make && \ | ||||
|     dnf install -y xorg-x11-server-Xvfb mesa-dri-drivers dbus dbus-x11 '*/xvfb-run' gdm-lib accountsservice-libs gnome-control-center && \ | ||||
|  | ||||
|     # GNOME Shell | ||||
|     dnf builddep -y gnome-shell --setopt=install_weak_deps=False && \ | ||||
|     # New dep this cycle | ||||
|     dnf install -y 'pkgconfig(gnome-autoar-0)' && \ | ||||
|     dnf remove -y gnome-bluetooth-libs-devel dbus-glib-devel upower-devel python3-devel && \ | ||||
|     dnf remove -y --noautoremove mutter mutter-devel && \ | ||||
|  | ||||
|   | ||||
| @@ -40,11 +40,12 @@ function commit_message_subject_is_compliant() { | ||||
|   return 0 | ||||
| } | ||||
|  | ||||
| RET=0 | ||||
| for commit in $commits; do | ||||
|   commit_short=$(echo $commit | cut -c -8) | ||||
|  | ||||
|   if ! commit_message_has_url $commit; then | ||||
|     echo "Missing merge request or issue URL on commit $commit_short" | ||||
|     echo "Commit $commit_short needs a merge request or issue URL" | ||||
|     exit 1 | ||||
|   fi | ||||
|  | ||||
| @@ -52,6 +53,8 @@ for commit in $commits; do | ||||
|   if [ $? != 0 ]; then | ||||
|     echo "Commit message for $commit_short is not compliant:" | ||||
|     echo "$errors" | ||||
|     exit 1 | ||||
|     RET=1 | ||||
|   fi | ||||
| done | ||||
|  | ||||
| exit $RET | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| #!/usr/bin/bash | ||||
|  | ||||
| mutter_branch=$(git describe --contains --all HEAD) | ||||
| gnome_shell_target= | ||||
|  | ||||
| git clone https://gitlab.gnome.org/GNOME/gnome-shell.git | ||||
| @@ -26,8 +25,7 @@ if [ "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME" ]; then | ||||
| fi | ||||
|  | ||||
| if [ -z "$gnome_shell_target" ]; then | ||||
|   gnome_shell_target=$(git branch -r -l origin/$mutter_branch) | ||||
|   gnome_shell_target=${gnome_shell_target:-$(git branch -r -l ${mutter_branch#remotes/})} | ||||
|   gnome_shell_target=$(git branch -r -l origin/$CI_COMMIT_REF_NAME) | ||||
|   gnome_shell_target=${gnome_shell_target:-origin/master} | ||||
|   echo Using $gnome_shell_target instead | ||||
| fi | ||||
|   | ||||
							
								
								
									
										15
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								NEWS
									
									
									
									
									
								
							| @@ -1,3 +1,18 @@ | ||||
| 3.35.1 | ||||
| ====== | ||||
| * Fix immediate screen blank after releaseing inhibitor [Tim; #573] | ||||
| * Respond to frame callbacks regardless of damage [Jonas; !839] | ||||
| * selection [Carlos; !842] | ||||
| * Fix Night Light on wayland [Jonas; !840] | ||||
| * Fix various copy+paste/DND regressions [Carlos; !848, #789, #842, | ||||
|   #793, #845, #854] | ||||
| * Misc. bug fixes and cleanups [Daniel, Marco, Jonas, Georges; | ||||
|   !841, !764, !837, !846] | ||||
|  | ||||
| Contributors: | ||||
|   Marco Trevisan (Treviño), Carlos Garnacho, Tim Klocke, | ||||
|   Georges Basile Stavracas Neto, Daniel van Vugt, Jonas Ådahl | ||||
|  | ||||
| 3.34.1 | ||||
| ====== | ||||
| * Fix startup of X11 session services on wayland [Carlos; #771] | ||||
|   | ||||
| @@ -310,11 +310,7 @@ cally_actor_finalize (GObject *obj) | ||||
|  | ||||
|   _cally_actor_clean_action_list (cally_actor); | ||||
|  | ||||
|   if (priv->action_idle_handler) | ||||
|     { | ||||
|       g_source_remove (priv->action_idle_handler); | ||||
|       priv->action_idle_handler = 0; | ||||
|     } | ||||
|   g_clear_handle_id (&priv->action_idle_handler, g_source_remove); | ||||
|  | ||||
|   if (priv->action_queue) | ||||
|     { | ||||
| @@ -657,7 +653,7 @@ cally_actor_get_extents (AtkComponent *component, | ||||
|   ClutterActor *actor      = NULL; | ||||
|   gint          top_level_x, top_level_y; | ||||
|   gfloat        f_width, f_height; | ||||
|   ClutterVertex verts[4]; | ||||
|   graphene_point3d_t verts[4]; | ||||
|   ClutterActor  *stage = NULL; | ||||
|  | ||||
|   g_return_if_fail (CALLY_IS_ACTOR (component)); | ||||
|   | ||||
| @@ -75,8 +75,8 @@ struct _CallyRootPrivate | ||||
|   GSList *stage_list; | ||||
|  | ||||
|   /* signals id */ | ||||
|   guint stage_added_id; | ||||
|   guint stage_removed_id; | ||||
|   gulong stage_added_id; | ||||
|   gulong stage_removed_id; | ||||
| }; | ||||
|  | ||||
| G_DEFINE_TYPE_WITH_PRIVATE (CallyRoot, cally_root,  ATK_TYPE_GOBJECT_ACCESSIBLE) | ||||
| @@ -149,11 +149,9 @@ cally_root_finalize (GObject *object) | ||||
|  | ||||
|   stage_manager = atk_gobject_accessible_get_object (ATK_GOBJECT_ACCESSIBLE (root)); | ||||
|  | ||||
|   g_signal_handler_disconnect (stage_manager, | ||||
|                                root->priv->stage_added_id); | ||||
|   g_clear_signal_handler (&root->priv->stage_added_id, stage_manager); | ||||
|  | ||||
|   g_signal_handler_disconnect (stage_manager, | ||||
|                                root->priv->stage_added_id); | ||||
|   g_clear_signal_handler (&root->priv->stage_removed_id, stage_manager); | ||||
|  | ||||
|   G_OBJECT_CLASS (cally_root_parent_class)->finalize (object); | ||||
| } | ||||
|   | ||||
| @@ -247,11 +247,7 @@ cally_text_finalize   (GObject *obj) | ||||
| /*   g_object_unref (cally_text->priv->textutil); */ | ||||
| /*   cally_text->priv->textutil = NULL; */ | ||||
|  | ||||
|   if (cally_text->priv->insert_idle_handler) | ||||
|     { | ||||
|       g_source_remove (cally_text->priv->insert_idle_handler); | ||||
|       cally_text->priv->insert_idle_handler = 0; | ||||
|     } | ||||
|   g_clear_handle_id (&cally_text->priv->insert_idle_handler, g_source_remove); | ||||
|  | ||||
|   G_OBJECT_CLASS (cally_text_parent_class)->finalize (obj); | ||||
| } | ||||
| @@ -1438,7 +1434,7 @@ static void cally_text_get_character_extents (AtkText *text, | ||||
|   PangoLayout *layout; | ||||
|   PangoRectangle extents; | ||||
|   const gchar *text_value; | ||||
|   ClutterVertex verts[4]; | ||||
|   graphene_point3d_t verts[4]; | ||||
|  | ||||
|   actor = CALLY_GET_CLUTTER_ACTOR (text); | ||||
|   if (actor == NULL) /* State is defunct */ | ||||
| @@ -2294,7 +2290,7 @@ _cally_misc_get_index_at_point (ClutterText *clutter_text, | ||||
|   gint index, x_window, y_window, x_toplevel, y_toplevel; | ||||
|   gint x_temp, y_temp; | ||||
|   gboolean ret; | ||||
|   ClutterVertex verts[4]; | ||||
|   graphene_point3d_t verts[4]; | ||||
|   PangoLayout *layout; | ||||
|   gint x_layout, y_layout; | ||||
|  | ||||
|   | ||||
| @@ -1,98 +0,0 @@ | ||||
| /* CALLY - The Clutter Accessibility Implementation Library | ||||
|  * | ||||
|  * Copyright (C) 2009 Igalia, S.L. | ||||
|  * | ||||
|  * Author: Alejandro Piñeiro Iglesias <apinheiro@igalia.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, write to the | ||||
|  * Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||||
|  * Boston, MA 02111-1307, USA. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * SECTION:cally-texture | ||||
|  * @Title: CallyTexture | ||||
|  * @short_description: Implementation of the ATK interfaces for a #ClutterTexture | ||||
|  * @see_also: #ClutterTexture | ||||
|  * | ||||
|  * #CallyTexture implements the required ATK interfaces of #ClutterTexture | ||||
|  * | ||||
|  * In particular it sets a proper role for the texture. | ||||
|  */ | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #define CLUTTER_DISABLE_DEPRECATION_WARNINGS | ||||
|  | ||||
| #include "cally-texture.h" | ||||
| #include "cally-actor-private.h" | ||||
|  | ||||
| #include "deprecated/clutter-texture.h" | ||||
|  | ||||
| /* AtkObject */ | ||||
| static void                  cally_texture_real_initialize (AtkObject *obj, | ||||
|                                                            gpointer   data); | ||||
|  | ||||
| G_DEFINE_TYPE (CallyTexture, cally_texture, CALLY_TYPE_ACTOR) | ||||
|  | ||||
| static void | ||||
| cally_texture_class_init (CallyTextureClass *klass) | ||||
| { | ||||
| /*   GObjectClass   *gobject_class = G_OBJECT_CLASS (klass); */ | ||||
|   AtkObjectClass *class         = ATK_OBJECT_CLASS (klass); | ||||
|  | ||||
|   class->initialize      = cally_texture_real_initialize; | ||||
| } | ||||
|  | ||||
| static void | ||||
| cally_texture_init (CallyTexture *texture) | ||||
| { | ||||
|   /* nothing to do yet */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * cally_texture_new: | ||||
|  * @actor: a #ClutterActor | ||||
|  * | ||||
|  * Creates a new #CallyTexture for the given @actor. @actor must be | ||||
|  * a #ClutterTexture. | ||||
|  * | ||||
|  * Return value: the newly created #AtkObject | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| AtkObject* | ||||
| cally_texture_new (ClutterActor *actor) | ||||
| { | ||||
|   GObject   *object     = NULL; | ||||
|   AtkObject *accessible = NULL; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_TEXTURE (actor), NULL); | ||||
|  | ||||
|   object = g_object_new (CALLY_TYPE_TEXTURE, NULL); | ||||
|  | ||||
|   accessible = ATK_OBJECT (object); | ||||
|   atk_object_initialize (accessible, actor); | ||||
|  | ||||
|   return accessible; | ||||
| } | ||||
|  | ||||
| static void | ||||
| cally_texture_real_initialize (AtkObject *obj, | ||||
|                               gpointer   data) | ||||
| { | ||||
|   ATK_OBJECT_CLASS (cally_texture_parent_class)->initialize (obj, data); | ||||
|  | ||||
|   /* default role */ | ||||
|   obj->role = ATK_ROLE_IMAGE; | ||||
| } | ||||
| @@ -1,84 +0,0 @@ | ||||
| /* CALLY - The Clutter Accessibility Implementation Library | ||||
|  * | ||||
|  * Copyright (C) 2009 Igalia, S.L. | ||||
|  * | ||||
|  * Author: Alejandro Piñeiro Iglesias <apinheiro@igalia.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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef __CALLY_TEXTURE_H__ | ||||
| #define __CALLY_TEXTURE_H__ | ||||
|  | ||||
| #if !defined(__CALLY_H_INSIDE__) && !defined(CLUTTER_COMPILATION) | ||||
| #error "Only <cally/cally.h> can be included directly." | ||||
| #endif | ||||
|  | ||||
| #include <clutter/clutter.h> | ||||
| #include <cally/cally-actor.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| #define CALLY_TYPE_TEXTURE            (cally_texture_get_type ()) | ||||
| #define CALLY_TEXTURE(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), CALLY_TYPE_TEXTURE, CallyTexture)) | ||||
| #define CALLY_TEXTURE_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), CALLY_TYPE_TEXTURE, CallyTextureClass)) | ||||
| #define CALLY_IS_TEXTURE(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CALLY_TYPE_TEXTURE)) | ||||
| #define CALLY_IS_TEXTURE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), CALLY_TYPE_TEXTURE)) | ||||
| #define CALLY_TEXTURE_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), CALLY_TYPE_TEXTURE, CallyTextureClass)) | ||||
|  | ||||
| typedef struct _CallyTexture        CallyTexture; | ||||
| typedef struct _CallyTextureClass   CallyTextureClass; | ||||
| typedef struct _CallyTexturePrivate CallyTexturePrivate; | ||||
|  | ||||
| /** | ||||
|  * CallyTexture: | ||||
|  * | ||||
|  * The <structname>CallyTexture</structname> structure contains only | ||||
|  * private data and should be accessed using the provided API | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| struct _CallyTexture | ||||
| { | ||||
|   /*< private >*/ | ||||
|   CallyActor parent; | ||||
|  | ||||
|   CallyTexturePrivate *priv; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * CallyTextureClass: | ||||
|  * | ||||
|  * The <structname>CallyTextureClass</structname> structure contains | ||||
|  * only private data | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| struct _CallyTextureClass | ||||
| { | ||||
|   /*< private >*/ | ||||
|   CallyActorClass parent_class; | ||||
|  | ||||
|   /* padding for future expansion */ | ||||
|   gpointer _padding_dummy[8]; | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType      cally_texture_get_type (void) G_GNUC_CONST; | ||||
| CLUTTER_EXPORT | ||||
| AtkObject *cally_texture_new      (ClutterActor *actor); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CALLY_TEXTURE_H__ */ | ||||
| @@ -39,7 +39,6 @@ | ||||
| #include "cally-group.h" | ||||
| #include "cally-stage.h" | ||||
| #include "cally-text.h" | ||||
| #include "cally-texture.h" | ||||
| #include "cally-rectangle.h" | ||||
| #include "cally-clone.h" | ||||
|  | ||||
| @@ -56,7 +55,6 @@ CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_ACTOR, cally_actor, cally_actor_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_GROUP, cally_group, cally_group_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_STAGE, cally_stage, cally_stage_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_TEXT, cally_text, cally_text_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_TEXTURE, cally_texture, cally_texture_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_RECTANGLE, cally_rectangle, cally_rectangle_new) | ||||
| CALLY_ACCESSIBLE_FACTORY (CALLY_TYPE_CLONE, cally_clone, cally_clone_new) | ||||
|  | ||||
| @@ -78,7 +76,6 @@ cally_accessibility_init (void) | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_GROUP, cally_group); | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_STAGE, cally_stage); | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_TEXT, cally_text); | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_TEXTURE, cally_texture); | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_RECTANGLE, cally_rectangle); | ||||
|   CALLY_ACTOR_SET_FACTORY (CLUTTER_TYPE_CLONE, cally_clone); | ||||
|  | ||||
|   | ||||
| @@ -32,7 +32,6 @@ | ||||
| #include "cally-root.h" | ||||
| #include "cally-stage.h" | ||||
| #include "cally-text.h" | ||||
| #include "cally-texture.h" | ||||
| #include "cally-util.h" | ||||
|  | ||||
| #undef __CALLY_H_INSIDE__ | ||||
|   | ||||
| @@ -340,7 +340,7 @@ clutter_actor_box_contains (const ClutterActorBox *box, | ||||
| /** | ||||
|  * clutter_actor_box_from_vertices: | ||||
|  * @box: a #ClutterActorBox | ||||
|  * @verts: (array fixed-size=4): array of four #ClutterVertex | ||||
|  * @verts: (array fixed-size=4): array of four #graphene_point3d_t | ||||
|  * | ||||
|  * Calculates the bounding box represented by the four vertices; for details | ||||
|  * of the vertex array see clutter_actor_get_abs_allocation_vertices(). | ||||
| @@ -348,8 +348,8 @@ clutter_actor_box_contains (const ClutterActorBox *box, | ||||
|  * Since: 1.0 | ||||
|  */ | ||||
| void | ||||
| clutter_actor_box_from_vertices (ClutterActorBox     *box, | ||||
|                                  const ClutterVertex  verts[]) | ||||
| clutter_actor_box_from_vertices (ClutterActorBox          *box, | ||||
|                                  const graphene_point3d_t  verts[]) | ||||
| { | ||||
|   gfloat x_1, x_2, y_1, y_2; | ||||
|  | ||||
|   | ||||
| @@ -51,7 +51,7 @@ | ||||
| struct _ClutterActorMetaPrivate | ||||
| { | ||||
|   ClutterActor *actor; | ||||
|   guint destroy_id; | ||||
|   gulong destroy_id; | ||||
|  | ||||
|   gchar *name; | ||||
|  | ||||
| @@ -91,11 +91,7 @@ clutter_actor_meta_real_set_actor (ClutterActorMeta *meta, | ||||
|   if (meta->priv->actor == actor) | ||||
|     return; | ||||
|  | ||||
|   if (meta->priv->destroy_id != 0) | ||||
|     { | ||||
|       g_signal_handler_disconnect (meta->priv->actor, meta->priv->destroy_id); | ||||
|       meta->priv->destroy_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&meta->priv->destroy_id, meta->priv->actor); | ||||
|  | ||||
|   meta->priv->actor = actor; | ||||
|  | ||||
| @@ -162,8 +158,8 @@ clutter_actor_meta_finalize (GObject *gobject) | ||||
| { | ||||
|   ClutterActorMetaPrivate *priv = CLUTTER_ACTOR_META (gobject)->priv; | ||||
|  | ||||
|   if (priv->destroy_id != 0 && priv->actor != NULL) | ||||
|     g_signal_handler_disconnect (priv->actor, priv->destroy_id); | ||||
|   if (priv->actor != NULL) | ||||
|     g_clear_signal_handler (&priv->destroy_id, priv->actor); | ||||
|  | ||||
|   g_free (priv->name); | ||||
|  | ||||
|   | ||||
| @@ -135,7 +135,7 @@ struct _AnchorCoord | ||||
|     } fraction; | ||||
|  | ||||
|     /* Use when is_fractional == FALSE */ | ||||
|     ClutterVertex units; | ||||
|     graphene_point3d_t units; | ||||
|   } v; | ||||
| }; | ||||
|  | ||||
| @@ -163,7 +163,7 @@ struct _SizeRequest | ||||
| struct _ClutterLayoutInfo | ||||
| { | ||||
|   /* fixed position coordinates */ | ||||
|   ClutterPoint fixed_pos; | ||||
|   graphene_point_t fixed_pos; | ||||
|  | ||||
|   ClutterMargin margin; | ||||
|  | ||||
| @@ -173,8 +173,8 @@ struct _ClutterLayoutInfo | ||||
|   guint x_expand : 1; | ||||
|   guint y_expand : 1; | ||||
|  | ||||
|   ClutterSize minimum; | ||||
|   ClutterSize natural; | ||||
|   graphene_size_t minimum; | ||||
|   graphene_size_t natural; | ||||
| }; | ||||
|  | ||||
| const ClutterLayoutInfo *       _clutter_actor_get_layout_info_or_defaults      (ClutterActor *self); | ||||
| @@ -203,13 +203,13 @@ struct _ClutterTransformInfo | ||||
|   AnchorCoord anchor; | ||||
|  | ||||
|   /* translation */ | ||||
|   ClutterVertex translation; | ||||
|   graphene_point3d_t translation; | ||||
|  | ||||
|   /* z_position */ | ||||
|   gfloat z_position; | ||||
|  | ||||
|   /* transformation center */ | ||||
|   ClutterPoint pivot; | ||||
|   graphene_point_t pivot; | ||||
|   gfloat pivot_z; | ||||
|  | ||||
|   CoglMatrix transform; | ||||
| @@ -274,6 +274,9 @@ void                            _clutter_actor_set_enable_paint_unmapped | ||||
| void                            _clutter_actor_set_has_pointer                          (ClutterActor *self, | ||||
|                                                                                          gboolean      has_pointer); | ||||
|  | ||||
| void                            _clutter_actor_set_has_key_focus                        (ClutterActor *self, | ||||
|                                                                                          gboolean      has_key_focus); | ||||
|  | ||||
| void                            _clutter_actor_queue_redraw_with_clip                   (ClutterActor             *self, | ||||
|                                                                                          ClutterRedrawFlags        flags, | ||||
|                                                                                          const ClutterPaintVolume *clip_volume); | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -233,8 +233,7 @@ struct _ClutterActorClass | ||||
|                                  ClutterActor          *old_parent); | ||||
|  | ||||
|   void (* destroy)              (ClutterActor          *self); | ||||
|   void (* pick)                 (ClutterActor          *actor, | ||||
|                                  const ClutterColor    *color); | ||||
|   void (* pick)                 (ClutterActor          *actor); | ||||
|  | ||||
|   gboolean (* queue_redraw)     (ClutterActor          *actor, | ||||
|                                  ClutterActor          *leaf_that_queued, | ||||
| @@ -354,6 +353,10 @@ void                            clutter_actor_paint | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_continue_paint                    (ClutterActor                *self); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_pick                              (ClutterActor                *actor); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_continue_pick                     (ClutterActor                *actor); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_queue_redraw                      (ClutterActor                *self); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_queue_redraw_with_clip            (ClutterActor                *self, | ||||
| @@ -431,7 +434,7 @@ void                            clutter_actor_get_allocation_box | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_get_allocation_vertices           (ClutterActor                *self, | ||||
|                                                                                  ClutterActor                *ancestor, | ||||
|                                                                                  ClutterVertex                verts[]); | ||||
|                                                                                  graphene_point3d_t          *verts); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                        clutter_actor_has_allocation                    (ClutterActor                *self); | ||||
| CLUTTER_EXPORT | ||||
| @@ -817,16 +820,16 @@ gboolean                        clutter_actor_transform_stage_point | ||||
|                                                                                  gfloat                     *y_out); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_get_abs_allocation_vertices       (ClutterActor               *self, | ||||
|                                                                                  ClutterVertex               verts[]); | ||||
|                                                                                  graphene_point3d_t         *verts); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_apply_transform_to_point          (ClutterActor               *self, | ||||
|                                                                                  const ClutterVertex        *point, | ||||
|                                                                                  ClutterVertex              *vertex); | ||||
|                                                                                  const graphene_point3d_t   *point, | ||||
|                                                                                  graphene_point3d_t         *vertex); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_actor_apply_relative_transform_to_point (ClutterActor               *self, | ||||
|                                                                                  ClutterActor               *ancestor, | ||||
|                                                                                  const ClutterVertex        *point, | ||||
|                                                                                  ClutterVertex              *vertex); | ||||
|                                                                                  const graphene_point3d_t   *point, | ||||
|                                                                                  graphene_point3d_t         *vertex); | ||||
|  | ||||
| /* Implicit animations */ | ||||
| CLUTTER_EXPORT | ||||
|   | ||||
| @@ -54,7 +54,6 @@ | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-private.h" | ||||
|  | ||||
| #include "deprecated/clutter-animatable.h" | ||||
| #include "deprecated/clutter-animation.h" | ||||
|  | ||||
| G_DEFINE_INTERFACE (ClutterAnimatable, clutter_animatable, G_TYPE_OBJECT); | ||||
| @@ -64,80 +63,6 @@ clutter_animatable_default_init (ClutterAnimatableInterface *iface) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_animatable_animate_property: | ||||
|  * @animatable: a #ClutterAnimatable | ||||
|  * @animation: a #ClutterAnimation | ||||
|  * @property_name: the name of the animated property | ||||
|  * @initial_value: the initial value of the animation interval | ||||
|  * @final_value: the final value of the animation interval | ||||
|  * @progress: the progress factor | ||||
|  * @value: return location for the animation value | ||||
|  * | ||||
|  * Calls the animate_property() virtual function for @animatable. | ||||
|  * | ||||
|  * The @initial_value and @final_value #GValue<!-- -->s must contain | ||||
|  * the same type; @value must have been initialized to the same | ||||
|  * type of @initial_value and @final_value. | ||||
|  * | ||||
|  * All implementation of the #ClutterAnimatable interface must | ||||
|  * implement this function. | ||||
|  * | ||||
|  * Return value: %TRUE if the value has been validated and can | ||||
|  *   be applied to the #ClutterAnimatable, and %FALSE otherwise | ||||
|  * | ||||
|  * Since: 1.0 | ||||
|  * | ||||
|  * Deprecated: 1.8: Use clutter_animatable_interpolate_value() | ||||
|  *   instead | ||||
|  */ | ||||
| gboolean | ||||
| clutter_animatable_animate_property (ClutterAnimatable *animatable, | ||||
|                                      ClutterAnimation  *animation, | ||||
|                                      const gchar       *property_name, | ||||
|                                      const GValue      *initial_value, | ||||
|                                      const GValue      *final_value, | ||||
|                                      gdouble            progress, | ||||
|                                      GValue            *value) | ||||
| { | ||||
|   ClutterAnimatableInterface *iface; | ||||
|   gboolean res; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_ANIMATABLE (animatable), FALSE); | ||||
|   g_return_val_if_fail (CLUTTER_IS_ANIMATION (animation), FALSE); | ||||
|   g_return_val_if_fail (property_name != NULL, FALSE); | ||||
|   g_return_val_if_fail (initial_value != NULL && final_value != NULL, FALSE); | ||||
|   g_return_val_if_fail (G_VALUE_TYPE (initial_value) != G_TYPE_INVALID, FALSE); | ||||
|   g_return_val_if_fail (G_VALUE_TYPE (final_value) != G_TYPE_INVALID, FALSE); | ||||
|   g_return_val_if_fail (value != NULL, FALSE); | ||||
|   g_return_val_if_fail (G_VALUE_TYPE (value) == G_VALUE_TYPE (initial_value) && | ||||
|                         G_VALUE_TYPE (value) == G_VALUE_TYPE (final_value), | ||||
|                         FALSE); | ||||
|  | ||||
|   iface = CLUTTER_ANIMATABLE_GET_IFACE (animatable); | ||||
|   if (iface->animate_property == NULL) | ||||
|     { | ||||
|       ClutterInterval *interval; | ||||
|  | ||||
|       interval = clutter_animation_get_interval (animation, property_name); | ||||
|       if (interval == NULL) | ||||
|         return FALSE; | ||||
|  | ||||
|       res = clutter_animatable_interpolate_value (animatable, property_name, | ||||
|                                                   interval, | ||||
|                                                   progress, | ||||
|                                                   value); | ||||
|     } | ||||
|   else | ||||
|     res = iface->animate_property (animatable, animation, | ||||
|                                    property_name, | ||||
|                                    initial_value, final_value, | ||||
|                                    progress, | ||||
|                                    value); | ||||
|  | ||||
|   return res; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_animatable_find_property: | ||||
|  * @animatable: a #ClutterAnimatable | ||||
|   | ||||
| @@ -93,10 +93,6 @@ G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterMatrix, clutter_matrix_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterPaintNode, clutter_paint_node_unref) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterPaintVolume, clutter_paint_volume_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterPathNode, clutter_path_node_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterPoint, clutter_point_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterRect, clutter_rect_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterSize, clutter_size_free) | ||||
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterVertex, clutter_vertex_free) | ||||
|  | ||||
| #endif /* __GI_SCANNER__ */ | ||||
|  | ||||
|   | ||||
| @@ -23,8 +23,7 @@ | ||||
| #define __CLUTTER_BACKEND_PRIVATE_H__ | ||||
|  | ||||
| #include <clutter/clutter-backend.h> | ||||
| #include <clutter/clutter-device-manager.h> | ||||
| #include <clutter/clutter-keymap.h> | ||||
| #include <clutter/clutter-seat.h> | ||||
| #include <clutter/clutter-stage-window.h> | ||||
|  | ||||
| #define CLUTTER_BACKEND_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_BACKEND, ClutterBackendClass)) | ||||
| @@ -47,8 +46,6 @@ struct _ClutterBackend | ||||
|  | ||||
|   CoglOnscreen *dummy_onscreen; | ||||
|  | ||||
|   ClutterDeviceManager *device_manager; | ||||
|  | ||||
|   cairo_font_options_t *font_options; | ||||
|  | ||||
|   gchar *font_name; | ||||
| @@ -59,8 +56,6 @@ struct _ClutterBackend | ||||
|   ClutterStageWindow *stage_window; | ||||
|  | ||||
|   ClutterInputMethod *input_method; | ||||
|  | ||||
|   ClutterKeymap *keymap; | ||||
| }; | ||||
|  | ||||
| struct _ClutterBackendClass | ||||
| @@ -89,17 +84,12 @@ struct _ClutterBackendClass | ||||
|                                                 GError         **error); | ||||
|   gboolean              (* create_context)     (ClutterBackend  *backend, | ||||
|                                                 GError         **error); | ||||
|   ClutterDeviceManager *(* get_device_manager) (ClutterBackend  *backend); | ||||
|  | ||||
|   gboolean              (* translate_event)    (ClutterBackend     *backend, | ||||
|                                                 gpointer            native, | ||||
|                                                 ClutterEvent       *event); | ||||
|  | ||||
|   PangoDirection        (* get_keymap_direction) (ClutterBackend   *backend); | ||||
|  | ||||
|   void                  (* bell_notify)          (ClutterBackend   *backend); | ||||
|  | ||||
|   ClutterKeymap *       (* get_keymap)           (ClutterBackend   *backend); | ||||
|   ClutterSeat *         (* get_default_seat)   (ClutterBackend *backend); | ||||
|  | ||||
|   /* signals */ | ||||
|   void (* resolution_changed) (ClutterBackend *backend); | ||||
| @@ -139,8 +129,6 @@ gfloat                  _clutter_backend_get_units_per_em               (Clutter | ||||
|                                                                          PangoFontDescription   *font_desc); | ||||
| gint32                  _clutter_backend_get_units_serial               (ClutterBackend         *backend); | ||||
|  | ||||
| PangoDirection          _clutter_backend_get_keymap_direction           (ClutterBackend         *backend); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                    _clutter_backend_reset_cogl_framebuffer         (ClutterBackend         *backend); | ||||
|  | ||||
|   | ||||
| @@ -51,7 +51,6 @@ | ||||
| #include "clutter-stage-manager-private.h" | ||||
| #include "clutter-stage-private.h" | ||||
| #include "clutter-stage-window.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
|  | ||||
| #ifdef CLUTTER_HAS_WAYLAND_COMPOSITOR_SUPPORT | ||||
| #include "wayland/clutter-wayland-compositor.h" | ||||
| @@ -528,30 +527,6 @@ clutter_backend_real_init_events (ClutterBackend *backend) | ||||
|   g_error ("Unknown input backend"); | ||||
| } | ||||
|  | ||||
| static ClutterDeviceManager * | ||||
| clutter_backend_real_get_device_manager (ClutterBackend *backend) | ||||
| { | ||||
|   if (G_UNLIKELY (backend->device_manager == NULL)) | ||||
|     { | ||||
|       g_critical ("No device manager available, expect broken input"); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
|   return backend->device_manager; | ||||
| } | ||||
|  | ||||
| static ClutterKeymap * | ||||
| clutter_backend_real_get_keymap (ClutterBackend *backend) | ||||
| { | ||||
|   if (G_UNLIKELY (backend->keymap == NULL)) | ||||
|     { | ||||
|       g_critical ("No keymap available, expect broken keyboard input"); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
|   return backend->keymap; | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_backend_class_init (ClutterBackendClass *klass) | ||||
| { | ||||
| @@ -615,10 +590,8 @@ clutter_backend_class_init (ClutterBackendClass *klass) | ||||
|   klass->font_changed = clutter_backend_real_font_changed; | ||||
|  | ||||
|   klass->init_events = clutter_backend_real_init_events; | ||||
|   klass->get_device_manager = clutter_backend_real_get_device_manager; | ||||
|   klass->create_context = clutter_backend_real_create_context; | ||||
|   klass->get_features = clutter_backend_real_get_features; | ||||
|   klass->get_keymap = clutter_backend_real_get_keymap; | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -627,7 +600,7 @@ clutter_backend_init (ClutterBackend *self) | ||||
|   self->units_per_em = -1.0; | ||||
|   self->units_serial = 1; | ||||
|  | ||||
|   self->dummy_onscreen = COGL_INVALID_HANDLE; | ||||
|   self->dummy_onscreen = NULL; | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -783,24 +756,24 @@ _clutter_backend_copy_event_data (ClutterBackend     *backend, | ||||
|                                   const ClutterEvent *src, | ||||
|                                   ClutterEvent       *dest) | ||||
| { | ||||
|   ClutterDeviceManagerClass *device_manager_class; | ||||
|   ClutterDeviceManager *device_manager; | ||||
|   ClutterSeatClass *seat_class; | ||||
|   ClutterSeat *seat; | ||||
|  | ||||
|   device_manager = clutter_device_manager_get_default (); | ||||
|   device_manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   device_manager_class->copy_event_data (device_manager, src, dest); | ||||
|   seat = clutter_backend_get_default_seat (backend); | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   seat_class->copy_event_data (seat, src, dest); | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_backend_free_event_data (ClutterBackend *backend, | ||||
|                                   ClutterEvent   *event) | ||||
| { | ||||
|   ClutterDeviceManagerClass *device_manager_class; | ||||
|   ClutterDeviceManager *device_manager; | ||||
|   ClutterSeatClass *seat_class; | ||||
|   ClutterSeat *seat; | ||||
|  | ||||
|   device_manager = clutter_device_manager_get_default (); | ||||
|   device_manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   device_manager_class->free_event_data (device_manager, event); | ||||
|   seat = clutter_backend_get_default_seat (backend); | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   seat_class->free_event_data (seat, event); | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -997,22 +970,10 @@ clutter_wayland_set_compositor_display (void *display) | ||||
| } | ||||
| #endif | ||||
|  | ||||
| PangoDirection | ||||
| _clutter_backend_get_keymap_direction (ClutterBackend *backend) | ||||
| { | ||||
|   ClutterBackendClass *klass; | ||||
|  | ||||
|   klass = CLUTTER_BACKEND_GET_CLASS (backend); | ||||
|   if (klass->get_keymap_direction != NULL) | ||||
|     return klass->get_keymap_direction (backend); | ||||
|  | ||||
|   return PANGO_DIRECTION_NEUTRAL; | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_backend_reset_cogl_framebuffer (ClutterBackend *backend) | ||||
| { | ||||
|   if (backend->dummy_onscreen == COGL_INVALID_HANDLE) | ||||
|   if (backend->dummy_onscreen == NULL) | ||||
|     { | ||||
|       GError *internal_error = NULL; | ||||
|  | ||||
| @@ -1042,16 +1003,6 @@ clutter_set_allowed_drivers (const char *drivers) | ||||
|   allowed_drivers = g_strdup (drivers); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_backend_bell_notify (ClutterBackend *backend) | ||||
| { | ||||
|   ClutterBackendClass *klass; | ||||
|  | ||||
|   klass = CLUTTER_BACKEND_GET_CLASS (backend); | ||||
|   if (klass->bell_notify) | ||||
|     klass->bell_notify (backend); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_backend_get_input_method: | ||||
|  * @backend: the #CLutterBackend | ||||
| @@ -1080,22 +1031,24 @@ clutter_backend_set_input_method (ClutterBackend     *backend, | ||||
|   g_set_object (&backend->input_method, method); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_backend_get_keymap: | ||||
|  * @backend: the #ClutterBackend | ||||
|  * | ||||
|  * Gets the keymap used by Clutter | ||||
|  * | ||||
|  * Returns: (transfer none): the keymap | ||||
|  **/ | ||||
| ClutterKeymap * | ||||
| clutter_backend_get_keymap (ClutterBackend *backend) | ||||
| { | ||||
|   return CLUTTER_BACKEND_GET_CLASS (backend)->get_keymap (backend); | ||||
| } | ||||
|  | ||||
| ClutterStageWindow * | ||||
| clutter_backend_get_stage_window (ClutterBackend *backend) | ||||
| { | ||||
|   return backend->stage_window; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_backend_get_default_seat: | ||||
|  * @backend: the #ClutterBackend | ||||
|  * | ||||
|  * Returns the default seat | ||||
|  * | ||||
|  * Returns: (transfer none): the default seat | ||||
|  **/ | ||||
| ClutterSeat * | ||||
| clutter_backend_get_default_seat (ClutterBackend *backend) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_BACKEND (backend), NULL); | ||||
|  | ||||
|   return CLUTTER_BACKEND_GET_CLASS (backend)->get_default_seat (backend); | ||||
| } | ||||
|   | ||||
| @@ -36,6 +36,7 @@ | ||||
| #include <clutter/clutter-config.h> | ||||
| #include <clutter/clutter-keymap.h> | ||||
| #include <clutter/clutter-types.h> | ||||
| #include <clutter/clutter-seat.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| @@ -72,9 +73,6 @@ const cairo_font_options_t *    clutter_backend_get_font_options        (Clutter | ||||
| CLUTTER_EXPORT | ||||
| CoglContext *                   clutter_backend_get_cogl_context        (ClutterBackend             *backend); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_backend_bell_notify             (ClutterBackend             *backend); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputMethod *            clutter_backend_get_input_method        (ClutterBackend             *backend); | ||||
|  | ||||
| @@ -82,7 +80,7 @@ CLUTTER_EXPORT | ||||
| void                            clutter_backend_set_input_method        (ClutterBackend             *backend, | ||||
|                                                                          ClutterInputMethod         *method); | ||||
| CLUTTER_EXPORT | ||||
| ClutterKeymap *                 clutter_backend_get_keymap              (ClutterBackend             *backend); | ||||
| ClutterSeat *                   clutter_backend_get_default_seat        (ClutterBackend             *backend); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -49,10 +49,10 @@ | ||||
|  | ||||
| #define CLUTTER_DISABLE_DEPRECATION_WARNINGS | ||||
| #include "deprecated/clutter-container.h" | ||||
| #include "deprecated/clutter-bin-layout.h" | ||||
|  | ||||
| #include "clutter-actor-private.h" | ||||
| #include "clutter-animatable.h" | ||||
| #include "clutter-bin-layout.h" | ||||
| #include "clutter-child-meta.h" | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-enum-types.h" | ||||
| @@ -698,187 +698,3 @@ clutter_bin_layout_new (ClutterBinAlignment x_align, | ||||
|                        "y-align", y_align, | ||||
|                        NULL); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_bin_layout_set_alignment: | ||||
|  * @self: a #ClutterBinLayout | ||||
|  * @child: (allow-none): a child of @container | ||||
|  * @x_align: the horizontal alignment policy to be used for the @child | ||||
|  *   inside @container | ||||
|  * @y_align: the vertical aligment policy to be used on the @child | ||||
|  *   inside @container | ||||
|  * | ||||
|  * Sets the horizontal and vertical alignment policies to be applied | ||||
|  * to a @child of @self | ||||
|  * | ||||
|  * If @child is %NULL then the @x_align and @y_align values will | ||||
|  * be set as the default alignment policies | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  * | ||||
|  * Deprecated: 1.12: Use the #ClutterActor:x-align and | ||||
|  *   #ClutterActor:y-align properties of #ClutterActor instead. | ||||
|  */ | ||||
| void | ||||
| clutter_bin_layout_set_alignment (ClutterBinLayout    *self, | ||||
|                                   ClutterActor        *child, | ||||
|                                   ClutterBinAlignment  x_align, | ||||
|                                   ClutterBinAlignment  y_align) | ||||
| { | ||||
|   ClutterBinLayoutPrivate *priv; | ||||
|   ClutterLayoutManager *manager; | ||||
|   ClutterLayoutMeta *meta; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_BIN_LAYOUT (self)); | ||||
|   g_return_if_fail (child == NULL || CLUTTER_IS_ACTOR (child)); | ||||
|  | ||||
|   priv = self->priv; | ||||
|  | ||||
|   if (priv->container == NULL) | ||||
|     { | ||||
|       if (child == NULL) | ||||
|         { | ||||
|           set_x_align (self, x_align); | ||||
|           set_y_align (self, y_align); | ||||
|         } | ||||
|       else | ||||
|         g_warning ("The layout of type '%s' must be associated to " | ||||
|                    "a ClutterContainer before setting the alignment " | ||||
|                    "on its children", | ||||
|                    G_OBJECT_TYPE_NAME (self)); | ||||
|  | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   manager = CLUTTER_LAYOUT_MANAGER (self); | ||||
|   meta = clutter_layout_manager_get_child_meta (manager, | ||||
|                                                 priv->container, | ||||
|                                                 child); | ||||
|   g_assert (CLUTTER_IS_BIN_LAYER (meta)); | ||||
|  | ||||
|   set_layer_x_align (CLUTTER_BIN_LAYER (meta), x_align); | ||||
|   set_layer_y_align (CLUTTER_BIN_LAYER (meta), y_align); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_bin_layout_get_alignment: | ||||
|  * @self: a #ClutterBinLayout | ||||
|  * @child: (allow-none): a child of @container | ||||
|  * @x_align: (out) (allow-none): return location for the horizontal | ||||
|  *   alignment policy | ||||
|  * @y_align: (out) (allow-none): return location for the vertical | ||||
|  *   alignment policy | ||||
|  * | ||||
|  * Retrieves the horizontal and vertical alignment policies for | ||||
|  * a child of @self | ||||
|  * | ||||
|  * If @child is %NULL the default alignment policies will be returned | ||||
|  * instead | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  * | ||||
|  * Deprecated: 1.12: Use the #ClutterActor:x-align and the | ||||
|  *   #ClutterActor:y-align properties of #ClutterActor instead. | ||||
|  */ | ||||
| void | ||||
| clutter_bin_layout_get_alignment (ClutterBinLayout    *self, | ||||
|                                   ClutterActor        *child, | ||||
|                                   ClutterBinAlignment *x_align, | ||||
|                                   ClutterBinAlignment *y_align) | ||||
| { | ||||
|   ClutterBinLayoutPrivate *priv; | ||||
|   ClutterLayoutManager *manager; | ||||
|   ClutterLayoutMeta *meta; | ||||
|   ClutterBinLayer *layer; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_BIN_LAYOUT (self)); | ||||
|  | ||||
|   priv = self->priv; | ||||
|  | ||||
|   if (priv->container == NULL) | ||||
|     { | ||||
|       if (child == NULL) | ||||
|         { | ||||
|           if (x_align) | ||||
|             *x_align = priv->x_align; | ||||
|  | ||||
|           if (y_align) | ||||
|             *y_align = priv->y_align; | ||||
|         } | ||||
|       else | ||||
|         g_warning ("The layout of type '%s' must be associated to " | ||||
|                    "a ClutterContainer before getting the alignment " | ||||
|                    "of its children", | ||||
|                    G_OBJECT_TYPE_NAME (self)); | ||||
|  | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   manager = CLUTTER_LAYOUT_MANAGER (self); | ||||
|   meta = clutter_layout_manager_get_child_meta (manager, | ||||
|                                                 priv->container, | ||||
|                                                 child); | ||||
|   g_assert (CLUTTER_IS_BIN_LAYER (meta)); | ||||
|  | ||||
|   layer = CLUTTER_BIN_LAYER (meta); | ||||
|  | ||||
|   if (x_align) | ||||
|     *x_align = layer->x_align; | ||||
|  | ||||
|   if (y_align) | ||||
|     *y_align = layer->y_align; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_bin_layout_add: | ||||
|  * @self: a #ClutterBinLayout | ||||
|  * @child: a #ClutterActor | ||||
|  * @x_align: horizontal alignment policy for @child | ||||
|  * @y_align: vertical alignment policy for @child | ||||
|  * | ||||
|  * Adds a #ClutterActor to the container using @self and | ||||
|  * sets the alignment policies for it | ||||
|  * | ||||
|  * This function is equivalent to clutter_container_add_actor() | ||||
|  * and clutter_layout_manager_child_set_property() but it does not | ||||
|  * require a pointer to the #ClutterContainer associated to the | ||||
|  * #ClutterBinLayout | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  * | ||||
|  * Deprecated: 1.12: Use clutter_actor_add_child() instead. | ||||
|  */ | ||||
| void | ||||
| clutter_bin_layout_add (ClutterBinLayout    *self, | ||||
|                         ClutterActor        *child, | ||||
|                         ClutterBinAlignment  x_align, | ||||
|                         ClutterBinAlignment  y_align) | ||||
| { | ||||
|   ClutterBinLayoutPrivate *priv; | ||||
|   ClutterLayoutManager *manager; | ||||
|   ClutterLayoutMeta *meta; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_BIN_LAYOUT (self)); | ||||
|   g_return_if_fail (CLUTTER_IS_ACTOR (child)); | ||||
|  | ||||
|   priv = self->priv; | ||||
|  | ||||
|   if (priv->container == NULL) | ||||
|     { | ||||
|       g_warning ("The layout of type '%s' must be associated to " | ||||
|                  "a ClutterContainer before adding children", | ||||
|                  G_OBJECT_TYPE_NAME (self)); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   clutter_container_add_actor (priv->container, child); | ||||
|  | ||||
|   manager = CLUTTER_LAYOUT_MANAGER (self); | ||||
|   meta = clutter_layout_manager_get_child_meta (manager, | ||||
|                                                 priv->container, | ||||
|                                                 child); | ||||
|   g_assert (CLUTTER_IS_BIN_LAYER (meta)); | ||||
|  | ||||
|   set_layer_x_align (CLUTTER_BIN_LAYER (meta), x_align); | ||||
|   set_layer_y_align (CLUTTER_BIN_LAYER (meta), y_align); | ||||
| } | ||||
|   | ||||
| @@ -152,7 +152,9 @@ clutter_bind_constraint_update_allocation (ClutterConstraint *constraint, | ||||
|   ClutterBindConstraint *bind = CLUTTER_BIND_CONSTRAINT (constraint); | ||||
|   gfloat source_width, source_height; | ||||
|   gfloat actor_width, actor_height; | ||||
|   ClutterVertex source_position = { 0., }; | ||||
|   graphene_point3d_t source_position; | ||||
|  | ||||
|   source_position = GRAPHENE_POINT3D_INIT (0.f, 0.f, 0.f); | ||||
|  | ||||
|   if (bind->source == NULL) | ||||
|     return; | ||||
|   | ||||
| @@ -182,7 +182,7 @@ clutter_blur_effect_modify_paint_volume (ClutterEffect      *effect, | ||||
|                                          ClutterPaintVolume *volume) | ||||
| { | ||||
|   gfloat cur_width, cur_height; | ||||
|   ClutterVertex origin; | ||||
|   graphene_point3d_t origin; | ||||
|  | ||||
|   clutter_paint_volume_get_origin (volume, &origin); | ||||
|   cur_width = clutter_paint_volume_get_width (volume); | ||||
|   | ||||
| @@ -105,8 +105,8 @@ struct _ClutterClickActionPrivate | ||||
| { | ||||
|   ClutterActor *stage; | ||||
|  | ||||
|   guint event_id; | ||||
|   guint capture_id; | ||||
|   gulong event_id; | ||||
|   gulong capture_id; | ||||
|   guint long_press_id; | ||||
|  | ||||
|   gint long_press_threshold; | ||||
| @@ -202,11 +202,7 @@ click_action_emit_long_press (gpointer data) | ||||
|                  CLUTTER_LONG_PRESS_ACTIVATE, | ||||
|                  &result); | ||||
|  | ||||
|   if (priv->capture_id != 0) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|       priv->capture_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|   click_action_set_pressed (action, FALSE); | ||||
|   click_action_set_held (action, FALSE); | ||||
| @@ -261,8 +257,7 @@ click_action_cancel_long_press (ClutterClickAction *action) | ||||
|  | ||||
|       actor = clutter_actor_meta_get_actor (CLUTTER_ACTOR_META (action)); | ||||
|  | ||||
|       g_source_remove (priv->long_press_id); | ||||
|       priv->long_press_id = 0; | ||||
|       g_clear_handle_id (&priv->long_press_id, g_source_remove); | ||||
|  | ||||
|       g_signal_emit (action, click_signals[LONG_PRESS], 0, | ||||
|                      actor, | ||||
| @@ -375,17 +370,9 @@ on_captured_event (ClutterActor       *stage, | ||||
|       click_action_cancel_long_press (action); | ||||
|  | ||||
|       /* disconnect the capture */ | ||||
|       if (priv->capture_id != 0) | ||||
|         { | ||||
|           g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|           priv->capture_id = 0; | ||||
|         } | ||||
|       g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|       if (priv->long_press_id != 0) | ||||
|         { | ||||
|           g_source_remove (priv->long_press_id); | ||||
|           priv->long_press_id = 0; | ||||
|         } | ||||
|       g_clear_handle_id (&priv->long_press_id, g_source_remove); | ||||
|  | ||||
|       if (!clutter_actor_contains (actor, clutter_event_get_source (event))) | ||||
|         return CLUTTER_EVENT_PROPAGATE; | ||||
| @@ -453,7 +440,7 @@ clutter_click_action_set_actor (ClutterActorMeta *meta, | ||||
|       ClutterActor *old_actor = clutter_actor_meta_get_actor (meta); | ||||
|  | ||||
|       if (old_actor != NULL) | ||||
|         g_signal_handler_disconnect (old_actor, priv->event_id); | ||||
|         g_clear_signal_handler (&priv->event_id, old_actor); | ||||
|  | ||||
|       priv->event_id = 0; | ||||
|     } | ||||
| @@ -461,17 +448,13 @@ clutter_click_action_set_actor (ClutterActorMeta *meta, | ||||
|   if (priv->capture_id != 0) | ||||
|     { | ||||
|       if (priv->stage != NULL) | ||||
|         g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|         g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|       priv->capture_id = 0; | ||||
|       priv->stage = NULL; | ||||
|     } | ||||
|  | ||||
|   if (priv->long_press_id != 0) | ||||
|     { | ||||
|       g_source_remove (priv->long_press_id); | ||||
|       priv->long_press_id = 0; | ||||
|     } | ||||
|   g_clear_handle_id (&priv->long_press_id, g_source_remove); | ||||
|  | ||||
|   click_action_set_pressed (action, FALSE); | ||||
|   click_action_set_held (action, FALSE); | ||||
| @@ -545,24 +528,12 @@ clutter_click_action_dispose (GObject *gobject) | ||||
| { | ||||
|   ClutterClickActionPrivate *priv = CLUTTER_CLICK_ACTION (gobject)->priv; | ||||
|  | ||||
|   if (priv->event_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (clutter_actor_meta_get_actor (CLUTTER_ACTOR_META (gobject)), | ||||
|                                    priv->event_id); | ||||
|       priv->event_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->event_id, | ||||
|                           clutter_actor_meta_get_actor (CLUTTER_ACTOR_META (gobject))); | ||||
|  | ||||
|   if (priv->capture_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|       priv->capture_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|   if (priv->long_press_id) | ||||
|     { | ||||
|       g_source_remove (priv->long_press_id); | ||||
|       priv->long_press_id = 0; | ||||
|     } | ||||
|   g_clear_handle_id (&priv->long_press_id, g_source_remove); | ||||
|  | ||||
|   G_OBJECT_CLASS (clutter_click_action_parent_class)->dispose (gobject); | ||||
| } | ||||
| @@ -760,11 +731,7 @@ clutter_click_action_release (ClutterClickAction *action) | ||||
|     return; | ||||
|  | ||||
|   /* disconnect the capture */ | ||||
|   if (priv->capture_id != 0) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|       priv->capture_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|   click_action_cancel_long_press (action); | ||||
|   click_action_set_held (action, FALSE); | ||||
|   | ||||
| @@ -400,8 +400,7 @@ clutter_clone_set_source_internal (ClutterClone *self, | ||||
|  | ||||
|   if (priv->clone_source != NULL) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->clone_source, priv->source_destroy_id); | ||||
|       priv->source_destroy_id = 0; | ||||
|       g_clear_signal_handler (&priv->source_destroy_id, priv->clone_source); | ||||
|       _clutter_actor_detach_clone (priv->clone_source, CLUTTER_ACTOR (self)); | ||||
|       g_object_unref (priv->clone_source); | ||||
|       priv->clone_source = NULL; | ||||
|   | ||||
| @@ -48,7 +48,7 @@ | ||||
|  * Constraints provide a way to build user interfaces by using | ||||
|  * relations between #ClutterActors, without explicit fixed | ||||
|  * positioning and sizing, similarly to how fluid layout managers like | ||||
|  * #ClutterBoxLayout and #ClutterTableLayout lay out their children. | ||||
|  * #ClutterBoxLayout lay out their children. | ||||
|  * | ||||
|  * Constraints are attached to a #ClutterActor, and are available | ||||
|  * for inspection using clutter_actor_get_constraints(). | ||||
|   | ||||
| @@ -118,37 +118,6 @@ container_real_remove (ClutterContainer *container, | ||||
|   clutter_actor_remove_child (CLUTTER_ACTOR (container), actor); | ||||
| } | ||||
|  | ||||
| typedef struct { | ||||
|   ClutterCallback callback; | ||||
|   gpointer data; | ||||
| } ForeachClosure; | ||||
|  | ||||
| static gboolean | ||||
| foreach_cb (ClutterActor *actor, | ||||
|             gpointer      data) | ||||
| { | ||||
|   ForeachClosure *clos = data; | ||||
|  | ||||
|   clos->callback (actor, clos->data); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static void | ||||
| container_real_foreach (ClutterContainer *container, | ||||
|                         ClutterCallback   callback, | ||||
|                         gpointer          user_data) | ||||
| { | ||||
|   ForeachClosure clos; | ||||
|  | ||||
|   clos.callback = callback; | ||||
|   clos.data = user_data; | ||||
|  | ||||
|   _clutter_actor_foreach_child (CLUTTER_ACTOR (container), | ||||
|                                 foreach_cb, | ||||
|                                 &clos); | ||||
| } | ||||
|  | ||||
| static void | ||||
| container_real_raise (ClutterContainer *container, | ||||
|                       ClutterActor     *child, | ||||
| @@ -243,7 +212,6 @@ clutter_container_default_init (ClutterContainerInterface *iface) | ||||
|  | ||||
|   iface->add = container_real_add; | ||||
|   iface->remove = container_real_remove; | ||||
|   iface->foreach = container_real_foreach; | ||||
|   iface->raise = container_real_raise; | ||||
|   iface->lower = container_real_lower; | ||||
|   iface->sort_depth_order = container_real_sort_depth_order; | ||||
| @@ -416,33 +384,6 @@ clutter_container_add_actor (ClutterContainer *container, | ||||
|   container_add_actor (container, actor); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_add_valist: (skip) | ||||
|  * @container: a #ClutterContainer | ||||
|  * @first_actor: the first #ClutterActor to add | ||||
|  * @var_args: list of actors to add, followed by %NULL | ||||
|  * | ||||
|  * Alternative va_list version of clutter_container_add(). | ||||
|  * | ||||
|  * This function will call #ClutterContainerIface.add(), which is a | ||||
|  * deprecated virtual function. The default implementation will | ||||
|  * call clutter_actor_add_child(). | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  * | ||||
|  * Deprecated: 1.10: Use clutter_actor_add_child() instead. | ||||
|  */ | ||||
| void | ||||
| clutter_container_add_valist (ClutterContainer *container, | ||||
|                               ClutterActor     *first_actor, | ||||
|                               va_list           var_args) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_CONTAINER (container)); | ||||
|   g_return_if_fail (CLUTTER_IS_ACTOR (first_actor)); | ||||
|  | ||||
|   container_add_valist (container, first_actor, var_args); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_remove: (skip) | ||||
|  * @container: a #ClutterContainer | ||||
| @@ -506,42 +447,6 @@ clutter_container_remove_actor (ClutterContainer *container, | ||||
|   container_remove_actor (container, actor); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_remove_valist: (skip) | ||||
|  * @container: a #ClutterContainer | ||||
|  * @first_actor: the first #ClutterActor to add | ||||
|  * @var_args: list of actors to remove, followed by %NULL | ||||
|  * | ||||
|  * Alternative va_list version of clutter_container_remove(). | ||||
|  * | ||||
|  * This function will call #ClutterContainerIface.remove(), which is a | ||||
|  * deprecated virtual function. The default implementation will call | ||||
|  * clutter_actor_remove_child(). | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  * | ||||
|  * Deprecated: 1.10: Use clutter_actor_remove_child() instead. | ||||
|  */ | ||||
| void | ||||
| clutter_container_remove_valist (ClutterContainer *container, | ||||
|                                  ClutterActor     *first_actor, | ||||
|                                  va_list           var_args) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_CONTAINER (container)); | ||||
|   g_return_if_fail (CLUTTER_IS_ACTOR (first_actor)); | ||||
|  | ||||
|   container_remove_valist (container, first_actor, var_args); | ||||
| } | ||||
|  | ||||
| static void | ||||
| get_children_cb (ClutterActor *child, | ||||
|                  gpointer      data) | ||||
| { | ||||
|   GList **children = data; | ||||
|  | ||||
|   *children = g_list_prepend (*children, child); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_get_children: | ||||
|  * @container: a #ClutterContainer | ||||
| @@ -559,108 +464,9 @@ get_children_cb (ClutterActor *child, | ||||
| GList * | ||||
| clutter_container_get_children (ClutterContainer *container) | ||||
| { | ||||
|   GList *retval; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_CONTAINER (container), NULL); | ||||
|  | ||||
|   retval = NULL; | ||||
|   clutter_container_foreach (container, get_children_cb, &retval); | ||||
|  | ||||
|   return g_list_reverse (retval); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_foreach: | ||||
|  * @container: a #ClutterContainer | ||||
|  * @callback: (scope call): a function to be called for each child | ||||
|  * @user_data: data to be passed to the function, or %NULL | ||||
|  * | ||||
|  * Calls @callback for each child of @container that was added | ||||
|  * by the application (with clutter_container_add_actor()). Does | ||||
|  * not iterate over "internal" children that are part of the | ||||
|  * container's own implementation, if any. | ||||
|  * | ||||
|  * This function calls the #ClutterContainerIface.foreach() | ||||
|  * virtual function, which has been deprecated. | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  * | ||||
|  * Deprecated: 1.10: Use clutter_actor_get_first_child() or | ||||
|  *   clutter_actor_get_last_child() to retrieve the beginning of | ||||
|  *   the list of children, and clutter_actor_get_next_sibling() | ||||
|  *   and clutter_actor_get_previous_sibling() to iterate over it; | ||||
|  *   alternatively, use the #ClutterActorIter API. | ||||
|  */ | ||||
| void | ||||
| clutter_container_foreach (ClutterContainer *container, | ||||
|                            ClutterCallback   callback, | ||||
|                            gpointer          user_data) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_CONTAINER (container)); | ||||
|   g_return_if_fail (callback != NULL); | ||||
|  | ||||
| #ifdef CLUTTER_ENABLE_DEBUG | ||||
|   if (G_UNLIKELY (_clutter_diagnostic_enabled ())) | ||||
|     { | ||||
|       ClutterContainerIface *iface = CLUTTER_CONTAINER_GET_IFACE (container); | ||||
|  | ||||
|       if (iface->foreach != container_real_foreach) | ||||
|         _clutter_diagnostic_message ("The ClutterContainer::foreach() " | ||||
|                                      "virtual function has been deprecated " | ||||
|                                      "and it should not be overridden by " | ||||
|                                      "newly written code"); | ||||
|     } | ||||
| #endif /* CLUTTER_ENABLE_DEBUG */ | ||||
|  | ||||
|   CLUTTER_CONTAINER_GET_IFACE (container)->foreach (container, | ||||
|                                                     callback, | ||||
|                                                     user_data); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_container_foreach_with_internals: | ||||
|  * @container: a #ClutterContainer | ||||
|  * @callback: (scope call): a function to be called for each child | ||||
|  * @user_data: data to be passed to the function, or %NULL | ||||
|  * | ||||
|  * Calls @callback for each child of @container, including "internal" | ||||
|  * children built in to the container itself that were never added | ||||
|  * by the application. | ||||
|  * | ||||
|  * This function calls the #ClutterContainerIface.foreach_with_internals() | ||||
|  * virtual function, which has been deprecated. | ||||
|  * | ||||
|  * Since: 1.0 | ||||
|  * | ||||
|  * Deprecated: 1.10: See clutter_container_foreach(). | ||||
|  */ | ||||
| void | ||||
| clutter_container_foreach_with_internals (ClutterContainer *container, | ||||
|                                           ClutterCallback   callback, | ||||
|                                           gpointer          user_data) | ||||
| { | ||||
|   ClutterContainerIface *iface; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_CONTAINER (container)); | ||||
|   g_return_if_fail (callback != NULL); | ||||
|  | ||||
|   iface = CLUTTER_CONTAINER_GET_IFACE (container); | ||||
|  | ||||
| #ifdef CLUTTER_ENABLE_DEBUG | ||||
|   if (G_UNLIKELY (_clutter_diagnostic_enabled ())) | ||||
|     { | ||||
|       if (iface->foreach_with_internals != NULL) | ||||
|         _clutter_diagnostic_message ("The ClutterContainer::foreach_with_internals() " | ||||
|                                      "virtual function has been deprecated " | ||||
|                                      "and it should not be overridden by " | ||||
|                                      "newly written code"); | ||||
|     } | ||||
| #endif /* CLUTTER_ENABLE_DEBUG */ | ||||
|  | ||||
|   if (iface->foreach_with_internals != NULL) | ||||
|     iface->foreach_with_internals (container, callback, user_data); | ||||
|   else | ||||
|     iface->foreach (container, callback, user_data); | ||||
|   return clutter_actor_get_children (CLUTTER_ACTOR (container)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -59,14 +59,6 @@ typedef struct _ClutterContainerIface   ClutterContainerIface; | ||||
|  *   function is deprecated, and it should not be overridden. | ||||
|  * @remove: virtual function for removing an actor from the container. This | ||||
|  *   virtual function is deprecated, and it should not be overridden. | ||||
|  * @foreach: virtual function for iterating over the container's children. | ||||
|  *   This virtual function is deprecated, and it should not be overridden. | ||||
|  * @foreach_with_internals: virtual functions for iterating over the | ||||
|  *   container's children, both added using the #ClutterContainer API | ||||
|  *   and internal children. The implementation of this virtual function | ||||
|  *   is required only if the #ClutterContainer implementation has | ||||
|  *   internal children. This virtual function is deprecated, and it should | ||||
|  *   not be overridden. | ||||
|  * @raise: virtual function for raising a child. This virtual function is | ||||
|  *   deprecated and it should not be overridden. | ||||
|  * @lower: virtual function for lowering a child. This virtual function is | ||||
| @@ -88,7 +80,7 @@ typedef struct _ClutterContainerIface   ClutterContainerIface; | ||||
|  * @actor_removed: class handler for #ClutterContainer::actor-removed | ||||
|  * @child_notify: class handler for #ClutterContainer::child-notify | ||||
|  * | ||||
|  * Base interface for container actors. The @add, @remove and @foreach | ||||
|  * Base interface for container actors. The @add and @remove | ||||
|  * virtual functions must be provided by any implementation; the other | ||||
|  * virtual functions are optional. | ||||
|  * | ||||
| @@ -104,13 +96,6 @@ struct _ClutterContainerIface | ||||
|                              ClutterActor     *actor); | ||||
|   void (* remove)           (ClutterContainer *container, | ||||
|                              ClutterActor     *actor); | ||||
|   void (* foreach)          (ClutterContainer *container, | ||||
|                              ClutterCallback   callback, | ||||
|                              gpointer          user_data); | ||||
|  | ||||
|   void (* foreach_with_internals) (ClutterContainer *container, | ||||
|                                    ClutterCallback   callback, | ||||
|                                    gpointer          user_data); | ||||
|  | ||||
|   /* child stacking */ | ||||
|   void (* raise)            (ClutterContainer *container, | ||||
|   | ||||
| @@ -6,45 +6,6 @@ | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_MISC                = 1 << 0, | ||||
|   CLUTTER_DEBUG_ACTOR               = 1 << 1, | ||||
|   CLUTTER_DEBUG_TEXTURE             = 1 << 2, | ||||
|   CLUTTER_DEBUG_EVENT               = 1 << 3, | ||||
|   CLUTTER_DEBUG_PAINT               = 1 << 4, | ||||
|   CLUTTER_DEBUG_PANGO               = 1 << 5, | ||||
|   CLUTTER_DEBUG_BACKEND             = 1 << 6, | ||||
|   CLUTTER_DEBUG_SCHEDULER           = 1 << 7, | ||||
|   CLUTTER_DEBUG_SCRIPT              = 1 << 8, | ||||
|   CLUTTER_DEBUG_SHADER              = 1 << 9, | ||||
|   CLUTTER_DEBUG_MULTISTAGE          = 1 << 10, | ||||
|   CLUTTER_DEBUG_ANIMATION           = 1 << 11, | ||||
|   CLUTTER_DEBUG_LAYOUT              = 1 << 12, | ||||
|   CLUTTER_DEBUG_PICK                = 1 << 13, | ||||
|   CLUTTER_DEBUG_EVENTLOOP           = 1 << 14, | ||||
|   CLUTTER_DEBUG_CLIPPING            = 1 << 15, | ||||
|   CLUTTER_DEBUG_OOB_TRANSFORMS      = 1 << 16 | ||||
| } ClutterDebugFlag; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_NOP_PICKING         = 1 << 0, | ||||
| } ClutterPickDebugFlag; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_DISABLE_SWAP_EVENTS     = 1 << 0, | ||||
|   CLUTTER_DEBUG_DISABLE_CLIPPED_REDRAWS = 1 << 1, | ||||
|   CLUTTER_DEBUG_REDRAWS                 = 1 << 2, | ||||
|   CLUTTER_DEBUG_PAINT_VOLUMES           = 1 << 3, | ||||
|   CLUTTER_DEBUG_DISABLE_CULLING         = 1 << 4, | ||||
|   CLUTTER_DEBUG_DISABLE_OFFSCREEN_REDIRECT = 1 << 5, | ||||
|   CLUTTER_DEBUG_CONTINUOUS_REDRAW       = 1 << 6, | ||||
|   CLUTTER_DEBUG_PAINT_DEFORM_TILES      = 1 << 7, | ||||
|   CLUTTER_DEBUG_PAINT_DAMAGE_REGION     = 1 << 8, | ||||
| } ClutterDrawDebugFlag; | ||||
|  | ||||
| #ifdef CLUTTER_ENABLE_DEBUG | ||||
|  | ||||
| #define CLUTTER_HAS_DEBUG(type)         ((clutter_debug_flags & CLUTTER_DEBUG_##type) != FALSE) | ||||
|   | ||||
| @@ -147,7 +147,7 @@ clutter_deform_effect_set_actor (ClutterActorMeta *meta, | ||||
|       ClutterActor *old_actor = clutter_actor_meta_get_actor (meta); | ||||
|  | ||||
|       if (old_actor != NULL) | ||||
|         g_signal_handler_disconnect (old_actor, priv->allocation_id); | ||||
|         g_clear_signal_handler (&priv->allocation_id, old_actor); | ||||
|  | ||||
|       priv->allocation_id = 0; | ||||
|     } | ||||
| @@ -177,7 +177,7 @@ clutter_deform_effect_paint_target (ClutterOffscreenEffect *effect) | ||||
|  | ||||
|   if (priv->is_dirty) | ||||
|     { | ||||
|       ClutterRect rect; | ||||
|       graphene_rect_t rect; | ||||
|       gboolean mapped_buffer; | ||||
|       CoglVertexP3T2C4 *verts; | ||||
|       ClutterActor *actor; | ||||
| @@ -193,8 +193,8 @@ clutter_deform_effect_paint_target (ClutterOffscreenEffect *effect) | ||||
|        */ | ||||
|       if (clutter_offscreen_effect_get_target_rect (effect, &rect)) | ||||
|         { | ||||
|           width = clutter_rect_get_width (&rect); | ||||
|           height = clutter_rect_get_height (&rect); | ||||
|           width = graphene_rect_get_width (&rect); | ||||
|           height = graphene_rect_get_height (&rect); | ||||
|         } | ||||
|       else | ||||
|         clutter_actor_get_size (actor, &width, &height); | ||||
|   | ||||
| @@ -5,24 +5,13 @@ | ||||
|  | ||||
| #include "deprecated/clutter-actor.h" | ||||
| #include "deprecated/clutter-alpha.h" | ||||
| #include "deprecated/clutter-animatable.h" | ||||
| #include "deprecated/clutter-animation.h" | ||||
| #include "deprecated/clutter-behaviour.h" | ||||
| #include "deprecated/clutter-behaviour-depth.h" | ||||
| #include "deprecated/clutter-behaviour-opacity.h" | ||||
| #include "deprecated/clutter-behaviour-scale.h" | ||||
| #include "deprecated/clutter-bin-layout.h" | ||||
| #include "deprecated/clutter-box.h" | ||||
| #include "deprecated/clutter-cairo-texture.h" | ||||
| #include "deprecated/clutter-container.h" | ||||
| #include "deprecated/clutter-group.h" | ||||
| #include "deprecated/clutter-keysyms.h" | ||||
| #include "deprecated/clutter-rectangle.h" | ||||
| #include "deprecated/clutter-stage-manager.h" | ||||
| #include "deprecated/clutter-stage.h" | ||||
| #include "deprecated/clutter-state.h" | ||||
| #include "deprecated/clutter-table-layout.h" | ||||
| #include "deprecated/clutter-texture.h" | ||||
| #include "deprecated/clutter-timeline.h" | ||||
|  | ||||
| #undef __CLUTTER_DEPRECATED_H_INSIDE__ | ||||
|   | ||||
| @@ -1,306 +0,0 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2010  Intel Corporation. | ||||
|  * | ||||
|  * 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/>. | ||||
|  * | ||||
|  * Author: | ||||
|  *   Emmanuele Bassi <ebassi@linux.intel.com> | ||||
|  */ | ||||
|  | ||||
| #ifndef __CLUTTER_DEVICE_MANAGER_PRIVATE_H__ | ||||
| #define __CLUTTER_DEVICE_MANAGER_PRIVATE_H__ | ||||
|  | ||||
| #include <clutter/clutter-backend.h> | ||||
| #include <clutter/clutter-device-manager.h> | ||||
| #include <clutter/clutter-event.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| typedef struct _ClutterAxisInfo | ||||
| { | ||||
|   ClutterInputAxis axis; | ||||
|  | ||||
|   gdouble min_axis; | ||||
|   gdouble max_axis; | ||||
|  | ||||
|   gdouble min_value; | ||||
|   gdouble max_value; | ||||
|  | ||||
|   gdouble resolution; | ||||
| } ClutterAxisInfo; | ||||
|  | ||||
| typedef struct _ClutterKeyInfo | ||||
| { | ||||
|   guint keyval; | ||||
|   ClutterModifierType modifiers; | ||||
| } ClutterKeyInfo; | ||||
|  | ||||
| typedef struct _ClutterScrollInfo | ||||
| { | ||||
|   guint axis_id; | ||||
|   ClutterScrollDirection direction; | ||||
|   gdouble increment; | ||||
|  | ||||
|   gdouble last_value; | ||||
|   guint last_value_valid : 1; | ||||
| } ClutterScrollInfo; | ||||
|  | ||||
| typedef struct _ClutterTouchInfo | ||||
| { | ||||
|   ClutterEventSequence *sequence; | ||||
|   ClutterActor *actor; | ||||
|  | ||||
|   gfloat current_x; | ||||
|   gfloat current_y; | ||||
| } ClutterTouchInfo; | ||||
|  | ||||
| typedef struct _ClutterPtrA11yData | ||||
| { | ||||
|   int n_btn_pressed; | ||||
|   float current_x; | ||||
|   float current_y; | ||||
|  | ||||
|   float dwell_x; | ||||
|   float dwell_y; | ||||
|   gboolean dwell_drag_started; | ||||
|   gboolean dwell_gesture_started; | ||||
|   guint dwell_timer; | ||||
|   guint dwell_position_timer; | ||||
|  | ||||
|   guint secondary_click_timer; | ||||
|   gboolean secondary_click_triggered; | ||||
| } ClutterPtrA11yData; | ||||
|  | ||||
| struct _ClutterInputDevice | ||||
| { | ||||
|   GObject parent_instance; | ||||
|  | ||||
|   gint id; | ||||
|  | ||||
|   ClutterInputDeviceType device_type; | ||||
|   ClutterInputMode device_mode; | ||||
|  | ||||
|   gchar *device_name; | ||||
|  | ||||
|   ClutterDeviceManager *device_manager; | ||||
|  | ||||
|   ClutterBackend *backend; | ||||
|  | ||||
|   /* the associated device */ | ||||
|   ClutterInputDevice *associated; | ||||
|  | ||||
|   GList *slaves; | ||||
|  | ||||
|   /* the actor underneath the pointer */ | ||||
|   ClutterActor *cursor_actor; | ||||
|   GHashTable   *inv_touch_sequence_actors; | ||||
|  | ||||
|   /* the actor that has a grab in place for the device */ | ||||
|   ClutterActor *pointer_grab_actor; | ||||
|   ClutterActor *keyboard_grab_actor; | ||||
|   GHashTable   *sequence_grab_actors; | ||||
|   GHashTable   *inv_sequence_grab_actors; | ||||
|  | ||||
|   /* the current click count */ | ||||
|   gint click_count; | ||||
|  | ||||
|   /* the stage the device is on */ | ||||
|   ClutterStage *stage; | ||||
|  | ||||
|   /* the current state */ | ||||
|   gfloat current_x; | ||||
|   gfloat current_y; | ||||
|   guint32 current_time; | ||||
|   gint current_button_number; | ||||
|   ClutterModifierType current_state; | ||||
|  | ||||
|   /* the current touch points states */ | ||||
|   GHashTable *touch_sequences_info; | ||||
|  | ||||
|   /* the previous state, used for click count generation */ | ||||
|   gint previous_x; | ||||
|   gint previous_y; | ||||
|   guint32 previous_time; | ||||
|   gint previous_button_number; | ||||
|   ClutterModifierType previous_state; | ||||
|  | ||||
|   GArray *axes; | ||||
|  | ||||
|   guint n_keys; | ||||
|   GArray *keys; | ||||
|  | ||||
|   GArray *scroll_info; | ||||
|  | ||||
|   gchar *vendor_id; | ||||
|   gchar *product_id; | ||||
|   gchar *node_path; | ||||
|  | ||||
|   GPtrArray *tools; | ||||
|  | ||||
|   gint n_rings; | ||||
|   gint n_strips; | ||||
|   gint n_mode_groups; | ||||
|  | ||||
|   ClutterInputDeviceMapping mapping_mode; | ||||
|  | ||||
|   guint has_cursor : 1; | ||||
|   guint is_enabled : 1; | ||||
|  | ||||
|   /* Accessiblity */ | ||||
|   ClutterVirtualInputDevice *accessibility_virtual_device; | ||||
|   ClutterPtrA11yData *ptr_a11y_data; | ||||
| }; | ||||
|  | ||||
| typedef void (*ClutterEmitInputDeviceEvent) (ClutterEvent       *event, | ||||
|                                              ClutterInputDevice *device); | ||||
|  | ||||
| struct _ClutterInputDeviceClass | ||||
| { | ||||
|   GObjectClass parent_class; | ||||
|  | ||||
|   gboolean (* keycode_to_evdev) (ClutterInputDevice *device, | ||||
|                                  guint               hardware_keycode, | ||||
|                                  guint              *evdev_keycode); | ||||
|   void (* update_from_tool) (ClutterInputDevice     *device, | ||||
|                              ClutterInputDeviceTool *tool); | ||||
|  | ||||
|   gboolean (* is_mode_switch_button) (ClutterInputDevice *device, | ||||
|                                       guint               group, | ||||
|                                       guint               button); | ||||
|   gint (* get_group_n_modes) (ClutterInputDevice *device, | ||||
|                               gint                group); | ||||
|  | ||||
|   gboolean (* is_grouped) (ClutterInputDevice *device, | ||||
|                            ClutterInputDevice *other_device); | ||||
|  | ||||
|   /* Keyboard accessbility */ | ||||
|   void (* process_kbd_a11y_event) (ClutterEvent               *event, | ||||
|                                    ClutterInputDevice         *device, | ||||
|                                    ClutterEmitInputDeviceEvent emit_event_func); | ||||
| }; | ||||
|  | ||||
| /* device manager */ | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_device_manager_add_device              (ClutterDeviceManager *device_manager, | ||||
|                                                                  ClutterInputDevice   *device); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_device_manager_remove_device           (ClutterDeviceManager *device_manager, | ||||
|                                                                  ClutterInputDevice   *device); | ||||
| void            _clutter_device_manager_update_devices          (ClutterDeviceManager *device_manager); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_device_manager_select_stage_events     (ClutterDeviceManager *device_manager, | ||||
|                                                                  ClutterStage         *stage); | ||||
| ClutterBackend *_clutter_device_manager_get_backend             (ClutterDeviceManager *device_manager); | ||||
|  | ||||
| void            _clutter_device_manager_compress_motion         (ClutterDeviceManager *device_manger, | ||||
|                                                                  ClutterEvent         *event, | ||||
|                                                                  const ClutterEvent   *to_discard); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_device_manager_ensure_a11y_state        (ClutterDeviceManager *device_manager); | ||||
|  | ||||
| /* input device */ | ||||
| CLUTTER_EXPORT | ||||
| gboolean        _clutter_input_device_has_sequence              (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEventSequence *sequence); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_add_event_sequence        (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEvent         *event); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_remove_event_sequence     (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEvent         *event); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_coords                (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEventSequence *sequence, | ||||
|                                                                  gfloat                x, | ||||
|                                                                  gfloat                y, | ||||
|                                                                  ClutterStage         *stage); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_state                 (ClutterInputDevice   *device, | ||||
|                                                                  ClutterModifierType   state); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_time                  (ClutterInputDevice   *device, | ||||
|                                                                  guint32               time_); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_stage                 (ClutterInputDevice   *device, | ||||
|                                                                  ClutterStage         *stage); | ||||
| CLUTTER_EXPORT | ||||
| ClutterStage *  _clutter_input_device_get_stage                 (ClutterInputDevice   *device); | ||||
| void            _clutter_input_device_set_actor                 (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEventSequence *sequence, | ||||
|                                                                  ClutterActor         *actor, | ||||
|                                                                  gboolean              emit_crossing); | ||||
| ClutterActor *  _clutter_input_device_update                    (ClutterInputDevice   *device, | ||||
|                                                                  ClutterEventSequence *sequence, | ||||
|                                                                  gboolean              emit_crossing); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_n_keys                (ClutterInputDevice   *device, | ||||
|                                                                  guint                 n_keys); | ||||
| CLUTTER_EXPORT | ||||
| guint           _clutter_input_device_add_axis                  (ClutterInputDevice   *device, | ||||
|                                                                  ClutterInputAxis      axis, | ||||
|                                                                  gdouble               min_value, | ||||
|                                                                  gdouble               max_value, | ||||
|                                                                  gdouble               resolution); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_reset_axes                (ClutterInputDevice   *device); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_set_associated_device     (ClutterInputDevice   *device, | ||||
|                                                                  ClutterInputDevice   *associated); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_add_slave                 (ClutterInputDevice   *master, | ||||
|                                                                  ClutterInputDevice   *slave); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_remove_slave              (ClutterInputDevice   *master, | ||||
|                                                                  ClutterInputDevice   *slave); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| gboolean        _clutter_input_device_translate_axis            (ClutterInputDevice   *device, | ||||
|                                                                  guint                 index_, | ||||
|                                                                  gdouble               value, | ||||
|                                                                  gdouble              *axis_value); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_add_scroll_info           (ClutterInputDevice   *device, | ||||
|                                                                  guint                 index_, | ||||
|                                                                  ClutterScrollDirection direction, | ||||
|                                                                  gdouble               increment); | ||||
| CLUTTER_EXPORT | ||||
| void            _clutter_input_device_reset_scroll_info         (ClutterInputDevice   *device); | ||||
| CLUTTER_EXPORT | ||||
| gboolean        _clutter_input_device_get_scroll_delta          (ClutterInputDevice   *device, | ||||
|                                                                  guint                 index_, | ||||
|                                                                  gdouble               value, | ||||
|                                                                  ClutterScrollDirection *direction_p, | ||||
|                                                                  gdouble                *delta_p); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDeviceTool * clutter_input_device_lookup_tool       (ClutterInputDevice         *device, | ||||
|                                                                  guint64                     serial, | ||||
|                                                                  ClutterInputDeviceToolType  type); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_input_device_add_tool                   (ClutterInputDevice     *device, | ||||
|                                                                  ClutterInputDeviceTool *tool); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_input_device_update_from_tool           (ClutterInputDevice     *device, | ||||
|                                                                  ClutterInputDeviceTool *tool); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_DEVICE_MANAGER_PRIVATE_H__ */ | ||||
| @@ -1,753 +0,0 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2009  Intel Corp. | ||||
|  * | ||||
|  * 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/>. | ||||
|  * | ||||
|  * Author: Emmanuele Bassi <ebassi@linux.intel.com> | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * SECTION:clutter-device-manager | ||||
|  * @short_description: Maintains the list of input devices | ||||
|  * | ||||
|  * #ClutterDeviceManager is a singleton object, owned by Clutter, which | ||||
|  * maintains the list of #ClutterInputDevice<!-- -->s. | ||||
|  * | ||||
|  * Depending on the backend used by Clutter it is possible to use the | ||||
|  * #ClutterDeviceManager::device-added and | ||||
|  * #ClutterDeviceManager::device-removed to monitor addition and removal | ||||
|  * of devices. | ||||
|  * | ||||
|  * #ClutterDeviceManager is available since Clutter 1.2 | ||||
|  */ | ||||
|  | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #include "clutter-backend-private.h" | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-enum-types.h" | ||||
| #include "clutter-marshal.h" | ||||
| #include "clutter-private.h" | ||||
| #include "clutter-stage-private.h" | ||||
| #include "clutter-virtual-input-device.h" | ||||
| #include "clutter-input-device-tool.h" | ||||
| #include "clutter-input-pointer-a11y-private.h" | ||||
|  | ||||
| struct _ClutterDeviceManagerPrivate | ||||
| { | ||||
|   /* back-pointer to the backend */ | ||||
|   ClutterBackend *backend; | ||||
|  | ||||
|   /* Keyboard a11y */ | ||||
|   ClutterKbdA11ySettings kbd_a11y_settings; | ||||
|   /* Pointer a11y */ | ||||
|   ClutterPointerA11ySettings pointer_a11y_settings; | ||||
| }; | ||||
|  | ||||
| enum | ||||
| { | ||||
|   PROP_0, | ||||
|  | ||||
|   PROP_BACKEND, | ||||
|  | ||||
|   PROP_LAST | ||||
| }; | ||||
|  | ||||
| static GParamSpec *obj_props[PROP_LAST]; | ||||
|  | ||||
| enum | ||||
| { | ||||
|   DEVICE_ADDED, | ||||
|   DEVICE_REMOVED, | ||||
|   TOOL_CHANGED, | ||||
|   KBD_A11Y_MASK_CHANGED, | ||||
|   KBD_A11Y_FLAGS_CHANGED, | ||||
|   PTR_A11Y_DWELL_CLICK_TYPE_CHANGED, | ||||
|   PTR_A11Y_TIMEOUT_STARTED, | ||||
|   PTR_A11Y_TIMEOUT_STOPPED, | ||||
|  | ||||
|   LAST_SIGNAL | ||||
| }; | ||||
|  | ||||
| static guint manager_signals[LAST_SIGNAL] = { 0, }; | ||||
|  | ||||
| G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (ClutterDeviceManager, | ||||
|                                      clutter_device_manager, | ||||
|                                      G_TYPE_OBJECT) | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_set_property (GObject      *gobject, | ||||
|                                      guint         prop_id, | ||||
|                                      const GValue *value, | ||||
|                                      GParamSpec   *pspec) | ||||
| { | ||||
|   ClutterDeviceManager *self = CLUTTER_DEVICE_MANAGER (gobject); | ||||
|   ClutterDeviceManagerPrivate *priv = clutter_device_manager_get_instance_private (self); | ||||
|  | ||||
|   switch (prop_id) | ||||
|     { | ||||
|     case PROP_BACKEND: | ||||
|       priv->backend = g_value_get_object (value); | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_get_property (GObject    *gobject, | ||||
|                                      guint       prop_id, | ||||
|                                      GValue     *value, | ||||
|                                      GParamSpec *pspec) | ||||
| { | ||||
|   ClutterDeviceManager *self = CLUTTER_DEVICE_MANAGER (gobject); | ||||
|   ClutterDeviceManagerPrivate *priv = clutter_device_manager_get_instance_private (self); | ||||
|  | ||||
|   switch (prop_id) | ||||
|     { | ||||
|     case PROP_BACKEND: | ||||
|       g_value_set_object (value, priv->backend); | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_class_init (ClutterDeviceManagerClass *klass) | ||||
| { | ||||
|   GObjectClass *gobject_class = G_OBJECT_CLASS (klass); | ||||
|  | ||||
|   obj_props[PROP_BACKEND] = | ||||
|     g_param_spec_object ("backend", | ||||
|                          P_("Backend"), | ||||
|                          P_("The ClutterBackend of the device manager"), | ||||
|                          CLUTTER_TYPE_BACKEND, | ||||
|                          CLUTTER_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY); | ||||
|  | ||||
|   gobject_class->set_property = clutter_device_manager_set_property; | ||||
|   gobject_class->get_property = clutter_device_manager_get_property; | ||||
|   g_object_class_install_properties (gobject_class, | ||||
|                                      PROP_LAST, | ||||
|                                      obj_props); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::device-added: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @device: the newly added #ClutterInputDevice | ||||
|    * | ||||
|    * The ::device-added signal is emitted each time a device has been | ||||
|    * added to the #ClutterDeviceManager | ||||
|    * | ||||
|    * Since: 1.2 | ||||
|    */ | ||||
|   manager_signals[DEVICE_ADDED] = | ||||
|     g_signal_new (I_("device-added"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, | ||||
|                   NULL, NULL, NULL, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::device-removed: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @device: the removed #ClutterInputDevice | ||||
|    * | ||||
|    * The ::device-removed signal is emitted each time a device has been | ||||
|    * removed from the #ClutterDeviceManager | ||||
|    * | ||||
|    * Since: 1.2 | ||||
|    */ | ||||
|   manager_signals[DEVICE_REMOVED] = | ||||
|     g_signal_new (I_("device-removed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, | ||||
|                   NULL, NULL, NULL, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE); | ||||
|  | ||||
|   manager_signals[TOOL_CHANGED] = | ||||
|     g_signal_new (I_("tool-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_OBJECT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE_TOOL); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::kbd-a11y-mods-state-changed: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @latched_mask: the latched modifier mask from stickykeys | ||||
|    * @locked_mask:  the locked modifier mask from stickykeys | ||||
|    * | ||||
|    * The ::kbd-a11y-mods-state-changed signal is emitted each time either the | ||||
|    * latched modifiers mask or locked modifiers mask are changed as the | ||||
|    * result of keyboard accessibilty's sticky keys operations. | ||||
|    */ | ||||
|   manager_signals[KBD_A11Y_MASK_CHANGED] = | ||||
|     g_signal_new (I_("kbd-a11y-mods-state-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__UINT_UINT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   G_TYPE_UINT, | ||||
|                   G_TYPE_UINT); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::kbd-a11y-flags-changed: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @settings_flags: the new ClutterKeyboardA11yFlags configuration | ||||
|    * @changed_mask: the ClutterKeyboardA11yFlags changed | ||||
|    * | ||||
|    * The ::kbd-a11y-flags-changed signal is emitted each time the | ||||
|    * ClutterKeyboardA11yFlags configuration is changed as the result of | ||||
|    * keyboard accessibilty operations. | ||||
|    */ | ||||
|   manager_signals[KBD_A11Y_FLAGS_CHANGED] = | ||||
|     g_signal_new (I_("kbd-a11y-flags-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__UINT_UINT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   G_TYPE_UINT, | ||||
|                   G_TYPE_UINT); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::ptr-a11y-dwell-click-type-changed: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @click_type: the new #ClutterPointerA11yDwellClickType mode | ||||
|    * | ||||
|    * The ::ptr-a11y-dwell-click-type-changed signal is emitted each time | ||||
|    * the ClutterPointerA11yDwellClickType mode is changed as the result | ||||
|    * of pointer accessibility operations. | ||||
|    */ | ||||
|   manager_signals[PTR_A11Y_DWELL_CLICK_TYPE_CHANGED] = | ||||
|     g_signal_new (I_("ptr-a11y-dwell-click-type-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   g_cclosure_marshal_VOID__FLAGS, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_DWELL_CLICK_TYPE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::ptr-a11y-timeout-started: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @device: the core pointer #ClutterInputDevice | ||||
|    * @timeout_type: the type of timeout #ClutterPointerA11yTimeoutType | ||||
|    * @delay: the delay in ms before secondary-click is triggered. | ||||
|    * | ||||
|    * The ::ptr-a11y-timeout-started signal is emitted when a | ||||
|    * pointer accessibility timeout delay is started, so that upper | ||||
|    * layers can notify the user with some visual feedback. | ||||
|    */ | ||||
|   manager_signals[PTR_A11Y_TIMEOUT_STARTED] = | ||||
|     g_signal_new (I_("ptr-a11y-timeout-started"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_FLAGS_UINT, | ||||
|                   G_TYPE_NONE, 3, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_TIMEOUT_TYPE, | ||||
|                   G_TYPE_UINT); | ||||
|  | ||||
|   /** | ||||
|    * ClutterDeviceManager::ptr-a11y-timeout-stopped: | ||||
|    * @manager: the #ClutterDeviceManager that emitted the signal | ||||
|    * @device: the core pointer #ClutterInputDevice | ||||
|    * @timeout_type: the type of timeout #ClutterPointerA11yTimeoutType | ||||
|    * @clicked: %TRUE if the timeout finished and triggered a click | ||||
|    * | ||||
|    * The ::ptr-a11y-timeout-stopped signal is emitted when a running | ||||
|    * pointer accessibility timeout delay is stopped, either because | ||||
|    * it's triggered at the end of the delay or cancelled, so that | ||||
|    * upper layers can notify the user with some visual feedback. | ||||
|    */ | ||||
|   manager_signals[PTR_A11Y_TIMEOUT_STOPPED] = | ||||
|     g_signal_new (I_("ptr-a11y-timeout-stopped"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_FLAGS_BOOLEAN, | ||||
|                   G_TYPE_NONE, 3, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_TIMEOUT_TYPE, | ||||
|                   G_TYPE_BOOLEAN); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_init (ClutterDeviceManager *self) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_get_default: | ||||
|  * | ||||
|  * Retrieves the device manager singleton | ||||
|  * | ||||
|  * Return value: (transfer none): the #ClutterDeviceManager singleton. | ||||
|  *   The returned instance is owned by Clutter and it should not be | ||||
|  *   modified or freed | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| ClutterDeviceManager * | ||||
| clutter_device_manager_get_default (void) | ||||
| { | ||||
|   ClutterBackend *backend = clutter_get_default_backend (); | ||||
|  | ||||
|   return CLUTTER_BACKEND_GET_CLASS (backend)->get_device_manager (backend); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_list_devices: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * | ||||
|  * Lists all currently registered input devices | ||||
|  * | ||||
|  * Return value: (transfer container) (element-type Clutter.InputDevice): | ||||
|  *   a newly allocated list of #ClutterInputDevice objects. Use | ||||
|  *   g_slist_free() to deallocate it when done | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| GSList * | ||||
| clutter_device_manager_list_devices (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   const GSList *devices; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), NULL); | ||||
|  | ||||
|   devices = clutter_device_manager_peek_devices (device_manager); | ||||
|  | ||||
|   return g_slist_copy ((GSList *) devices); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_peek_devices: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * | ||||
|  * Lists all currently registered input devices | ||||
|  * | ||||
|  * Return value: (transfer none) (element-type Clutter.InputDevice): | ||||
|  *   a pointer to the internal list of #ClutterInputDevice objects. The | ||||
|  *   returned list is owned by the #ClutterDeviceManager and should never | ||||
|  *   be modified or freed | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| const GSList * | ||||
| clutter_device_manager_peek_devices (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), NULL); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   return manager_class->get_devices (device_manager); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_get_device: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @device_id: the integer id of a device | ||||
|  * | ||||
|  * Retrieves the #ClutterInputDevice with the given @device_id | ||||
|  * | ||||
|  * Return value: (transfer none): a #ClutterInputDevice or %NULL. The | ||||
|  *   returned device is owned by the #ClutterDeviceManager and should | ||||
|  *   never be modified or freed | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| ClutterInputDevice * | ||||
| clutter_device_manager_get_device (ClutterDeviceManager *device_manager, | ||||
|                                    gint                  device_id) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), NULL); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   return manager_class->get_device (device_manager, device_id); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_get_core_device: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @device_type: the type of the core device | ||||
|  * | ||||
|  * Retrieves the core #ClutterInputDevice of type @device_type | ||||
|  * | ||||
|  * Core devices are devices created automatically by the default | ||||
|  * Clutter backend | ||||
|  * | ||||
|  * Return value: (transfer none): a #ClutterInputDevice or %NULL. The | ||||
|  *   returned device is owned by the #ClutterDeviceManager and should | ||||
|  *   not be modified or freed | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| ClutterInputDevice * | ||||
| clutter_device_manager_get_core_device (ClutterDeviceManager   *device_manager, | ||||
|                                         ClutterInputDeviceType  device_type) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), NULL); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   return manager_class->get_core_device (device_manager, device_type); | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_device_manager_select_stage_events (ClutterDeviceManager *device_manager, | ||||
|                                              ClutterStage         *stage) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   if (manager_class->select_stage_events) | ||||
|     manager_class->select_stage_events (device_manager, stage); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * _clutter_device_manager_add_device: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @device: a #ClutterInputDevice | ||||
|  * | ||||
|  * Adds @device to the list of #ClutterInputDevice<!-- -->s maintained | ||||
|  * by @device_manager | ||||
|  * | ||||
|  * The reference count of @device is not increased | ||||
|  * | ||||
|  * The #ClutterDeviceManager::device-added signal is emitted after | ||||
|  * adding @device to the list | ||||
|  */ | ||||
| void | ||||
| _clutter_device_manager_add_device (ClutterDeviceManager *device_manager, | ||||
|                                     ClutterInputDevice   *device) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   g_assert (manager_class->add_device != NULL); | ||||
|  | ||||
|   manager_class->add_device (device_manager, device); | ||||
|  | ||||
|   g_signal_emit (device_manager, manager_signals[DEVICE_ADDED], 0, device); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * _clutter_device_manager_remove_device: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @device: a #ClutterInputDevice | ||||
|  * | ||||
|  * Removes @device from the list of #ClutterInputDevice<!-- -->s | ||||
|  * maintained by @device_manager | ||||
|  * | ||||
|  * The reference count of @device is not decreased | ||||
|  * | ||||
|  * The #ClutterDeviceManager::device-removed signal is emitted after | ||||
|  * removing @device from the list | ||||
|  */ | ||||
| void | ||||
| _clutter_device_manager_remove_device (ClutterDeviceManager *device_manager, | ||||
|                                        ClutterInputDevice   *device) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   g_assert (manager_class->remove_device != NULL); | ||||
|  | ||||
|   /* The subclass remove_device() method will likely unref it but we | ||||
|      have to keep it alive during the signal emission. */ | ||||
|   g_object_ref (device); | ||||
|  | ||||
|   manager_class->remove_device (device_manager, device); | ||||
|   g_signal_emit (device_manager, manager_signals[DEVICE_REMOVED], 0, device); | ||||
|  | ||||
|   g_object_unref (device); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * _clutter_device_manager_update_devices: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * | ||||
|  * Updates every #ClutterInputDevice handled by @device_manager | ||||
|  * by performing a pick paint at the coordinates of each pointer | ||||
|  * device | ||||
|  */ | ||||
| void | ||||
| _clutter_device_manager_update_devices (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   const GSList *d; | ||||
|  | ||||
|   for (d = clutter_device_manager_peek_devices (device_manager); | ||||
|        d != NULL; | ||||
|        d = d->next) | ||||
|     { | ||||
|       ClutterInputDevice *device = d->data; | ||||
|       ClutterInputDeviceType device_type; | ||||
|  | ||||
|       /* we only care about pointer devices */ | ||||
|       device_type = clutter_input_device_get_device_type (device); | ||||
|       if (device_type != CLUTTER_POINTER_DEVICE) | ||||
|         continue; | ||||
|  | ||||
|       /* out of stage */ | ||||
|       if (device->stage == NULL) | ||||
|         continue; | ||||
|  | ||||
|       /* the user disabled motion events delivery on actors for | ||||
|        * the stage the device is on; we don't perform any picking | ||||
|        * since the source of the events will always be set to be | ||||
|        * the stage | ||||
|        */ | ||||
|       if (!clutter_stage_get_motion_events_enabled (device->stage)) | ||||
|         continue; | ||||
|  | ||||
|       _clutter_input_device_update (device, NULL, TRUE); | ||||
|     } | ||||
| } | ||||
|  | ||||
| ClutterBackend * | ||||
| _clutter_device_manager_get_backend (ClutterDeviceManager *manager) | ||||
| { | ||||
|   ClutterDeviceManagerPrivate *priv = clutter_device_manager_get_instance_private (manager); | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (manager), NULL); | ||||
|  | ||||
|   return priv->backend; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_create_virtual_device: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @device_type: the type of the virtual device | ||||
|  * | ||||
|  * Creates a virtual input device. | ||||
|  * | ||||
|  * Returns: (transfer full): a newly created virtual device | ||||
|  **/ | ||||
| ClutterVirtualInputDevice * | ||||
| clutter_device_manager_create_virtual_device (ClutterDeviceManager   *device_manager, | ||||
|                                               ClutterInputDeviceType  device_type) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), NULL); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   return manager_class->create_virtual_device (device_manager, | ||||
|                                                device_type); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_supported_virtua_device_types: (skip) | ||||
|  */ | ||||
| ClutterVirtualDeviceType | ||||
| clutter_device_manager_get_supported_virtual_device_types (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager), | ||||
|                         CLUTTER_VIRTUAL_DEVICE_TYPE_NONE); | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   return manager_class->get_supported_virtual_device_types (device_manager); | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_device_manager_compress_motion (ClutterDeviceManager *device_manager, | ||||
|                                          ClutterEvent         *event, | ||||
|                                          const ClutterEvent   *to_discard) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   if (!manager_class->compress_motion) | ||||
|     return; | ||||
|  | ||||
|   manager_class->compress_motion (device_manager, event, to_discard); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_device_manager_ensure_a11y_state (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_device_manager_get_core_device (device_manager, | ||||
|                                                          CLUTTER_POINTER_DEVICE); | ||||
|   if (core_pointer) | ||||
|     { | ||||
|       if (_clutter_is_input_pointer_a11y_enabled (core_pointer)) | ||||
|         _clutter_input_pointer_a11y_add_device (core_pointer); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| are_kbd_a11y_settings_equal (ClutterKbdA11ySettings *a, | ||||
|                              ClutterKbdA11ySettings *b) | ||||
| { | ||||
|   return (memcmp (a, b, sizeof (ClutterKbdA11ySettings)) == 0); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_device_manager_set_kbd_a11y_settings (ClutterDeviceManager   *device_manager, | ||||
|                                               ClutterKbdA11ySettings *settings) | ||||
| { | ||||
|   ClutterDeviceManagerClass *manager_class; | ||||
|   ClutterDeviceManagerPrivate *priv = clutter_device_manager_get_instance_private (device_manager); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   if (are_kbd_a11y_settings_equal (&priv->kbd_a11y_settings, settings)) | ||||
|     return; | ||||
|  | ||||
|   priv->kbd_a11y_settings = *settings; | ||||
|  | ||||
|   manager_class = CLUTTER_DEVICE_MANAGER_GET_CLASS (device_manager); | ||||
|   if (manager_class->apply_kbd_a11y_settings) | ||||
|     manager_class->apply_kbd_a11y_settings (device_manager, settings); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_device_manager_get_kbd_a11y_settings (ClutterDeviceManager   *device_manager, | ||||
|                                               ClutterKbdA11ySettings *settings) | ||||
| { | ||||
|   ClutterDeviceManagerPrivate *priv = clutter_device_manager_get_instance_private (device_manager); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   *settings = priv->kbd_a11y_settings; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| are_pointer_a11y_settings_equal (ClutterPointerA11ySettings *a, | ||||
|                                  ClutterPointerA11ySettings *b) | ||||
| { | ||||
|   return (memcmp (a, b, sizeof (ClutterPointerA11ySettings)) == 0); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_enable_pointer_a11y (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_device_manager_get_core_device (device_manager, | ||||
|                                                          CLUTTER_POINTER_DEVICE); | ||||
|  | ||||
|   _clutter_input_pointer_a11y_add_device (core_pointer); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_device_manager_disable_pointer_a11y (ClutterDeviceManager *device_manager) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_device_manager_get_core_device (device_manager, | ||||
|                                                          CLUTTER_POINTER_DEVICE); | ||||
|  | ||||
|   _clutter_input_pointer_a11y_remove_device (core_pointer); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_set_pointer_a11y_settings: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @settings: a pointer to a #ClutterPointerA11ySettings | ||||
|  * | ||||
|  * Sets the pointer accessibility settings | ||||
|  **/ | ||||
| void | ||||
| clutter_device_manager_set_pointer_a11y_settings (ClutterDeviceManager       *device_manager, | ||||
|                                                   ClutterPointerA11ySettings *settings) | ||||
| { | ||||
|   ClutterDeviceManagerPrivate *priv = | ||||
|     clutter_device_manager_get_instance_private (device_manager); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   if (are_pointer_a11y_settings_equal (&priv->pointer_a11y_settings, settings)) | ||||
|     return; | ||||
|  | ||||
|   if (priv->pointer_a11y_settings.controls == 0 && settings->controls != 0) | ||||
|     clutter_device_manager_enable_pointer_a11y (device_manager); | ||||
|   else if (priv->pointer_a11y_settings.controls != 0 && settings->controls == 0) | ||||
|     clutter_device_manager_disable_pointer_a11y (device_manager); | ||||
|  | ||||
|   priv->pointer_a11y_settings = *settings; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_get_pointer_a11y_settings: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @settings: a pointer to a #ClutterPointerA11ySettings | ||||
|  * | ||||
|  * Gets the current pointer accessibility settings | ||||
|  **/ | ||||
| void | ||||
| clutter_device_manager_get_pointer_a11y_settings (ClutterDeviceManager       *device_manager, | ||||
|                                                   ClutterPointerA11ySettings *settings) | ||||
| { | ||||
|   ClutterDeviceManagerPrivate *priv = | ||||
|     clutter_device_manager_get_instance_private (device_manager); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   *settings = priv->pointer_a11y_settings; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_device_manager_set_pointer_a11y_dwell_click_type: | ||||
|  * @device_manager: a #ClutterDeviceManager | ||||
|  * @click_type: type of click as #ClutterPointerA11yDwellClickType | ||||
|  * | ||||
|  * Sets the dwell click type | ||||
|  **/ | ||||
| void | ||||
| clutter_device_manager_set_pointer_a11y_dwell_click_type (ClutterDeviceManager             *device_manager, | ||||
|                                                           ClutterPointerA11yDwellClickType  click_type) | ||||
| { | ||||
|   ClutterDeviceManagerPrivate *priv = | ||||
|     clutter_device_manager_get_instance_private (device_manager); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_DEVICE_MANAGER (device_manager)); | ||||
|  | ||||
|   priv->pointer_a11y_settings.dwell_click_type = click_type; | ||||
| } | ||||
| @@ -1,181 +0,0 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2009  Intel Corp. | ||||
|  * | ||||
|  * 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/>. | ||||
|  * | ||||
|  * Author: Emmanuele Bassi <ebassi@linux.intel.com> | ||||
|  */ | ||||
|  | ||||
| #ifndef __CLUTTER_DEVICE_MANAGER_H__ | ||||
| #define __CLUTTER_DEVICE_MANAGER_H__ | ||||
|  | ||||
| #if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION) | ||||
| #error "Only <clutter/clutter.h> can be included directly." | ||||
| #endif | ||||
|  | ||||
| #include <clutter/clutter-input-device.h> | ||||
| #include <clutter/clutter-stage.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| #define CLUTTER_TYPE_DEVICE_MANAGER (clutter_device_manager_get_type ()) | ||||
| CLUTTER_EXPORT | ||||
| G_DECLARE_DERIVABLE_TYPE (ClutterDeviceManager, clutter_device_manager, | ||||
|                           CLUTTER, DEVICE_MANAGER, GObject) | ||||
|  | ||||
| typedef struct _ClutterDeviceManagerPrivate     ClutterDeviceManagerPrivate; | ||||
|  | ||||
| /** | ||||
|  * ClutterVirtualDeviceType: | ||||
|  */ | ||||
| typedef enum _ClutterVirtualDeviceType | ||||
| { | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_NONE = 0, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_KEYBOARD = 1 << 0, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_POINTER = 1 << 1, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_TOUCHSCREEN = 1 << 2, | ||||
| } ClutterVirtualDeviceType; | ||||
|  | ||||
| /** | ||||
|  * ClutterKbdA11ySettings: | ||||
|  * | ||||
|  * The #ClutterKbdA11ySettings structure contains keyboard accessibility | ||||
|  * settings | ||||
|  * | ||||
|  */ | ||||
| typedef struct _ClutterKbdA11ySettings | ||||
| { | ||||
|   ClutterKeyboardA11yFlags controls; | ||||
|   gint slowkeys_delay; | ||||
|   gint debounce_delay; | ||||
|   gint timeout_delay; | ||||
|   gint mousekeys_init_delay; | ||||
|   gint mousekeys_max_speed; | ||||
|   gint mousekeys_accel_time; | ||||
| } ClutterKbdA11ySettings; | ||||
|  | ||||
| /** | ||||
|  * ClutterPointerA11ySettings: | ||||
|  * | ||||
|  * The #ClutterPointerA11ySettings structure contains pointer accessibility | ||||
|  * settings | ||||
|  * | ||||
|  */ | ||||
| typedef struct _ClutterPointerA11ySettings | ||||
| { | ||||
|   ClutterPointerA11yFlags controls; | ||||
|   ClutterPointerA11yDwellClickType dwell_click_type; | ||||
|   ClutterPointerA11yDwellMode dwell_mode; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_single; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_double; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_drag; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_secondary; | ||||
|   gint secondary_click_delay; | ||||
|   gint dwell_delay; | ||||
|   gint dwell_threshold; | ||||
| } ClutterPointerA11ySettings; | ||||
|  | ||||
| /** | ||||
|  * ClutterDeviceManagerClass: | ||||
|  * | ||||
|  * The #ClutterDeviceManagerClass structure contains only private data | ||||
|  * | ||||
|  * Since: 1.2 | ||||
|  */ | ||||
| struct _ClutterDeviceManagerClass | ||||
| { | ||||
|   /*< private >*/ | ||||
|   GObjectClass parent_class; | ||||
|  | ||||
|   const GSList *      (* get_devices)     (ClutterDeviceManager   *device_manager); | ||||
|   ClutterInputDevice *(* get_core_device) (ClutterDeviceManager   *device_manager, | ||||
|                                            ClutterInputDeviceType  device_type); | ||||
|   ClutterInputDevice *(* get_device)      (ClutterDeviceManager   *device_manager, | ||||
|                                            gint                    device_id); | ||||
|  | ||||
|   void                (* add_device)      (ClutterDeviceManager   *manager, | ||||
|                                            ClutterInputDevice     *device); | ||||
|   void                (* remove_device)   (ClutterDeviceManager   *manager, | ||||
|                                            ClutterInputDevice     *device); | ||||
|   void                (* select_stage_events) (ClutterDeviceManager *manager, | ||||
|                                                ClutterStage       *stage); | ||||
|   ClutterVirtualInputDevice *(* create_virtual_device) (ClutterDeviceManager  *device_manager, | ||||
|                                                         ClutterInputDeviceType device_type); | ||||
|   ClutterVirtualDeviceType (* get_supported_virtual_device_types) (ClutterDeviceManager *device_manager); | ||||
|   void                (* compress_motion) (ClutterDeviceManager *device_manger, | ||||
|                                            ClutterEvent         *event, | ||||
|                                            const ClutterEvent   *to_discard); | ||||
|   /* Keyboard accessbility */ | ||||
|   void                (* apply_kbd_a11y_settings) (ClutterDeviceManager   *device_manger, | ||||
|                                                    ClutterKbdA11ySettings *settings); | ||||
|  | ||||
|   /* Event platform data */ | ||||
|   void (* copy_event_data) (ClutterDeviceManager *device_manager, | ||||
|                             const ClutterEvent   *src, | ||||
|                             ClutterEvent         *dest); | ||||
|   void (* free_event_data) (ClutterDeviceManager *device_manager, | ||||
|                             ClutterEvent         *event); | ||||
|  | ||||
|   /* padding */ | ||||
|   gpointer _padding[4]; | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterDeviceManager *clutter_device_manager_get_default     (void); | ||||
| CLUTTER_EXPORT | ||||
| GSList *              clutter_device_manager_list_devices    (ClutterDeviceManager   *device_manager); | ||||
| CLUTTER_EXPORT | ||||
| const GSList *        clutter_device_manager_peek_devices    (ClutterDeviceManager   *device_manager); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDevice *  clutter_device_manager_get_device      (ClutterDeviceManager   *device_manager, | ||||
|                                                               gint                    device_id); | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDevice *  clutter_device_manager_get_core_device (ClutterDeviceManager   *device_manager, | ||||
|                                                               ClutterInputDeviceType  device_type); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterVirtualInputDevice *clutter_device_manager_create_virtual_device (ClutterDeviceManager  *device_manager, | ||||
|                                                                          ClutterInputDeviceType device_type); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterVirtualDeviceType clutter_device_manager_get_supported_virtual_device_types (ClutterDeviceManager *device_manager); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_device_manager_set_kbd_a11y_settings (ClutterDeviceManager   *device_manager, | ||||
|                                                    ClutterKbdA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_device_manager_get_kbd_a11y_settings (ClutterDeviceManager   *device_manager, | ||||
|                                                    ClutterKbdA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_device_manager_set_pointer_a11y_settings (ClutterDeviceManager       *device_manager, | ||||
|                                                        ClutterPointerA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_device_manager_get_pointer_a11y_settings (ClutterDeviceManager       *device_manager, | ||||
|                                                        ClutterPointerA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_device_manager_set_pointer_a11y_dwell_click_type (ClutterDeviceManager             *device_manager, | ||||
|                                                                ClutterPointerA11yDwellClickType  click_type); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_DEVICE_MANAGER_H__ */ | ||||
| @@ -81,7 +81,7 @@ struct _ClutterDragActionPrivate | ||||
|   gint y_drag_threshold; | ||||
|   ClutterActor *drag_handle; | ||||
|   ClutterDragAxis drag_axis; | ||||
|   ClutterRect drag_area; | ||||
|   graphene_rect_t drag_area; | ||||
|  | ||||
|   ClutterInputDevice *device; | ||||
|   ClutterEventSequence *sequence; | ||||
| @@ -315,11 +315,7 @@ emit_drag_end (ClutterDragAction *action, | ||||
|     goto out; | ||||
|  | ||||
|   /* disconnect the capture */ | ||||
|   if (priv->capture_id != 0) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|       priv->capture_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|   clutter_stage_set_motion_events_enabled (priv->stage, | ||||
|                                            priv->motion_events_enabled); | ||||
| @@ -478,8 +474,8 @@ clutter_drag_action_set_actor (ClutterActorMeta *meta, | ||||
|       old_actor = clutter_actor_meta_get_actor (meta); | ||||
|       if (old_actor != NULL) | ||||
|         { | ||||
|           g_signal_handler_disconnect (old_actor, priv->button_press_id); | ||||
|           g_signal_handler_disconnect (old_actor, priv->touch_begin_id); | ||||
|           g_clear_signal_handler (&priv->button_press_id, old_actor); | ||||
|           g_clear_signal_handler (&priv->touch_begin_id, old_actor); | ||||
|         } | ||||
|  | ||||
|       priv->button_press_id = 0; | ||||
| @@ -489,7 +485,7 @@ clutter_drag_action_set_actor (ClutterActorMeta *meta, | ||||
|   if (priv->capture_id != 0) | ||||
|     { | ||||
|       if (priv->stage != NULL) | ||||
|         g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|         g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|       priv->capture_id = 0; | ||||
|       priv->stage = NULL; | ||||
| @@ -542,7 +538,7 @@ clutter_drag_action_real_drag_motion (ClutterDragAction *action, | ||||
|  | ||||
|   if (action->priv->drag_area_set) | ||||
|     { | ||||
|       ClutterRect *drag_area = &action->priv->drag_area; | ||||
|       graphene_rect_t *drag_area = &action->priv->drag_area; | ||||
|  | ||||
|       x = CLAMP (x, drag_area->origin.x, drag_area->origin.x + drag_area->size.width); | ||||
|       y = CLAMP (y, drag_area->origin.y, drag_area->origin.y + drag_area->size.height); | ||||
| @@ -668,7 +664,7 @@ clutter_drag_action_dispose (GObject *gobject) | ||||
|                                                priv->motion_events_enabled); | ||||
|  | ||||
|       if (priv->stage != NULL) | ||||
|         g_signal_handler_disconnect (priv->stage, priv->capture_id); | ||||
|         g_clear_signal_handler (&priv->capture_id, priv->stage); | ||||
|  | ||||
|       priv->capture_id = 0; | ||||
|       priv->stage = NULL; | ||||
| @@ -681,8 +677,8 @@ clutter_drag_action_dispose (GObject *gobject) | ||||
|       actor = clutter_actor_meta_get_actor (CLUTTER_ACTOR_META (gobject)); | ||||
|       if (actor != NULL) | ||||
|         { | ||||
|           g_signal_handler_disconnect (actor, priv->button_press_id); | ||||
|           g_signal_handler_disconnect (actor, priv->touch_begin_id); | ||||
|           g_clear_signal_handler (&priv->button_press_id, actor); | ||||
|           g_clear_signal_handler (&priv->touch_begin_id, actor); | ||||
|         } | ||||
|  | ||||
|       priv->button_press_id = 0; | ||||
| @@ -811,7 +807,7 @@ clutter_drag_action_class_init (ClutterDragActionClass *klass) | ||||
|     g_param_spec_boxed ("drag-area", | ||||
| 			P_("Drag Area"), | ||||
| 			P_("Constrains the dragging to a rectangle"), | ||||
| 			CLUTTER_TYPE_RECT, | ||||
| 			GRAPHENE_TYPE_RECT, | ||||
| 			CLUTTER_PARAM_READWRITE); | ||||
|  | ||||
|   /** | ||||
| @@ -1267,10 +1263,10 @@ clutter_drag_action_get_motion_coords (ClutterDragAction *action, | ||||
| /** | ||||
|  * clutter_drag_action_get_drag_area: | ||||
|  * @action: a #ClutterDragAction | ||||
|  * @drag_area: (out caller-allocates): a #ClutterRect to be filled | ||||
|  * @drag_area: (out caller-allocates): a #graphene_rect_t to be filled | ||||
|  * | ||||
|  * Retrieves the "drag area" associated with @action, that | ||||
|  * is a #ClutterRect that constrains the actor movements, | ||||
|  * is a #graphene_rect_t that constrains the actor movements, | ||||
|  * in parents coordinates. | ||||
|  * | ||||
|  * Returns: %TRUE if the actor is actually constrained (and thus | ||||
| @@ -1278,7 +1274,7 @@ clutter_drag_action_get_motion_coords (ClutterDragAction *action, | ||||
|  */ | ||||
| gboolean | ||||
| clutter_drag_action_get_drag_area (ClutterDragAction *action, | ||||
| 				   ClutterRect       *drag_area) | ||||
|                                    graphene_rect_t   *drag_area) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_DRAG_ACTION (action), FALSE); | ||||
|  | ||||
| @@ -1298,8 +1294,8 @@ clutter_drag_action_get_drag_area (ClutterDragAction *action, | ||||
|  * If @drag_area is %NULL, the actor is not constrained. | ||||
|  */ | ||||
| void | ||||
| clutter_drag_action_set_drag_area (ClutterDragAction *action, | ||||
| 				   const ClutterRect *drag_area) | ||||
| clutter_drag_action_set_drag_area (ClutterDragAction     *action, | ||||
|                                    const graphene_rect_t *drag_area) | ||||
| { | ||||
|   ClutterDragActionPrivate *priv; | ||||
|  | ||||
|   | ||||
| @@ -141,11 +141,11 @@ void            clutter_drag_action_get_motion_coords  (ClutterDragAction *actio | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| gboolean        clutter_drag_action_get_drag_area      (ClutterDragAction *action, | ||||
|                                                         ClutterRect       *drag_area); | ||||
|                                                         graphene_rect_t   *drag_area); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_drag_action_set_drag_area      (ClutterDragAction *action, | ||||
|                                                         const ClutterRect *drag_area); | ||||
| void            clutter_drag_action_set_drag_area      (ClutterDragAction     *action, | ||||
|                                                         const graphene_rect_t *drag_area); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
| @@ -107,7 +107,7 @@ drop_target_free (gpointer _data) | ||||
| { | ||||
|   DropTarget *data = _data; | ||||
|  | ||||
|   g_signal_handler_disconnect (data->stage, data->capture_id); | ||||
|   g_clear_signal_handler (&data->capture_id, data->stage); | ||||
|   g_hash_table_destroy (data->actions); | ||||
|   g_free (data); | ||||
| } | ||||
| @@ -326,12 +326,10 @@ clutter_drop_action_set_actor (ClutterActorMeta *meta, | ||||
|     { | ||||
|       drop_action_unregister (CLUTTER_DROP_ACTION (meta)); | ||||
|  | ||||
|       if (priv->mapped_id != 0) | ||||
|         g_signal_handler_disconnect (priv->actor, priv->mapped_id); | ||||
|       g_clear_signal_handler (&priv->mapped_id, priv->actor); | ||||
|  | ||||
|       priv->stage = NULL; | ||||
|       priv->actor = NULL; | ||||
|       priv->mapped_id = 0; | ||||
|     } | ||||
|  | ||||
|   priv->actor = actor; | ||||
|   | ||||
| @@ -12,8 +12,7 @@ gboolean        _clutter_effect_modify_paint_volume     (ClutterEffect | ||||
| gboolean        _clutter_effect_has_custom_paint_volume (ClutterEffect           *effect); | ||||
| void            _clutter_effect_paint                   (ClutterEffect           *effect, | ||||
|                                                          ClutterEffectPaintFlags  flags); | ||||
| void            _clutter_effect_pick                    (ClutterEffect           *effect, | ||||
|                                                          ClutterEffectPaintFlags  flags); | ||||
| void            _clutter_effect_pick                    (ClutterEffect           *effect); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
| @@ -100,13 +100,13 @@ | ||||
|  *    // Clear the previous state // | ||||
|  *    if (self->rect_1) | ||||
|  *      { | ||||
|  *        cogl_handle_unref (self->rect_1); | ||||
|  *        cogl_object_unref (self->rect_1); | ||||
|  *        self->rect_1 = NULL; | ||||
|  *      } | ||||
|  * | ||||
|  *    if (self->rect_2) | ||||
|  *      { | ||||
|  *        cogl_handle_unref (self->rect_2); | ||||
|  *        cogl_object_unref (self->rect_2); | ||||
|  *        self->rect_2 = NULL; | ||||
|  *      } | ||||
|  * | ||||
| @@ -216,14 +216,13 @@ clutter_effect_real_paint (ClutterEffect           *effect, | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_effect_real_pick (ClutterEffect           *effect, | ||||
|                           ClutterEffectPaintFlags  flags) | ||||
| clutter_effect_real_pick (ClutterEffect *effect) | ||||
| { | ||||
|   ClutterActorMeta *actor_meta = CLUTTER_ACTOR_META (effect); | ||||
|   ClutterActor *actor; | ||||
|  | ||||
|   actor = clutter_actor_meta_get_actor (actor_meta); | ||||
|   clutter_actor_continue_paint (actor); | ||||
|   clutter_actor_continue_pick (actor); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -288,12 +287,11 @@ _clutter_effect_paint (ClutterEffect           *effect, | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_effect_pick (ClutterEffect           *effect, | ||||
|                       ClutterEffectPaintFlags  flags) | ||||
| _clutter_effect_pick (ClutterEffect *effect) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_EFFECT (effect)); | ||||
|  | ||||
|   CLUTTER_EFFECT_GET_CLASS (effect)->pick (effect, flags); | ||||
|   CLUTTER_EFFECT_GET_CLASS (effect)->pick (effect); | ||||
| } | ||||
|  | ||||
| gboolean | ||||
|   | ||||
| @@ -82,8 +82,7 @@ struct _ClutterEffectClass | ||||
|  | ||||
|   void     (* paint)               (ClutterEffect           *effect, | ||||
|                                     ClutterEffectPaintFlags  flags); | ||||
|   void     (* pick)                (ClutterEffect           *effect, | ||||
|                                     ClutterEffectPaintFlags  flags); | ||||
|   void     (* pick)                (ClutterEffect           *effect); | ||||
|  | ||||
|   /*< private >*/ | ||||
|   void (* _clutter_effect4) (void); | ||||
|   | ||||
| @@ -970,8 +970,6 @@ typedef enum | ||||
| /** | ||||
|  * ClutterFeatureFlags: | ||||
|  * @CLUTTER_FEATURE_SWAP_THROTTLE: Set if backend throttles buffer swaps. | ||||
|  * @CLUTTER_FEATURE_TEXTURE_YUV: Set if YUV based textures supported. | ||||
|  * @CLUTTER_FEATURE_TEXTURE_READ_PIXELS: Set if texture pixels can be read. | ||||
|  * @CLUTTER_FEATURE_STAGE_STATIC: Set if stage size if fixed (i.e framebuffer) | ||||
|  * @CLUTTER_FEATURE_STAGE_CURSOR: Set if stage has a graphical cursor. | ||||
|  * @CLUTTER_FEATURE_SHADERS_GLSL: Set if the backend supports GLSL shaders. | ||||
| @@ -987,8 +985,6 @@ typedef enum | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_FEATURE_SWAP_THROTTLE          = (1 << 3), | ||||
|   CLUTTER_FEATURE_TEXTURE_YUV            = (1 << 4), | ||||
|   CLUTTER_FEATURE_TEXTURE_READ_PIXELS    = (1 << 5), | ||||
|   CLUTTER_FEATURE_STAGE_STATIC           = (1 << 6), | ||||
|   CLUTTER_FEATURE_STAGE_CURSOR           = (1 << 8), | ||||
|   CLUTTER_FEATURE_SHADERS_GLSL           = (1 << 9), | ||||
| @@ -1187,29 +1183,6 @@ typedef enum /*< prefix=CLUTTER_PAN >*/ | ||||
|   CLUTTER_PAN_AXIS_AUTO | ||||
| } ClutterPanAxis; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * ClutterTableAlignment: | ||||
|  * @CLUTTER_TABLE_ALIGNMENT_START: Align the child to the top or to the | ||||
|  *   left of a cell in the table, depending on the axis | ||||
|  * @CLUTTER_TABLE_ALIGNMENT_CENTER: Align the child to the center of | ||||
|  *   a cell in the table | ||||
|  * @CLUTTER_TABLE_ALIGNMENT_END: Align the child to the bottom or to the | ||||
|  *   right of a cell in the table, depending on the axis | ||||
|  * | ||||
|  * The alignment policies available on each axis of the #ClutterTableLayout | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  * | ||||
|  * Deprecated: 1.22: Use the alignment properties of #ClutterActor | ||||
|  */ | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_TABLE_ALIGNMENT_START, | ||||
|   CLUTTER_TABLE_ALIGNMENT_CENTER, | ||||
|   CLUTTER_TABLE_ALIGNMENT_END | ||||
| } ClutterTableAlignment; | ||||
|  | ||||
| /** | ||||
|  * ClutterTextureFlags: | ||||
|  * @CLUTTER_TEXTURE_NONE: No flags | ||||
| @@ -1217,8 +1190,7 @@ typedef enum | ||||
|  * @CLUTTER_TEXTURE_RGB_FLAG_PREMULT: Unused flag | ||||
|  * @CLUTTER_TEXTURE_YUV_FLAG_YUV2: Unused flag | ||||
|  * | ||||
|  * Flags for clutter_texture_set_from_rgb_data() and | ||||
|  * clutter_texture_set_from_yuv_data(). | ||||
|  * Flags for clutter_texture_set_from_rgb_data(). | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  * | ||||
|   | ||||
| @@ -370,7 +370,7 @@ clutter_event_get_coords (const ClutterEvent *event, | ||||
|                           gfloat             *x, | ||||
|                           gfloat             *y) | ||||
| { | ||||
|   ClutterPoint coords; | ||||
|   graphene_point_t coords; | ||||
|  | ||||
|   g_return_if_fail (event != NULL); | ||||
|  | ||||
| @@ -386,15 +386,15 @@ clutter_event_get_coords (const ClutterEvent *event, | ||||
| /** | ||||
|  * clutter_event_get_position: | ||||
|  * @event: a #ClutterEvent | ||||
|  * @position: a #ClutterPoint | ||||
|  * @position: a #graphene_point_t | ||||
|  * | ||||
|  * Retrieves the event coordinates as a #ClutterPoint. | ||||
|  * Retrieves the event coordinates as a #graphene_point_t. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| void | ||||
| clutter_event_get_position (const ClutterEvent *event, | ||||
|                             ClutterPoint       *position) | ||||
|                             graphene_point_t   *position) | ||||
| { | ||||
|   g_return_if_fail (event != NULL); | ||||
|   g_return_if_fail (position != NULL); | ||||
| @@ -415,42 +415,42 @@ clutter_event_get_position (const ClutterEvent *event, | ||||
|     case CLUTTER_PAD_BUTTON_RELEASE: | ||||
|     case CLUTTER_PAD_STRIP: | ||||
|     case CLUTTER_PAD_RING: | ||||
|       clutter_point_init (position, 0.f, 0.f); | ||||
|       graphene_point_init (position, 0.f, 0.f); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_ENTER: | ||||
|     case CLUTTER_LEAVE: | ||||
|       clutter_point_init (position, event->crossing.x, event->crossing.y); | ||||
|       graphene_point_init (position, event->crossing.x, event->crossing.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_BUTTON_PRESS: | ||||
|     case CLUTTER_BUTTON_RELEASE: | ||||
|       clutter_point_init (position, event->button.x, event->button.y); | ||||
|       graphene_point_init (position, event->button.x, event->button.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_MOTION: | ||||
|       clutter_point_init (position, event->motion.x, event->motion.y); | ||||
|       graphene_point_init (position, event->motion.x, event->motion.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_TOUCH_BEGIN: | ||||
|     case CLUTTER_TOUCH_UPDATE: | ||||
|     case CLUTTER_TOUCH_END: | ||||
|     case CLUTTER_TOUCH_CANCEL: | ||||
|       clutter_point_init (position, event->touch.x, event->touch.y); | ||||
|       graphene_point_init (position, event->touch.x, event->touch.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_SCROLL: | ||||
|       clutter_point_init (position, event->scroll.x, event->scroll.y); | ||||
|       graphene_point_init (position, event->scroll.x, event->scroll.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_TOUCHPAD_PINCH: | ||||
|       clutter_point_init (position, event->touchpad_pinch.x, | ||||
|                           event->touchpad_pinch.y); | ||||
|       graphene_point_init (position, event->touchpad_pinch.x, | ||||
|                            event->touchpad_pinch.y); | ||||
|       break; | ||||
|  | ||||
|     case CLUTTER_TOUCHPAD_SWIPE: | ||||
|       clutter_point_init (position, event->touchpad_swipe.x, | ||||
|                           event->touchpad_swipe.y); | ||||
|       graphene_point_init (position, event->touchpad_swipe.x, | ||||
|                            event->touchpad_swipe.y); | ||||
|       break; | ||||
|     } | ||||
|  | ||||
| @@ -1796,12 +1796,12 @@ float | ||||
| clutter_event_get_distance (const ClutterEvent *source, | ||||
|                             const ClutterEvent *target) | ||||
| { | ||||
|   ClutterPoint p0, p1; | ||||
|   graphene_point_t p0, p1; | ||||
|  | ||||
|   clutter_event_get_position (source, &p0); | ||||
|   clutter_event_get_position (source, &p1); | ||||
|  | ||||
|   return clutter_point_distance (&p0, &p1, NULL, NULL); | ||||
|   return graphene_point_distance (&p0, &p1, NULL, NULL); | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -1822,17 +1822,17 @@ double | ||||
| clutter_event_get_angle (const ClutterEvent *source, | ||||
|                          const ClutterEvent *target) | ||||
| { | ||||
|   ClutterPoint p0, p1; | ||||
|   graphene_point_t p0, p1; | ||||
|   float x_distance, y_distance; | ||||
|   double angle; | ||||
|  | ||||
|   clutter_event_get_position (source, &p0); | ||||
|   clutter_event_get_position (target, &p1); | ||||
|  | ||||
|   if (clutter_point_equals (&p0, &p1)) | ||||
|   if (graphene_point_equal (&p0, &p1)) | ||||
|     return 0; | ||||
|  | ||||
|   clutter_point_distance (&p0, &p1, &x_distance, &y_distance); | ||||
|   graphene_point_distance (&p0, &p1, &x_distance, &y_distance); | ||||
|  | ||||
|   angle = atan2 (x_distance, y_distance); | ||||
|  | ||||
| @@ -2161,9 +2161,9 @@ clutter_event_get_scroll_source (const ClutterEvent *event) | ||||
| ClutterScrollFinishFlags | ||||
| clutter_event_get_scroll_finish_flags (const ClutterEvent *event) | ||||
| { | ||||
|   g_return_val_if_fail (event != NULL, CLUTTER_SCROLL_SOURCE_UNKNOWN); | ||||
|   g_return_val_if_fail (event != NULL, CLUTTER_SCROLL_FINISHED_NONE); | ||||
|   g_return_val_if_fail (event->type == CLUTTER_SCROLL, | ||||
|                         CLUTTER_SCROLL_SOURCE_UNKNOWN); | ||||
|                         CLUTTER_SCROLL_FINISHED_NONE); | ||||
|  | ||||
|   return event->scroll.finish_flags; | ||||
| } | ||||
|   | ||||
| @@ -686,7 +686,7 @@ void                    clutter_event_get_coords                (const ClutterEv | ||||
|                                                                  gfloat                 *y); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_event_get_position              (const ClutterEvent     *event, | ||||
|                                                                  ClutterPoint           *position); | ||||
|                                                                  graphene_point_t       *position); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_event_get_distance              (const ClutterEvent     *source, | ||||
|                                                                  const ClutterEvent     *target); | ||||
|   | ||||
| @@ -33,8 +33,6 @@ | ||||
|  * | ||||
|  * It is possible to ask whether Clutter has support for specific features at | ||||
|  * run-time. | ||||
|  * | ||||
|  * See also cogl_get_features() and #CoglFeatureFlags | ||||
|  */ | ||||
|  | ||||
| #include "clutter-build-config.h" | ||||
| @@ -60,20 +58,13 @@ typedef struct ClutterFeatures | ||||
| static ClutterFeatures* __features = NULL; | ||||
|  | ||||
| static ClutterFeatureFlags | ||||
| clutter_features_from_cogl (guint cogl_flags) | ||||
| clutter_features_from_cogl (void) | ||||
| { | ||||
|   ClutterFeatureFlags clutter_flags = 0; | ||||
|    | ||||
|   if (cogl_flags & COGL_FEATURE_TEXTURE_YUV) | ||||
|     clutter_flags |= CLUTTER_FEATURE_TEXTURE_YUV; | ||||
|    | ||||
|   if (cogl_flags & COGL_FEATURE_TEXTURE_READ_PIXELS) | ||||
|     clutter_flags |= CLUTTER_FEATURE_TEXTURE_READ_PIXELS; | ||||
|    | ||||
|   clutter_flags |= CLUTTER_FEATURE_SHADERS_GLSL; | ||||
|    | ||||
|   if (cogl_flags & COGL_FEATURE_OFFSCREEN) | ||||
|     clutter_flags |= CLUTTER_FEATURE_OFFSCREEN; | ||||
|   clutter_flags |= CLUTTER_FEATURE_OFFSCREEN; | ||||
|    | ||||
|   return clutter_flags; | ||||
| } | ||||
| @@ -101,7 +92,7 @@ _clutter_feature_init (GError **error) | ||||
|   if (!_clutter_backend_create_context (context->backend, error)) | ||||
|     return FALSE; | ||||
|  | ||||
|   __features->flags = (clutter_features_from_cogl (cogl_get_features ()) | ||||
|   __features->flags = (clutter_features_from_cogl () | ||||
|                     | _clutter_backend_get_features (context->backend)); | ||||
|  | ||||
|   __features->features_set = TRUE; | ||||
|   | ||||
| @@ -118,7 +118,7 @@ struct _ClutterGestureActionPrivate | ||||
|   gint requested_nb_points; | ||||
|   GArray *points; | ||||
|  | ||||
|   guint actor_capture_id; | ||||
|   gulong actor_capture_id; | ||||
|   gulong stage_capture_id; | ||||
|  | ||||
|   ClutterGestureTriggerEdge edge; | ||||
| @@ -308,11 +308,7 @@ cancel_gesture (ClutterGestureAction *action) | ||||
|  | ||||
|   priv->in_gesture = FALSE; | ||||
|  | ||||
|   if (priv->stage_capture_id != 0) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->stage_capture_id); | ||||
|       priv->stage_capture_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->stage_capture_id, priv->stage); | ||||
|  | ||||
|   actor = clutter_actor_meta_get_actor (CLUTTER_ACTOR_META (action)); | ||||
|   g_signal_emit (action, gesture_signals[GESTURE_CANCEL], 0, actor); | ||||
| @@ -481,11 +477,8 @@ stage_captured_event_cb (ClutterActor         *stage, | ||||
|       break; | ||||
|     } | ||||
|  | ||||
|   if (priv->points->len == 0 && priv->stage_capture_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (priv->stage, priv->stage_capture_id); | ||||
|       priv->stage_capture_id = 0; | ||||
|     } | ||||
|   if (priv->points->len == 0) | ||||
|     g_clear_signal_handler (&priv->stage_capture_id, priv->stage); | ||||
|  | ||||
|   return CLUTTER_EVENT_PROPAGATE; | ||||
| } | ||||
| @@ -538,7 +531,7 @@ clutter_gesture_action_set_actor (ClutterActorMeta *meta, | ||||
|       ClutterActor *old_actor = clutter_actor_meta_get_actor (meta); | ||||
|  | ||||
|       if (old_actor != NULL) | ||||
|         g_signal_handler_disconnect (old_actor, priv->actor_capture_id); | ||||
|         g_clear_signal_handler (&priv->actor_capture_id, old_actor); | ||||
|  | ||||
|       priv->actor_capture_id = 0; | ||||
|     } | ||||
| @@ -546,7 +539,7 @@ clutter_gesture_action_set_actor (ClutterActorMeta *meta, | ||||
|   if (priv->stage_capture_id != 0) | ||||
|     { | ||||
|       if (priv->stage != NULL) | ||||
|         g_signal_handler_disconnect (priv->stage, priv->stage_capture_id); | ||||
|         g_clear_signal_handler (&priv->stage_capture_id, priv->stage); | ||||
|  | ||||
|       priv->stage_capture_id = 0; | ||||
|       priv->stage = NULL; | ||||
|   | ||||
							
								
								
									
										111
									
								
								clutter/clutter/clutter-graphene.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								clutter/clutter/clutter-graphene.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Authored By Georges Basile Stavracas Neto <georges.stavracas@gmail.com> | ||||
|  * | ||||
|  * Copyright (C) 2019 Endless, Inc | ||||
|  * Copyright (C) 2009, 2010 Intel Corp | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #include "clutter-graphene.h" | ||||
|  | ||||
| #include "clutter-private.h" | ||||
| #include "clutter-types.h" | ||||
|  | ||||
| static gboolean | ||||
| graphene_point_progress (const GValue *a, | ||||
|                          const GValue *b, | ||||
|                          double        progress, | ||||
|                          GValue       *retval) | ||||
| { | ||||
|   const graphene_point_t *ap = g_value_get_boxed (a); | ||||
|   const graphene_point_t *bp = g_value_get_boxed (b); | ||||
|   graphene_point_t res; | ||||
|  | ||||
|   graphene_point_interpolate (ap, bp, progress, &res); | ||||
|  | ||||
|   g_value_set_boxed (retval, &res); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| graphene_point3d_progress (const GValue *a, | ||||
|                            const GValue *b, | ||||
|                            double        progress, | ||||
|                            GValue       *retval) | ||||
| { | ||||
|   const graphene_point3d_t *av = g_value_get_boxed (a); | ||||
|   const graphene_point3d_t *bv = g_value_get_boxed (b); | ||||
|   graphene_point3d_t res; | ||||
|  | ||||
|   graphene_point3d_interpolate (av, bv, progress, &res); | ||||
|  | ||||
|   g_value_set_boxed (retval, &res); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| graphene_rect_progress (const GValue *a, | ||||
|                         const GValue *b, | ||||
|                         double        progress, | ||||
|                         GValue       *retval) | ||||
| { | ||||
|   const graphene_rect_t *rect_a = g_value_get_boxed (a); | ||||
|   const graphene_rect_t *rect_b = g_value_get_boxed (b); | ||||
|   graphene_rect_t res; | ||||
|  | ||||
|   graphene_rect_interpolate (rect_a, rect_b, progress, &res); | ||||
|  | ||||
|   g_value_set_boxed (retval, &res); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| graphene_size_progress (const GValue *a, | ||||
|                         const GValue *b, | ||||
|                         double        progress, | ||||
|                         GValue       *retval) | ||||
| { | ||||
|   const graphene_size_t *as = g_value_get_boxed (a); | ||||
|   const graphene_size_t *bs = g_value_get_boxed (b); | ||||
|   graphene_size_t res; | ||||
|  | ||||
|   graphene_size_interpolate (as, bs, progress, &res); | ||||
|  | ||||
|   g_value_set_boxed (retval, &res); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_graphene_init (void) | ||||
| { | ||||
|   clutter_interval_register_progress_func (GRAPHENE_TYPE_POINT, | ||||
|                                            graphene_point_progress); | ||||
|   clutter_interval_register_progress_func (GRAPHENE_TYPE_POINT3D, | ||||
|                                            graphene_point3d_progress); | ||||
|   clutter_interval_register_progress_func (GRAPHENE_TYPE_RECT, | ||||
|                                            graphene_rect_progress); | ||||
|   clutter_interval_register_progress_func (GRAPHENE_TYPE_SIZE, | ||||
|                                            graphene_size_progress); | ||||
| } | ||||
| @@ -3,7 +3,10 @@ | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2008 OpenedHand | ||||
|  * Authored By Georges Basile Stavracas Neto <georges.stavracas@gmail.com> | ||||
|  * | ||||
|  * Copyright (C) 2019 Endless, Inc | ||||
|  * Copyright (C) 2009, 2010 Intel Corp | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  * modify it under the terms of the GNU Lesser General Public | ||||
| @@ -17,26 +20,11 @@ | ||||
|  * | ||||
|  * 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/>.
 | ||||
|  * | ||||
|  * Author: Emmanuele Bassi <ebassi@linux.intel.com> | ||||
|  */ | ||||
| 
 | ||||
| #if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION) | ||||
| #error "Only <clutter/clutter.h> can be included directly." | ||||
| #ifndef CLUTTER_GRAPHENE_H | ||||
| #define CLUTTER_GRAPHENE_H | ||||
| 
 | ||||
| void clutter_graphene_init (void); | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __CLUTTER_STAGE_MANAGER_DEPRECATED_H__ | ||||
| #define __CLUTTER_STAGE_MANAGER_DEPRECATED_H__ | ||||
| 
 | ||||
| #include <clutter/clutter-stage-manager.h> | ||||
| 
 | ||||
| G_BEGIN_DECLS | ||||
| 
 | ||||
| CLUTTER_DEPRECATED | ||||
| void    clutter_stage_manager_set_default_stage (ClutterStageManager *stage_manager, | ||||
|                                                  ClutterStage        *stage); | ||||
| 
 | ||||
| G_END_DECLS | ||||
| 
 | ||||
| #endif /*__CLUTTER_STAGE_MANAGER_DEPRECATED_H__ */ | ||||
| 
 | ||||
| @@ -44,12 +44,12 @@ | ||||
|  * SECTION:clutter-grid-layout | ||||
|  * @Short_description: A layout manager for a grid of actors | ||||
|  * @Title: ClutterGridLayout | ||||
|  * @See_also: #ClutterTableLayout, #ClutterBoxLayout | ||||
|  * @See_also: #ClutterBoxLayout | ||||
|  * | ||||
|  * #ClutterGridLayout is a layout manager which arranges its child widgets in | ||||
|  * rows and columns. It is a very similar to #ClutterTableLayout and | ||||
|  * #ClutterBoxLayout, but it consistently uses #ClutterActor's | ||||
|  * alignment and expansion flags instead of custom child properties. | ||||
|  * rows and columns. It is a very similar to #ClutterBoxLayout, but it | ||||
|  * consistently uses #ClutterActor's alignment and expansion flags instead of | ||||
|  * custom child properties. | ||||
|  * | ||||
|  * Children are added using clutter_grid_layout_attach(). They can span | ||||
|  * multiple rows or columns. It is also possible to add a child next to an | ||||
|   | ||||
							
								
								
									
										254
									
								
								clutter/clutter/clutter-input-device-private.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										254
									
								
								clutter/clutter/clutter-input-device-private.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,254 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright © 2009, 2010, 2011  Intel Corp. | ||||
|  * | ||||
|  * 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/>. | ||||
|  * | ||||
|  * Author: Emmanuele Bassi <ebassi@linux.intel.com> | ||||
|  */ | ||||
|  | ||||
| #ifndef CLUTTER_INPUT_DEVICE_PRIVATE_H | ||||
| #define CLUTTER_INPUT_DEVICE_PRIVATE_H | ||||
|  | ||||
| #if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION) | ||||
| #error "Only <clutter/clutter.h> can be included directly." | ||||
| #endif | ||||
|  | ||||
| #include <clutter/clutter-input-device.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| typedef struct _ClutterAxisInfo | ||||
| { | ||||
|   ClutterInputAxis axis; | ||||
|  | ||||
|   gdouble min_axis; | ||||
|   gdouble max_axis; | ||||
|  | ||||
|   gdouble min_value; | ||||
|   gdouble max_value; | ||||
|  | ||||
|   gdouble resolution; | ||||
| } ClutterAxisInfo; | ||||
|  | ||||
| typedef struct _ClutterKeyInfo | ||||
| { | ||||
|   guint keyval; | ||||
|   ClutterModifierType modifiers; | ||||
| } ClutterKeyInfo; | ||||
|  | ||||
| typedef struct _ClutterScrollInfo | ||||
| { | ||||
|   guint axis_id; | ||||
|   ClutterScrollDirection direction; | ||||
|   gdouble increment; | ||||
|  | ||||
|   gdouble last_value; | ||||
|   guint last_value_valid : 1; | ||||
| } ClutterScrollInfo; | ||||
|  | ||||
| typedef struct _ClutterTouchInfo | ||||
| { | ||||
|   ClutterEventSequence *sequence; | ||||
|   ClutterActor *actor; | ||||
|  | ||||
|   gfloat current_x; | ||||
|   gfloat current_y; | ||||
| } ClutterTouchInfo; | ||||
|  | ||||
| typedef struct _ClutterPtrA11yData | ||||
| { | ||||
|   int n_btn_pressed; | ||||
|   float current_x; | ||||
|   float current_y; | ||||
|  | ||||
|   float dwell_x; | ||||
|   float dwell_y; | ||||
|   gboolean dwell_drag_started; | ||||
|   gboolean dwell_gesture_started; | ||||
|   guint dwell_timer; | ||||
|   guint dwell_position_timer; | ||||
|  | ||||
|   guint secondary_click_timer; | ||||
|   gboolean secondary_click_triggered; | ||||
| } ClutterPtrA11yData; | ||||
|  | ||||
| struct _ClutterInputDevice | ||||
| { | ||||
|   GObject parent_instance; | ||||
|  | ||||
|   gint id; | ||||
|  | ||||
|   ClutterInputDeviceType device_type; | ||||
|   ClutterInputMode device_mode; | ||||
|  | ||||
|   gchar *device_name; | ||||
|  | ||||
|   ClutterSeat *seat; | ||||
|  | ||||
|   ClutterBackend *backend; | ||||
|  | ||||
|   /* the associated device */ | ||||
|   ClutterInputDevice *associated; | ||||
|  | ||||
|   GList *slaves; | ||||
|  | ||||
|   /* the actor underneath the pointer */ | ||||
|   ClutterActor *cursor_actor; | ||||
|   GHashTable   *inv_touch_sequence_actors; | ||||
|  | ||||
|   /* the actor that has a grab in place for the device */ | ||||
|   ClutterActor *pointer_grab_actor; | ||||
|   ClutterActor *keyboard_grab_actor; | ||||
|   GHashTable   *sequence_grab_actors; | ||||
|   GHashTable   *inv_sequence_grab_actors; | ||||
|  | ||||
|   /* the current click count */ | ||||
|   gint click_count; | ||||
|  | ||||
|   /* the stage the device is on */ | ||||
|   ClutterStage *stage; | ||||
|  | ||||
|   /* the current state */ | ||||
|   gfloat current_x; | ||||
|   gfloat current_y; | ||||
|   guint32 current_time; | ||||
|   gint current_button_number; | ||||
|   ClutterModifierType current_state; | ||||
|  | ||||
|   /* the current touch points states */ | ||||
|   GHashTable *touch_sequences_info; | ||||
|  | ||||
|   /* the previous state, used for click count generation */ | ||||
|   gint previous_x; | ||||
|   gint previous_y; | ||||
|   guint32 previous_time; | ||||
|   gint previous_button_number; | ||||
|   ClutterModifierType previous_state; | ||||
|  | ||||
|   GArray *axes; | ||||
|  | ||||
|   guint n_keys; | ||||
|   GArray *keys; | ||||
|  | ||||
|   GArray *scroll_info; | ||||
|  | ||||
|   gchar *vendor_id; | ||||
|   gchar *product_id; | ||||
|   gchar *node_path; | ||||
|  | ||||
|   GPtrArray *tools; | ||||
|  | ||||
|   gint n_rings; | ||||
|   gint n_strips; | ||||
|   gint n_mode_groups; | ||||
|  | ||||
|   ClutterInputDeviceMapping mapping_mode; | ||||
|  | ||||
|   guint has_cursor : 1; | ||||
|   guint is_enabled : 1; | ||||
|  | ||||
|   /* Accessiblity */ | ||||
|   ClutterVirtualInputDevice *accessibility_virtual_device; | ||||
|   ClutterPtrA11yData *ptr_a11y_data; | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_associated_device (ClutterInputDevice *device, | ||||
|                                                   ClutterInputDevice *associated); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_add_slave (ClutterInputDevice *master, | ||||
|                                       ClutterInputDevice *slave); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_remove_slave (ClutterInputDevice *master, | ||||
|                                          ClutterInputDevice *slave); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_input_device_update_from_tool (ClutterInputDevice     *device, | ||||
|                                             ClutterInputDeviceTool *tool); | ||||
| CLUTTER_EXPORT | ||||
| ClutterStage * _clutter_input_device_get_stage (ClutterInputDevice *device); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_stage (ClutterInputDevice *device, | ||||
|                                       ClutterStage       *stage); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_coords (ClutterInputDevice   *device, | ||||
|                                        ClutterEventSequence *sequence, | ||||
|                                        gfloat                x, | ||||
|                                        gfloat                y, | ||||
|                                        ClutterStage         *stage); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_state (ClutterInputDevice  *device, | ||||
|                                       ClutterModifierType  state); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_time (ClutterInputDevice *device, | ||||
|                                      guint32             time_); | ||||
| void _clutter_input_device_set_actor (ClutterInputDevice   *device, | ||||
|                                       ClutterEventSequence *sequence, | ||||
|                                       ClutterActor         *actor, | ||||
|                                       gboolean              emit_crossing); | ||||
| ClutterActor * _clutter_input_device_update (ClutterInputDevice   *device, | ||||
|                                              ClutterEventSequence *sequence, | ||||
|                                              gboolean              emit_crossing); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_add_event_sequence (ClutterInputDevice *device, | ||||
|                                                ClutterEvent       *event); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_remove_event_sequence (ClutterInputDevice *device, | ||||
|                                                   ClutterEvent       *event); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_set_n_keys (ClutterInputDevice *device, | ||||
|                                        guint               n_keys); | ||||
| CLUTTER_EXPORT | ||||
| gboolean _clutter_input_device_translate_axis (ClutterInputDevice *device, | ||||
|                                                guint               index_, | ||||
|                                                gdouble             value, | ||||
|                                                gdouble            *axis_value); | ||||
| CLUTTER_EXPORT | ||||
| guint _clutter_input_device_add_axis (ClutterInputDevice *device, | ||||
|                                       ClutterInputAxis    axis, | ||||
|                                       gdouble             minimum, | ||||
|                                       gdouble             maximum, | ||||
|                                       gdouble             resolution); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_reset_axes (ClutterInputDevice *device); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_add_scroll_info (ClutterInputDevice     *device, | ||||
|                                             guint                   index_, | ||||
|                                             ClutterScrollDirection  direction, | ||||
|                                             gdouble                 increment); | ||||
| CLUTTER_EXPORT | ||||
| gboolean _clutter_input_device_get_scroll_delta (ClutterInputDevice     *device, | ||||
|                                                  guint                   index_, | ||||
|                                                  gdouble                 value, | ||||
|                                                  ClutterScrollDirection *direction_p, | ||||
|                                                  gdouble                *delta_p); | ||||
| CLUTTER_EXPORT | ||||
| void _clutter_input_device_reset_scroll_info (ClutterInputDevice *device); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_input_device_add_tool (ClutterInputDevice     *device, | ||||
|                                     ClutterInputDeviceTool *tool); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDeviceTool * | ||||
|    clutter_input_device_lookup_tool (ClutterInputDevice         *device, | ||||
|                                      guint64                     serial, | ||||
|                                      ClutterInputDeviceToolType  type); | ||||
|  | ||||
| #endif /* CLUTTER_INPUT_DEVICE_PRIVATE_H */ | ||||
| @@ -37,12 +37,12 @@ | ||||
|  | ||||
| #include "clutter-actor-private.h" | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-enum-types.h" | ||||
| #include "clutter-event-private.h" | ||||
| #include "clutter-marshal.h" | ||||
| #include "clutter-private.h" | ||||
| #include "clutter-stage-private.h" | ||||
| #include "clutter-input-device-private.h" | ||||
| #include "clutter-input-device-tool.h" | ||||
|  | ||||
| #include <math.h> | ||||
| @@ -57,7 +57,7 @@ enum | ||||
|   PROP_NAME, | ||||
|  | ||||
|   PROP_DEVICE_TYPE, | ||||
|   PROP_DEVICE_MANAGER, | ||||
|   PROP_SEAT, | ||||
|   PROP_DEVICE_MODE, | ||||
|  | ||||
|   PROP_HAS_CURSOR, | ||||
| @@ -170,8 +170,8 @@ clutter_input_device_set_property (GObject      *gobject, | ||||
|       self->device_type = g_value_get_enum (value); | ||||
|       break; | ||||
|  | ||||
|     case PROP_DEVICE_MANAGER: | ||||
|       self->device_manager = g_value_get_object (value); | ||||
|     case PROP_SEAT: | ||||
|       self->seat = g_value_get_object (value); | ||||
|       break; | ||||
|  | ||||
|     case PROP_DEVICE_MODE: | ||||
| @@ -246,8 +246,8 @@ clutter_input_device_get_property (GObject    *gobject, | ||||
|       g_value_set_enum (value, self->device_type); | ||||
|       break; | ||||
|  | ||||
|     case PROP_DEVICE_MANAGER: | ||||
|       g_value_set_object (value, self->device_manager); | ||||
|     case PROP_SEAT: | ||||
|       g_value_set_object (value, self->seat); | ||||
|       break; | ||||
|  | ||||
|     case PROP_DEVICE_MODE: | ||||
| @@ -361,17 +361,15 @@ clutter_input_device_class_init (ClutterInputDeviceClass *klass) | ||||
|                        G_PARAM_CONSTRUCT_ONLY); | ||||
|  | ||||
|   /** | ||||
|    * ClutterInputDevice:device-manager: | ||||
|    * ClutterInputDevice:seat: | ||||
|    * | ||||
|    * The #ClutterDeviceManager instance which owns the device | ||||
|    * | ||||
|    * Since: 1.6 | ||||
|    * The #ClutterSeat instance which owns the device | ||||
|    */ | ||||
|   obj_props[PROP_DEVICE_MANAGER] = | ||||
|     g_param_spec_object ("device-manager", | ||||
|                          P_("Device Manager"), | ||||
|                          P_("The device manager instance"), | ||||
|                          CLUTTER_TYPE_DEVICE_MANAGER, | ||||
|   obj_props[PROP_SEAT] = | ||||
|     g_param_spec_object ("seat", | ||||
|                          P_("Seat"), | ||||
|                          P_("Seat"), | ||||
|                          CLUTTER_TYPE_SEAT, | ||||
|                          CLUTTER_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY); | ||||
|  | ||||
|   /** | ||||
| @@ -991,7 +989,7 @@ clutter_input_device_get_enabled (ClutterInputDevice *device) | ||||
| gboolean | ||||
| clutter_input_device_get_coords (ClutterInputDevice   *device, | ||||
|                                  ClutterEventSequence *sequence, | ||||
|                                  ClutterPoint         *point) | ||||
|                                  graphene_point_t     *point) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_INPUT_DEVICE (device), FALSE); | ||||
|   g_return_val_if_fail (point != NULL, FALSE); | ||||
| @@ -1038,7 +1036,7 @@ _clutter_input_device_update (ClutterInputDevice   *device, | ||||
|   ClutterStage *stage; | ||||
|   ClutterActor *new_cursor_actor; | ||||
|   ClutterActor *old_cursor_actor; | ||||
|   ClutterPoint point = { -1, -1 }; | ||||
|   graphene_point_t point = GRAPHENE_POINT_INIT (-1.0f, -1.0f); | ||||
|   ClutterInputDeviceType device_type = device->device_type; | ||||
|  | ||||
|   g_assert (device_type != CLUTTER_KEYBOARD_DEVICE && | ||||
| @@ -1224,11 +1222,11 @@ clutter_input_device_get_device_mode (ClutterInputDevice *device) | ||||
|  * | ||||
|  *   translate_native_event_to_clutter (native_event, &c_event); | ||||
|  * | ||||
|  *   // get the device manager | ||||
|  *   manager = clutter_device_manager_get_default (); | ||||
|  *   // get the seat | ||||
|  *   seat = clutter_backend_get_deafult_seat (clutter_get_default_backend ()); | ||||
|  * | ||||
|  *   // use the default Core Pointer that Clutter backends register by default | ||||
|  *   device = clutter_device_manager_get_core_device (manager, %CLUTTER_POINTER_DEVICE); | ||||
|  *   device = clutter_seat_get_pointer (seat); | ||||
|  * | ||||
|  *   // update the state of the input device | ||||
|  *   clutter_input_device_update_from_event (device, &c_event, FALSE); | ||||
| @@ -2441,3 +2439,19 @@ clutter_input_device_is_grouped (ClutterInputDevice *device, | ||||
|  | ||||
|   return CLUTTER_INPUT_DEVICE_GET_CLASS (device)->is_grouped (device, other_device); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_input_device_get_seat: | ||||
|  * @device: a #ClutterInputDevice | ||||
|  * | ||||
|  * Returns the seat the device belongs to | ||||
|  * | ||||
|  * Returns: (transfer none): the device seat | ||||
|  **/ | ||||
| ClutterSeat * | ||||
| clutter_input_device_get_seat (ClutterInputDevice *device) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_INPUT_DEVICE (device), NULL); | ||||
|  | ||||
|   return device->seat; | ||||
| } | ||||
|   | ||||
| @@ -28,10 +28,40 @@ | ||||
| #error "Only <clutter/clutter.h> can be included directly." | ||||
| #endif | ||||
|  | ||||
| #include <clutter/clutter-backend.h> | ||||
| #include <clutter/clutter-types.h> | ||||
| #include <clutter/clutter-seat.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| typedef void (*ClutterEmitInputDeviceEvent) (ClutterEvent       *event, | ||||
|                                              ClutterInputDevice *device); | ||||
|  | ||||
| struct _ClutterInputDeviceClass | ||||
| { | ||||
|   GObjectClass parent_class; | ||||
|  | ||||
|   gboolean (* keycode_to_evdev) (ClutterInputDevice *device, | ||||
|                                  guint               hardware_keycode, | ||||
|                                  guint              *evdev_keycode); | ||||
|   void (* update_from_tool) (ClutterInputDevice     *device, | ||||
|                              ClutterInputDeviceTool *tool); | ||||
|  | ||||
|   gboolean (* is_mode_switch_button) (ClutterInputDevice *device, | ||||
|                                       guint               group, | ||||
|                                       guint               button); | ||||
|   gint (* get_group_n_modes) (ClutterInputDevice *device, | ||||
|                               gint                group); | ||||
|  | ||||
|   gboolean (* is_grouped) (ClutterInputDevice *device, | ||||
|                            ClutterInputDevice *other_device); | ||||
|  | ||||
|   /* Keyboard accessbility */ | ||||
|   void (* process_kbd_a11y_event) (ClutterEvent               *event, | ||||
|                                    ClutterInputDevice         *device, | ||||
|                                    ClutterEmitInputDeviceEvent emit_event_func); | ||||
| }; | ||||
|  | ||||
| #define CLUTTER_TYPE_INPUT_DEVICE               (clutter_input_device_get_type ()) | ||||
| #define CLUTTER_INPUT_DEVICE(obj)               (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_INPUT_DEVICE, ClutterInputDevice)) | ||||
| #define CLUTTER_IS_INPUT_DEVICE(obj)            (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_INPUT_DEVICE)) | ||||
| @@ -58,7 +88,7 @@ gint                    clutter_input_device_get_device_id      (ClutterInputDev | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_input_device_get_coords        (ClutterInputDevice   *device, | ||||
|                                                                 ClutterEventSequence *sequence, | ||||
|                                                                 ClutterPoint         *point); | ||||
|                                                                 graphene_point_t     *point); | ||||
| CLUTTER_EXPORT | ||||
| ClutterModifierType     clutter_input_device_get_modifier_state (ClutterInputDevice  *device); | ||||
| CLUTTER_EXPORT | ||||
| @@ -171,6 +201,8 @@ void                      clutter_input_device_set_mapping_mode (ClutterInputDev | ||||
| CLUTTER_EXPORT | ||||
| gboolean                  clutter_input_device_is_grouped       (ClutterInputDevice *device, | ||||
|                                                                  ClutterInputDevice *other_device); | ||||
| CLUTTER_EXPORT | ||||
| ClutterSeat *             clutter_input_device_get_seat         (ClutterInputDevice *device); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
| @@ -89,8 +89,8 @@ clutter_input_focus_reset (ClutterInputFocus *focus) | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_input_focus_set_cursor_location (ClutterInputFocus *focus, | ||||
|                                          const ClutterRect *rect) | ||||
| clutter_input_focus_set_cursor_location (ClutterInputFocus     *focus, | ||||
|                                          const graphene_rect_t *rect) | ||||
| { | ||||
|   ClutterInputFocusPrivate *priv; | ||||
|  | ||||
|   | ||||
| @@ -57,8 +57,8 @@ gboolean clutter_input_focus_is_focused (ClutterInputFocus *focus); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_input_focus_reset (ClutterInputFocus *focus); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_input_focus_set_cursor_location (ClutterInputFocus *focus, | ||||
|                                               const ClutterRect *rect); | ||||
| void clutter_input_focus_set_cursor_location (ClutterInputFocus     *focus, | ||||
|                                               const graphene_rect_t *rect); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_input_focus_set_surrounding (ClutterInputFocus *focus, | ||||
|   | ||||
| @@ -26,8 +26,8 @@ ClutterInputFocus * clutter_input_method_get_focus (ClutterInputMethod *method); | ||||
|  | ||||
| void clutter_input_method_reset               (ClutterInputMethod *method); | ||||
|  | ||||
| void clutter_input_method_set_cursor_location (ClutterInputMethod *method, | ||||
|                                                const ClutterRect  *rect); | ||||
| void clutter_input_method_set_cursor_location (ClutterInputMethod    *method, | ||||
|                                                const graphene_rect_t *rect); | ||||
| void clutter_input_method_set_surrounding     (ClutterInputMethod *method, | ||||
|                                                const gchar        *text, | ||||
|                                                guint               cursor, | ||||
|   | ||||
| @@ -22,10 +22,10 @@ | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #include "clutter-private.h" | ||||
| #include "clutter/clutter-input-device-private.h" | ||||
| #include "clutter/clutter-input-method.h" | ||||
| #include "clutter/clutter-input-method-private.h" | ||||
| #include "clutter/clutter-input-focus-private.h" | ||||
| #include "clutter/clutter-device-manager-private.h" | ||||
|  | ||||
| typedef struct _ClutterInputMethodPrivate ClutterInputMethodPrivate; | ||||
|  | ||||
| @@ -187,7 +187,7 @@ clutter_input_method_class_init (ClutterInputMethodClass *klass) | ||||
|                   G_TYPE_FROM_CLASS (object_class), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, NULL, | ||||
|                   G_TYPE_NONE, 1, CLUTTER_TYPE_RECT); | ||||
|                   G_TYPE_NONE, 1, GRAPHENE_TYPE_RECT); | ||||
|  | ||||
|   pspecs[PROP_CONTENT_HINTS] = | ||||
|     g_param_spec_flags ("content-hints", | ||||
| @@ -377,8 +377,8 @@ clutter_input_method_reset (ClutterInputMethod *im) | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_input_method_set_cursor_location (ClutterInputMethod *im, | ||||
|                                           const ClutterRect  *rect) | ||||
| clutter_input_method_set_cursor_location (ClutterInputMethod    *im, | ||||
|                                           const graphene_rect_t *rect) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_INPUT_METHOD (im)); | ||||
|  | ||||
| @@ -452,8 +452,8 @@ clutter_input_method_forward_key (ClutterInputMethod *im, | ||||
|                                   gboolean            press) | ||||
| { | ||||
|   ClutterInputMethodPrivate *priv; | ||||
|   ClutterDeviceManager *device_manager; | ||||
|   ClutterInputDevice *keyboard; | ||||
|   ClutterSeat *seat; | ||||
|   ClutterStage *stage; | ||||
|   ClutterEvent *event; | ||||
|  | ||||
| @@ -463,9 +463,8 @@ clutter_input_method_forward_key (ClutterInputMethod *im, | ||||
|   if (!priv->focus) | ||||
|     return; | ||||
|  | ||||
|   device_manager = clutter_device_manager_get_default (); | ||||
|   keyboard = clutter_device_manager_get_core_device (device_manager, | ||||
|                                                      CLUTTER_KEYBOARD_DEVICE); | ||||
|   seat = clutter_backend_get_default_seat (clutter_get_default_backend ()); | ||||
|   keyboard = clutter_seat_get_keyboard (seat); | ||||
|   stage = _clutter_input_device_get_stage (keyboard); | ||||
|   if (stage == NULL) | ||||
|     return; | ||||
|   | ||||
| @@ -42,8 +42,8 @@ struct _ClutterInputMethodClass | ||||
|  | ||||
|   void (* reset) (ClutterInputMethod *im); | ||||
|  | ||||
|   void (* set_cursor_location) (ClutterInputMethod          *im, | ||||
|                                 const ClutterRect           *rect); | ||||
|   void (* set_cursor_location) (ClutterInputMethod    *im, | ||||
|                                 const graphene_rect_t *rect); | ||||
|   void (* set_surrounding) (ClutterInputMethod *im, | ||||
|                             const gchar        *text, | ||||
|                             guint               cursor, | ||||
|   | ||||
| @@ -25,10 +25,9 @@ | ||||
|  | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #include "clutter-device-manager.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-enum-types.h" | ||||
| #include "clutter-input-device.h" | ||||
| #include "clutter-input-device-private.h" | ||||
| #include "clutter-input-pointer-a11y-private.h" | ||||
| #include "clutter-main.h" | ||||
| #include "clutter-virtual-input-device.h" | ||||
| @@ -38,7 +37,7 @@ is_secondary_click_enabled (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return (settings.controls & CLUTTER_A11Y_SECONDARY_CLICK_ENABLED); | ||||
| } | ||||
| @@ -48,7 +47,7 @@ is_dwell_click_enabled (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return (settings.controls & CLUTTER_A11Y_DWELL_ENABLED); | ||||
| } | ||||
| @@ -58,7 +57,7 @@ get_secondary_click_delay (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return settings.secondary_click_delay; | ||||
| } | ||||
| @@ -68,7 +67,7 @@ get_dwell_delay (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return settings.dwell_delay; | ||||
| } | ||||
| @@ -78,7 +77,7 @@ get_dwell_threshold (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return settings.dwell_threshold; | ||||
| } | ||||
| @@ -88,7 +87,7 @@ get_dwell_mode (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return settings.dwell_mode; | ||||
| } | ||||
| @@ -98,7 +97,7 @@ get_dwell_click_type (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   return settings.dwell_click_type; | ||||
| } | ||||
| @@ -109,7 +108,7 @@ get_dwell_click_type_for_direction (ClutterInputDevice               *device, | ||||
| { | ||||
|   ClutterPointerA11ySettings settings; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   if (direction == settings.dwell_gesture_single) | ||||
|     return CLUTTER_A11Y_DWELL_CLICK_TYPE_PRIMARY; | ||||
| @@ -168,7 +167,7 @@ trigger_secondary_click (gpointer data) | ||||
|   device->ptr_a11y_data->secondary_click_triggered = TRUE; | ||||
|   device->ptr_a11y_data->secondary_click_timer = 0; | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-stopped", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_SECONDARY_CLICK, | ||||
| @@ -185,7 +184,7 @@ start_secondary_click_timeout (ClutterInputDevice *device) | ||||
|   device->ptr_a11y_data->secondary_click_timer = | ||||
|     clutter_threads_add_timeout (delay, trigger_secondary_click, device); | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-started", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_SECONDARY_CLICK, | ||||
| @@ -197,10 +196,10 @@ stop_secondary_click_timeout (ClutterInputDevice *device) | ||||
| { | ||||
|   if (device->ptr_a11y_data->secondary_click_timer) | ||||
|     { | ||||
|       g_source_remove (device->ptr_a11y_data->secondary_click_timer); | ||||
|       device->ptr_a11y_data->secondary_click_timer = 0; | ||||
|       g_clear_handle_id (&device->ptr_a11y_data->secondary_click_timer, | ||||
|                          g_source_remove); | ||||
|  | ||||
|       g_signal_emit_by_name (device->device_manager, | ||||
|       g_signal_emit_by_name (device->seat, | ||||
|                              "ptr-a11y-timeout-stopped", | ||||
|                              device, | ||||
|                              CLUTTER_A11Y_TIMEOUT_TYPE_SECONDARY_CLICK, | ||||
| @@ -304,7 +303,7 @@ update_dwell_click_type (ClutterInputDevice *device) | ||||
|   ClutterPointerA11ySettings settings; | ||||
|   ClutterPointerA11yDwellClickType dwell_click_type; | ||||
|  | ||||
|   clutter_device_manager_get_pointer_a11y_settings (device->device_manager, &settings); | ||||
|   clutter_seat_get_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|   dwell_click_type = settings.dwell_click_type; | ||||
|   switch (dwell_click_type) | ||||
| @@ -329,10 +328,9 @@ update_dwell_click_type (ClutterInputDevice *device) | ||||
|   if (dwell_click_type != settings.dwell_click_type) | ||||
|     { | ||||
|       settings.dwell_click_type = dwell_click_type; | ||||
|       clutter_device_manager_set_pointer_a11y_settings (device->device_manager, | ||||
|                                                         &settings); | ||||
|       clutter_seat_set_pointer_a11y_settings (device->seat, &settings); | ||||
|  | ||||
|       g_signal_emit_by_name (device->device_manager, | ||||
|       g_signal_emit_by_name (device->seat, | ||||
|                              "ptr-a11y-dwell-click-type-changed", | ||||
|                              dwell_click_type); | ||||
|     } | ||||
| @@ -437,7 +435,7 @@ trigger_dwell_gesture (gpointer data) | ||||
|   device->ptr_a11y_data->dwell_timer = | ||||
|     clutter_threads_add_timeout (delay, trigger_clear_dwell_gesture, device); | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-stopped", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_GESTURE, | ||||
| @@ -455,7 +453,7 @@ start_dwell_gesture_timeout (ClutterInputDevice *device) | ||||
|     clutter_threads_add_timeout (delay, trigger_dwell_gesture, device); | ||||
|   device->ptr_a11y_data->dwell_gesture_started = TRUE; | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-started", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_GESTURE, | ||||
| @@ -469,7 +467,7 @@ trigger_dwell_click (gpointer data) | ||||
|  | ||||
|   device->ptr_a11y_data->dwell_timer = 0; | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-stopped", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_DWELL, | ||||
| @@ -499,7 +497,7 @@ start_dwell_timeout (ClutterInputDevice *device) | ||||
|   device->ptr_a11y_data->dwell_timer = | ||||
|     clutter_threads_add_timeout (delay, trigger_dwell_click, device); | ||||
|  | ||||
|   g_signal_emit_by_name (device->device_manager, | ||||
|   g_signal_emit_by_name (device->seat, | ||||
|                          "ptr-a11y-timeout-started", | ||||
|                          device, | ||||
|                          CLUTTER_A11Y_TIMEOUT_TYPE_DWELL, | ||||
| @@ -511,11 +509,10 @@ stop_dwell_timeout (ClutterInputDevice *device) | ||||
| { | ||||
|   if (device->ptr_a11y_data->dwell_timer) | ||||
|     { | ||||
|       g_source_remove (device->ptr_a11y_data->dwell_timer); | ||||
|       device->ptr_a11y_data->dwell_timer = 0; | ||||
|       g_clear_handle_id (&device->ptr_a11y_data->dwell_timer, g_source_remove); | ||||
|       device->ptr_a11y_data->dwell_gesture_started = FALSE; | ||||
|  | ||||
|       g_signal_emit_by_name (device->device_manager, | ||||
|       g_signal_emit_by_name (device->seat, | ||||
|                              "ptr-a11y-timeout-stopped", | ||||
|                              device, | ||||
|                              CLUTTER_A11Y_TIMEOUT_TYPE_DWELL, | ||||
| @@ -574,8 +571,7 @@ is_device_core_pointer (ClutterInputDevice *device) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_device_manager_get_core_device (device->device_manager, | ||||
|                                                          CLUTTER_POINTER_DEVICE); | ||||
|   core_pointer = clutter_seat_get_pointer (device->seat); | ||||
|   if (core_pointer == NULL) | ||||
|     return FALSE; | ||||
|  | ||||
| @@ -589,8 +585,8 @@ _clutter_input_pointer_a11y_add_device (ClutterInputDevice *device) | ||||
|     return; | ||||
|  | ||||
|   device->accessibility_virtual_device = | ||||
|     clutter_device_manager_create_virtual_device (device->device_manager, | ||||
|                                                   CLUTTER_POINTER_DEVICE); | ||||
|     clutter_seat_create_virtual_device (device->seat, | ||||
|                                         CLUTTER_POINTER_DEVICE); | ||||
|  | ||||
|   device->ptr_a11y_data = g_new0 (ClutterPtrA11yData, 1); | ||||
| } | ||||
|   | ||||
| @@ -62,3 +62,9 @@ clutter_keymap_get_caps_lock_state (ClutterKeymap *keymap) | ||||
| { | ||||
|   return CLUTTER_KEYMAP_GET_CLASS (keymap)->get_caps_lock_state (keymap); | ||||
| } | ||||
|  | ||||
| PangoDirection | ||||
| clutter_keymap_get_direction (ClutterKeymap *keymap) | ||||
| { | ||||
|   return CLUTTER_KEYMAP_GET_CLASS (keymap)->get_direction (keymap); | ||||
| } | ||||
|   | ||||
| @@ -29,6 +29,7 @@ | ||||
| #include <clutter/clutter-macros.h> | ||||
|  | ||||
| #include <glib-object.h> | ||||
| #include <pango/pango.h> | ||||
|  | ||||
| typedef struct _ClutterKeymap ClutterKeymap; | ||||
| typedef struct _ClutterKeymapClass ClutterKeymapClass; | ||||
| @@ -39,6 +40,7 @@ struct _ClutterKeymapClass | ||||
|  | ||||
|   gboolean (* get_num_lock_state)  (ClutterKeymap *keymap); | ||||
|   gboolean (* get_caps_lock_state) (ClutterKeymap *keymap); | ||||
|   PangoDirection (* get_direction) (ClutterKeymap *keymap); | ||||
| }; | ||||
|  | ||||
| #define CLUTTER_TYPE_KEYMAP (clutter_keymap_get_type ()) | ||||
| @@ -53,4 +55,6 @@ gboolean clutter_keymap_get_num_lock_state  (ClutterKeymap *keymap); | ||||
| CLUTTER_EXPORT | ||||
| gboolean clutter_keymap_get_caps_lock_state (ClutterKeymap *keymap); | ||||
|  | ||||
| PangoDirection clutter_keymap_get_direction (ClutterKeymap *keymap); | ||||
|  | ||||
| #endif /* CLUTTER_KEYMAP_H */ | ||||
|   | ||||
| @@ -58,10 +58,6 @@ die "Could not open file keysymdef.h: $!\n" | ||||
| die "Could not open file clutter-keysyms.h: $!\n" | ||||
|     unless open(OUT_KEYSYMS, ">:utf8", "clutter-keysyms.h"); | ||||
|  | ||||
| # Output: clutter/clutter/deprecated/clutter-keysyms.h | ||||
| die "Could not open file clutter-keysyms-compat.h: $!\n" | ||||
|     unless open(OUT_KEYSYMS_COMPAT, ">:utf8", "deprecated/clutter-keysyms.h"); | ||||
|  | ||||
| my $LICENSE_HEADER= <<EOF; | ||||
| /* Clutter | ||||
|  * | ||||
| @@ -85,7 +81,6 @@ my $LICENSE_HEADER= <<EOF; | ||||
| EOF | ||||
|  | ||||
| print OUT_KEYSYMS $LICENSE_HEADER; | ||||
| print OUT_KEYSYMS_COMPAT $LICENSE_HEADER; | ||||
|  | ||||
| print OUT_KEYSYMS<<EOF; | ||||
|  | ||||
| @@ -104,23 +99,6 @@ print OUT_KEYSYMS<<EOF; | ||||
|  | ||||
| EOF | ||||
|  | ||||
| print OUT_KEYSYMS_COMPAT<<EOF; | ||||
| /* | ||||
|  * Compatibility version of clutter-keysyms.h. | ||||
|  * | ||||
|  * Since Clutter 1.4, the key symbol defines have been changed to have | ||||
|  * a KEY_ prefix. This is a compatibility header that is included when | ||||
|  * deprecated symbols are enabled. Consider porting to the new names | ||||
|  * instead. | ||||
|  */ | ||||
|  | ||||
| #ifndef __CLUTTER_KEYSYMS_DEPRECATED_H__ | ||||
| #define __CLUTTER_KEYSYMS_DEPRECATED_H__ | ||||
|  | ||||
| #ifndef CLUTTER_DISABLE_DEPRECATED | ||||
|  | ||||
| EOF | ||||
|  | ||||
| while (<IN_KEYSYMDEF>) | ||||
| { | ||||
| 	next if ( ! /^#define / ); | ||||
| @@ -137,13 +115,8 @@ while (<IN_KEYSYMDEF>) | ||||
| 	my $element = $keysymelements[1]; | ||||
| 	my $binding = $element; | ||||
| 	$binding =~ s/^XK_/CLUTTER_KEY_/g; | ||||
| 	my $compat_binding = $element; | ||||
| 	$compat_binding =~ s/^XK_/CLUTTER_/g; | ||||
|  | ||||
| 	my $deprecation = "CLUTTER_DEPRECATED_MACRO_FOR(\"Deprecated key symbol. Use $binding instead.\")"; | ||||
|  | ||||
| 	printf OUT_KEYSYMS "#define %s 0x%03x\n", $binding, hex($keysymelements[2]); | ||||
| 	printf OUT_KEYSYMS_COMPAT "#define %s 0x%03x %s\n", $compat_binding, hex($keysymelements[2]), $deprecation; | ||||
| } | ||||
|  | ||||
| close IN_KEYSYMDEF; | ||||
| @@ -187,11 +160,8 @@ while (<IN_XF86KEYSYM>) | ||||
| 	my $element = $keysymelements[1]; | ||||
| 	my $binding = $element; | ||||
| 	$binding =~ s/^XF86XK_/CLUTTER_KEY_/g; | ||||
| 	my $compat_binding = $element; | ||||
| 	$compat_binding =~ s/^XF86XK_/CLUTTER_/g; | ||||
|  | ||||
| 	printf OUT_KEYSYMS "#define %s 0x%03x\n", $binding, hex($keysymelements[2]); | ||||
| 	printf OUT_KEYSYMS_COMPAT "#define %s 0x%03x\n", $compat_binding, hex($keysymelements[2]); | ||||
| } | ||||
|  | ||||
| close IN_XF86KEYSYM; | ||||
| @@ -202,13 +172,6 @@ print OUT_KEYSYMS<<EOF; | ||||
| #endif /* __CLUTTER_KEYSYMS_H__ */ | ||||
| EOF | ||||
|  | ||||
| print OUT_KEYSYMS_COMPAT<<EOF; | ||||
|  | ||||
| #endif /* CLUTTER_DISABLE_DEPRECATED */ | ||||
|  | ||||
| #endif /* __CLUTTER_KEYSYMS_DEPRECATED_H__ */ | ||||
| EOF | ||||
|  | ||||
| foreach my $f (qw/ keysymdef.h XF86keysym.h /) { | ||||
|     unlink $f or die "Unable to delete $f: $!"; | ||||
| } | ||||
|   | ||||
| @@ -98,11 +98,11 @@ | ||||
|  * |[ | ||||
|  * { | ||||
|  *   "type" : "ClutterBox", | ||||
|  *   "layout-manager" : { "type" : "ClutterTableLayout" }, | ||||
|  *   "layout-manager" : { "type" : "ClutterGridLayout" }, | ||||
|  *   "children" : [ | ||||
|  *     { | ||||
|  *       "type" : "ClutterTexture", | ||||
|  *       "filename" : "image-00.png", | ||||
|  *       "type" : "ClutterText", | ||||
|  *       "text" : "Some text", | ||||
|  * | ||||
|  *       "layout::row" : 0, | ||||
|  *       "layout::column" : 0, | ||||
| @@ -112,8 +112,8 @@ | ||||
|  *       "layout::y-expand" : true | ||||
|  *     }, | ||||
|  *     { | ||||
|  *       "type" : "ClutterTexture", | ||||
|  *       "filename" : "image-01.png", | ||||
|  *       "type" : "ClutterText", | ||||
|  *       "text" : "Some more text", | ||||
|  * | ||||
|  *       "layout::row" : 0, | ||||
|  *       "layout::column" : 1, | ||||
| @@ -329,9 +329,6 @@ layout_manager_real_begin_animation (ClutterLayoutManager *manager, | ||||
|   /* let the alpha take ownership of the timeline */ | ||||
|   g_object_unref (timeline); | ||||
|  | ||||
|   g_signal_connect_swapped (timeline, "completed", | ||||
|                             G_CALLBACK (clutter_layout_manager_end_animation), | ||||
|                             manager); | ||||
|   g_signal_connect_swapped (timeline, "new-frame", | ||||
|                             G_CALLBACK (clutter_layout_manager_layout_changed), | ||||
|                             manager); | ||||
| @@ -375,9 +372,6 @@ layout_manager_real_end_animation (ClutterLayoutManager *manager) | ||||
|   if (clutter_timeline_is_playing (timeline)) | ||||
|     clutter_timeline_stop (timeline); | ||||
|  | ||||
|   g_signal_handlers_disconnect_by_func (timeline, | ||||
|                                         G_CALLBACK (clutter_layout_manager_end_animation), | ||||
|                                         manager); | ||||
|   g_signal_handlers_disconnect_by_func (timeline, | ||||
|                                         G_CALLBACK (clutter_layout_manager_layout_changed), | ||||
|                                         manager); | ||||
|   | ||||
| @@ -213,15 +213,6 @@ void               clutter_layout_manager_child_get_property    (ClutterLayoutMa | ||||
|                                                                  const gchar            *property_name, | ||||
|                                                                  GValue                 *value); | ||||
|  | ||||
| CLUTTER_DEPRECATED | ||||
| ClutterAlpha *     clutter_layout_manager_begin_animation       (ClutterLayoutManager   *manager, | ||||
|                                                                  guint                   duration, | ||||
|                                                                  gulong                  mode); | ||||
| CLUTTER_DEPRECATED | ||||
| void               clutter_layout_manager_end_animation         (ClutterLayoutManager   *manager); | ||||
| CLUTTER_DEPRECATED | ||||
| gdouble            clutter_layout_manager_get_animation_progress (ClutterLayoutManager   *manager); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_LAYOUT_MANAGER_H__ */ | ||||
|   | ||||
| @@ -55,10 +55,11 @@ | ||||
| #include "clutter-backend-private.h" | ||||
| #include "clutter-config.h" | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-event-private.h" | ||||
| #include "clutter-feature.h" | ||||
| #include "clutter-input-device-private.h" | ||||
| #include "clutter-input-pointer-a11y-private.h" | ||||
| #include "clutter-graphene.h" | ||||
| #include "clutter-main.h" | ||||
| #include "clutter-master-clock.h" | ||||
| #include "clutter-mutter.h" | ||||
| @@ -1837,8 +1838,7 @@ _clutter_process_event_details (ClutterActor        *stage, | ||||
|                 gfloat x, y; | ||||
|  | ||||
|                 clutter_event_get_coords (event, &x, &y); | ||||
|                 core_pointer = clutter_device_manager_get_core_device (device->device_manager, | ||||
|                                                                        CLUTTER_POINTER_DEVICE); | ||||
|                 core_pointer = clutter_event_get_device (event); | ||||
|                 _clutter_input_pointer_a11y_on_motion_event (core_pointer, x, y); | ||||
|               } | ||||
|           } | ||||
| @@ -1880,9 +1880,7 @@ _clutter_process_event_details (ClutterActor        *stage, | ||||
|               { | ||||
|                 ClutterInputDevice *core_pointer; | ||||
|  | ||||
|                 core_pointer = clutter_device_manager_get_core_device (device->device_manager, | ||||
|                                                                        CLUTTER_POINTER_DEVICE); | ||||
|  | ||||
|                 core_pointer = clutter_event_get_device (event); | ||||
|                 _clutter_input_pointer_a11y_on_button_event (core_pointer, | ||||
|                                                              event->button.button, | ||||
|                                                              event->type == CLUTTER_BUTTON_PRESS); | ||||
| @@ -2194,6 +2192,8 @@ clutter_base_init (void) | ||||
|  | ||||
|       /* initialise the Big Clutter Lock™ if necessary */ | ||||
|       clutter_threads_init_default (); | ||||
|  | ||||
|       clutter_graphene_init (); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -2308,8 +2308,7 @@ clutter_threads_remove_repaint_func (guint handle_id) | ||||
|  * that it does not block, otherwise the frame time budget may be lost. | ||||
|  * | ||||
|  * A repaint function is useful to ensure that an update of the scenegraph | ||||
|  * is performed before the scenegraph is repainted; for instance, uploading | ||||
|  * a frame from a video into a #ClutterTexture. By default, a repaint | ||||
|  * is performed before the scenegraph is repainted. By default, a repaint | ||||
|  * function added using this function will be invoked prior to the frame | ||||
|  * being processed. | ||||
|  * | ||||
| @@ -2358,8 +2357,7 @@ clutter_threads_add_repaint_func (GSourceFunc    func, | ||||
|  * that it does not block, otherwise the frame time budget may be lost. | ||||
|  * | ||||
|  * A repaint function is useful to ensure that an update of the scenegraph | ||||
|  * is performed before the scenegraph is repainted; for instance, uploading | ||||
|  * a frame from a video into a #ClutterTexture. The @flags passed to this | ||||
|  * is performed before the scenegraph is repainted. The @flags passed to this | ||||
|  * function will determine the section of the frame processing that will | ||||
|  * result in @func being called. | ||||
|  * | ||||
| @@ -2602,6 +2600,36 @@ clutter_check_windowing_backend (const char *backend_type) | ||||
|   return FALSE; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_add_debug_flags: (skip) | ||||
|  * | ||||
|  * Adds the debug flags passed to the list of debug flags. | ||||
|  */ | ||||
| void | ||||
| clutter_add_debug_flags (ClutterDebugFlag     debug_flags, | ||||
|                          ClutterDrawDebugFlag draw_flags, | ||||
|                          ClutterPickDebugFlag pick_flags) | ||||
| { | ||||
|   clutter_debug_flags |= debug_flags; | ||||
|   clutter_paint_debug_flags |= draw_flags; | ||||
|   clutter_pick_debug_flags |= pick_flags; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_remove_debug_flags: (skip) | ||||
|  * | ||||
|  * Removes the debug flags passed from the list of debug flags. | ||||
|  */ | ||||
| void | ||||
| clutter_remove_debug_flags (ClutterDebugFlag     debug_flags, | ||||
|                             ClutterDrawDebugFlag draw_flags, | ||||
|                             ClutterPickDebugFlag pick_flags) | ||||
| { | ||||
|   clutter_debug_flags &= ~debug_flags; | ||||
|   clutter_paint_debug_flags &= ~draw_flags; | ||||
|   clutter_pick_debug_flags &= ~pick_flags; | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_set_sync_to_vblank (gboolean sync_to_vblank) | ||||
| { | ||||
|   | ||||
| @@ -34,6 +34,45 @@ | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_MISC                = 1 << 0, | ||||
|   CLUTTER_DEBUG_ACTOR               = 1 << 1, | ||||
|   CLUTTER_DEBUG_TEXTURE             = 1 << 2, | ||||
|   CLUTTER_DEBUG_EVENT               = 1 << 3, | ||||
|   CLUTTER_DEBUG_PAINT               = 1 << 4, | ||||
|   CLUTTER_DEBUG_PANGO               = 1 << 5, | ||||
|   CLUTTER_DEBUG_BACKEND             = 1 << 6, | ||||
|   CLUTTER_DEBUG_SCHEDULER           = 1 << 7, | ||||
|   CLUTTER_DEBUG_SCRIPT              = 1 << 8, | ||||
|   CLUTTER_DEBUG_SHADER              = 1 << 9, | ||||
|   CLUTTER_DEBUG_MULTISTAGE          = 1 << 10, | ||||
|   CLUTTER_DEBUG_ANIMATION           = 1 << 11, | ||||
|   CLUTTER_DEBUG_LAYOUT              = 1 << 12, | ||||
|   CLUTTER_DEBUG_PICK                = 1 << 13, | ||||
|   CLUTTER_DEBUG_EVENTLOOP           = 1 << 14, | ||||
|   CLUTTER_DEBUG_CLIPPING            = 1 << 15, | ||||
|   CLUTTER_DEBUG_OOB_TRANSFORMS      = 1 << 16, | ||||
| } ClutterDebugFlag; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_NOP_PICKING = 1 << 0, | ||||
| } ClutterPickDebugFlag; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_DEBUG_DISABLE_SWAP_EVENTS        = 1 << 0, | ||||
|   CLUTTER_DEBUG_DISABLE_CLIPPED_REDRAWS    = 1 << 1, | ||||
|   CLUTTER_DEBUG_REDRAWS                    = 1 << 2, | ||||
|   CLUTTER_DEBUG_PAINT_VOLUMES              = 1 << 3, | ||||
|   CLUTTER_DEBUG_DISABLE_CULLING            = 1 << 4, | ||||
|   CLUTTER_DEBUG_DISABLE_OFFSCREEN_REDIRECT = 1 << 5, | ||||
|   CLUTTER_DEBUG_CONTINUOUS_REDRAW          = 1 << 6, | ||||
|   CLUTTER_DEBUG_PAINT_DEFORM_TILES         = 1 << 7, | ||||
|   CLUTTER_DEBUG_PAINT_DAMAGE_REGION        = 1 << 8, | ||||
| } ClutterDrawDebugFlag; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_INIT_ERROR: | ||||
|  * | ||||
| @@ -158,6 +197,15 @@ guint                   clutter_get_default_frame_rate          (void); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_check_windowing_backend         (const char *backend_type); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_add_debug_flags                 (ClutterDebugFlag     debug_flags, | ||||
|                                                                  ClutterDrawDebugFlag draw_flags, | ||||
|                                                                  ClutterPickDebugFlag pick_flags); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_remove_debug_flags              (ClutterDebugFlag     debug_flags, | ||||
|                                                                  ClutterDrawDebugFlag draw_flags, | ||||
|                                                                  ClutterPickDebugFlag pick_flags); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
| @@ -26,8 +26,8 @@ | ||||
| #define __CLUTTER_H_INSIDE__ | ||||
|  | ||||
| #include "clutter-backend.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-event-private.h" | ||||
| #include "clutter-input-device-private.h" | ||||
| #include "clutter-input-pointer-a11y-private.h" | ||||
| #include "clutter-macros.h" | ||||
| #include "clutter-private.h" | ||||
|   | ||||
| @@ -86,7 +86,7 @@ struct _ClutterOffscreenEffectPrivate | ||||
|   ClutterActor *actor; | ||||
|   ClutterActor *stage; | ||||
|  | ||||
|   ClutterVertex position; | ||||
|   graphene_point3d_t position; | ||||
|  | ||||
|   int fbo_offset_x; | ||||
|   int fbo_offset_y; | ||||
| @@ -119,7 +119,7 @@ clutter_offscreen_effect_set_actor (ClutterActorMeta *meta, | ||||
|   /* clear out the previous state */ | ||||
|   if (priv->offscreen != NULL) | ||||
|     { | ||||
|       cogl_handle_unref (priv->offscreen); | ||||
|       cogl_object_unref (priv->offscreen); | ||||
|       priv->offscreen = NULL; | ||||
|     } | ||||
|  | ||||
| @@ -199,13 +199,13 @@ update_fbo (ClutterEffect *effect, | ||||
|  | ||||
|   if (priv->texture != NULL) | ||||
|     { | ||||
|       cogl_handle_unref (priv->texture); | ||||
|       cogl_object_unref (priv->texture); | ||||
|       priv->texture = NULL; | ||||
|     } | ||||
|  | ||||
|   if (priv->offscreen != NULL) | ||||
|     { | ||||
|       cogl_handle_unref (priv->offscreen); | ||||
|       cogl_object_unref (priv->offscreen); | ||||
|       priv->offscreen = NULL; | ||||
|     } | ||||
|  | ||||
| @@ -224,7 +224,7 @@ update_fbo (ClutterEffect *effect, | ||||
|     { | ||||
|       g_warning ("%s: Unable to create an Offscreen buffer", G_STRLOC); | ||||
|  | ||||
|       cogl_handle_unref (priv->target); | ||||
|       cogl_object_unref (priv->target); | ||||
|       priv->target = NULL; | ||||
|  | ||||
|       priv->target_width = 0; | ||||
| @@ -250,9 +250,11 @@ clutter_offscreen_effect_pre_paint (ClutterEffect *effect) | ||||
|   gfloat target_width = -1, target_height = -1; | ||||
|   gfloat resource_scale; | ||||
|   gfloat ceiled_resource_scale; | ||||
|   ClutterVertex local_offset = { 0.f, 0.f, 0.f }; | ||||
|   graphene_point3d_t local_offset; | ||||
|   gfloat old_viewport[4]; | ||||
|  | ||||
|   local_offset = GRAPHENE_POINT3D_INIT (0.0f, 0.0f, 0.0f); | ||||
|  | ||||
|   if (!clutter_actor_meta_get_enabled (CLUTTER_ACTOR_META (effect))) | ||||
|     return FALSE; | ||||
|  | ||||
| @@ -487,13 +489,13 @@ clutter_offscreen_effect_finalize (GObject *gobject) | ||||
|   ClutterOffscreenEffectPrivate *priv = self->priv; | ||||
|  | ||||
|   if (priv->offscreen) | ||||
|     cogl_handle_unref (priv->offscreen); | ||||
|     cogl_object_unref (priv->offscreen); | ||||
|  | ||||
|   if (priv->target) | ||||
|     cogl_handle_unref (priv->target); | ||||
|     cogl_object_unref (priv->target); | ||||
|  | ||||
|   if (priv->texture) | ||||
|     cogl_handle_unref (priv->texture); | ||||
|     cogl_object_unref (priv->texture); | ||||
|  | ||||
|   G_OBJECT_CLASS (clutter_offscreen_effect_parent_class)->finalize (gobject); | ||||
| } | ||||
| @@ -537,7 +539,7 @@ clutter_offscreen_effect_init (ClutterOffscreenEffect *self) | ||||
|  * used instead of clutter_offscreen_effect_get_target() when the | ||||
|  * effect subclass wants to paint using its own material. | ||||
|  * | ||||
|  * Return value: (transfer none): a #CoglHandle or %COGL_INVALID_HANDLE. The | ||||
|  * Return value: (transfer none): a #CoglHandle or %NULL. The | ||||
|  *   returned texture is owned by Clutter and it should not be | ||||
|  *   modified or freed | ||||
|  * | ||||
| @@ -602,7 +604,7 @@ clutter_offscreen_effect_paint_target (ClutterOffscreenEffect *effect) | ||||
|  * Calls the create_texture() virtual function of the @effect | ||||
|  * | ||||
|  * Return value: (transfer full): a handle to a Cogl texture, or | ||||
|  *   %COGL_INVALID_HANDLE. The returned handle has its reference | ||||
|  *   %NULL. The returned handle has its reference | ||||
|  *   count increased. | ||||
|  * | ||||
|  * Since: 1.4 | ||||
| @@ -682,7 +684,7 @@ clutter_offscreen_effect_get_target_size (ClutterOffscreenEffect *effect, | ||||
|  */ | ||||
| gboolean | ||||
| clutter_offscreen_effect_get_target_rect (ClutterOffscreenEffect *effect, | ||||
|                                           ClutterRect            *rect) | ||||
|                                           graphene_rect_t        *rect) | ||||
| { | ||||
|   ClutterOffscreenEffectPrivate *priv; | ||||
|  | ||||
| @@ -694,11 +696,11 @@ clutter_offscreen_effect_get_target_rect (ClutterOffscreenEffect *effect, | ||||
|   if (priv->texture == NULL) | ||||
|     return FALSE; | ||||
|  | ||||
|   clutter_rect_init (rect, | ||||
|                      priv->position.x, | ||||
|                      priv->position.y, | ||||
|                      cogl_texture_get_width (priv->texture), | ||||
|                      cogl_texture_get_height (priv->texture)); | ||||
|   graphene_rect_init (rect, | ||||
|                       priv->position.x, | ||||
|                       priv->position.y, | ||||
|                       cogl_texture_get_width (priv->texture), | ||||
|                       cogl_texture_get_height (priv->texture)); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|   | ||||
| @@ -114,7 +114,7 @@ gboolean        clutter_offscreen_effect_get_target_size        (ClutterOffscree | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| gboolean        clutter_offscreen_effect_get_target_rect        (ClutterOffscreenEffect *effect, | ||||
|                                                                  ClutterRect            *rect); | ||||
|                                                                  graphene_rect_t        *rect); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
| @@ -139,30 +139,6 @@ ClutterPaintNode *      clutter_paint_node_get_last_child               (Clutter | ||||
| G_GNUC_INTERNAL | ||||
| ClutterPaintNode *      clutter_paint_node_get_parent                   (ClutterPaintNode      *node); | ||||
|  | ||||
| #define CLUTTER_TYPE_LAYER_NODE                 (_clutter_layer_node_get_type ()) | ||||
| #define CLUTTER_LAYER_NODE(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_LAYER_NODE, ClutterLayerNode)) | ||||
| #define CLUTTER_IS_LAYER_NODE(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_LAYER_NODE)) | ||||
|  | ||||
| /* | ||||
|  * ClutterLayerNode: | ||||
|  * | ||||
|  * The #ClutterLayerNode structure is an opaque | ||||
|  * type whose members cannot be directly accessed. | ||||
|  * | ||||
|  * Since: 1.10 | ||||
|  */ | ||||
| typedef struct _ClutterLayerNode                ClutterLayerNode; | ||||
| typedef struct _ClutterLayerNodeClass           ClutterLayerNodeClass; | ||||
|  | ||||
| GType _clutter_layer_node_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| ClutterPaintNode *      _clutter_layer_node_new         (const CoglMatrix        *projection, | ||||
|                                                          const cairo_rectangle_t *viewport, | ||||
|                                                          float                    width, | ||||
|                                                          float                    height, | ||||
|                                                          guint8                   opacity); | ||||
|  | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_PAINT_NODE_PRIVATE_H__ */ | ||||
|   | ||||
| @@ -183,35 +183,31 @@ clutter_root_node_new (CoglFramebuffer    *framebuffer, | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Transform node | ||||
|  * | ||||
|  * A private PaintNode, that changes the modelview of its child | ||||
|  * nodes. | ||||
|  * ClutterTransformNode | ||||
|  */ | ||||
|  | ||||
| #define clutter_transform_node_get_type _clutter_transform_node_get_type | ||||
|  | ||||
| typedef struct _ClutterTransformNode { | ||||
| struct _ClutterTransformNode | ||||
| { | ||||
|   ClutterPaintNode parent_instance; | ||||
|  | ||||
|   CoglMatrix modelview; | ||||
| } ClutterTransformNode; | ||||
|   CoglMatrix transform; | ||||
| }; | ||||
|  | ||||
| typedef struct _ClutterPaintNodeClass   ClutterTransformNodeClass; | ||||
| struct _ClutterTransformNodeClass | ||||
| { | ||||
|   ClutterPaintNodeClass parent_class; | ||||
| }; | ||||
|  | ||||
| G_DEFINE_TYPE (ClutterTransformNode, clutter_transform_node, CLUTTER_TYPE_PAINT_NODE) | ||||
|  | ||||
| static gboolean | ||||
| clutter_transform_node_pre_draw (ClutterPaintNode *node) | ||||
| { | ||||
|   ClutterTransformNode *tnode = (ClutterTransformNode *) node; | ||||
|   CoglMatrix matrix; | ||||
|   ClutterTransformNode *transform_node = (ClutterTransformNode *) node; | ||||
|   CoglFramebuffer *fb = cogl_get_draw_framebuffer (); | ||||
|  | ||||
|   cogl_push_matrix (); | ||||
|  | ||||
|   cogl_get_modelview_matrix (&matrix); | ||||
|   cogl_matrix_multiply (&matrix, &matrix, &tnode->modelview); | ||||
|   cogl_set_modelview_matrix (&matrix); | ||||
|   cogl_framebuffer_push_matrix (fb); | ||||
|   cogl_framebuffer_transform (fb, &transform_node->transform); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
| @@ -219,7 +215,9 @@ clutter_transform_node_pre_draw (ClutterPaintNode *node) | ||||
| static void | ||||
| clutter_transform_node_post_draw (ClutterPaintNode *node) | ||||
| { | ||||
|   cogl_pop_matrix (); | ||||
|   CoglFramebuffer *fb = cogl_get_draw_framebuffer (); | ||||
|  | ||||
|   cogl_framebuffer_pop_matrix (fb); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -235,18 +233,24 @@ clutter_transform_node_class_init (ClutterTransformNodeClass *klass) | ||||
| static void | ||||
| clutter_transform_node_init (ClutterTransformNode *self) | ||||
| { | ||||
|   cogl_matrix_init_identity (&self->modelview); | ||||
|   cogl_matrix_init_identity (&self->transform); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * clutter_transform_node_new: | ||||
|  * @transform: (nullable): the transform matrix to apply | ||||
|  * | ||||
|  * Return value: (transfer full): the newly created #ClutterTransformNode. | ||||
|  *   Use clutter_paint_node_unref() when done. | ||||
|  */ | ||||
| ClutterPaintNode * | ||||
| _clutter_transform_node_new (const CoglMatrix *modelview) | ||||
| clutter_transform_node_new (const CoglMatrix *transform) | ||||
| { | ||||
|   ClutterTransformNode *res; | ||||
|  | ||||
|   res = _clutter_paint_node_create (_clutter_transform_node_get_type ()); | ||||
|  | ||||
|   if (modelview != NULL) | ||||
|     res->modelview = *modelview; | ||||
|   res = _clutter_paint_node_create (CLUTTER_TYPE_TRANSFORM_NODE); | ||||
|   if (transform) | ||||
|     res->transform = *transform; | ||||
|  | ||||
|   return (ClutterPaintNode *) res; | ||||
| } | ||||
| @@ -1078,10 +1082,114 @@ clutter_clip_node_new (void) | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * ClutterLayerNode (private) | ||||
|  * ClutterActorNode | ||||
|  */ | ||||
|  | ||||
| #define clutter_layer_node_get_type     _clutter_layer_node_get_type | ||||
| struct _ClutterActorNode | ||||
| { | ||||
|   ClutterPaintNode parent_instance; | ||||
|  | ||||
|   ClutterActor *actor; | ||||
| }; | ||||
|  | ||||
| struct _ClutterActorNodeClass | ||||
| { | ||||
|   ClutterPaintNodeClass parent_class; | ||||
| }; | ||||
|  | ||||
| G_DEFINE_TYPE (ClutterActorNode, clutter_actor_node, CLUTTER_TYPE_PAINT_NODE) | ||||
|  | ||||
| static gboolean | ||||
| clutter_actor_node_pre_draw (ClutterPaintNode *node) | ||||
| { | ||||
|   ClutterActorNode *actor_node = CLUTTER_ACTOR_NODE (node); | ||||
|  | ||||
|   CLUTTER_SET_PRIVATE_FLAGS (actor_node->actor, CLUTTER_IN_PAINT); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_actor_node_draw (ClutterPaintNode *node) | ||||
| { | ||||
|   ClutterActorNode *actor_node = CLUTTER_ACTOR_NODE (node); | ||||
|  | ||||
|   clutter_actor_continue_paint (actor_node->actor); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_actor_node_post_draw (ClutterPaintNode *node) | ||||
| { | ||||
|   ClutterActorNode *actor_node = CLUTTER_ACTOR_NODE (node); | ||||
|  | ||||
|   CLUTTER_UNSET_PRIVATE_FLAGS (actor_node->actor, CLUTTER_IN_PAINT); | ||||
| } | ||||
|  | ||||
| static JsonNode * | ||||
| clutter_actor_node_serialize (ClutterPaintNode *node) | ||||
| { | ||||
|   ClutterActorNode *actor_node = CLUTTER_ACTOR_NODE (node); | ||||
|   g_autoptr (JsonBuilder) builder = NULL; | ||||
|   const char *debug_name; | ||||
|  | ||||
|   debug_name = _clutter_actor_get_debug_name (actor_node->actor); | ||||
|  | ||||
|   builder = json_builder_new (); | ||||
|  | ||||
|   json_builder_begin_object (builder); | ||||
|   json_builder_set_member_name (builder, "actor"); | ||||
|   json_builder_add_string_value (builder, debug_name); | ||||
|   json_builder_end_object (builder); | ||||
|  | ||||
|   return json_builder_get_root (builder); | ||||
| } | ||||
| static void | ||||
| clutter_actor_node_class_init (ClutterActorNodeClass *klass) | ||||
| { | ||||
|   ClutterPaintNodeClass *node_class; | ||||
|  | ||||
|   node_class = CLUTTER_PAINT_NODE_CLASS (klass); | ||||
|   node_class->pre_draw = clutter_actor_node_pre_draw; | ||||
|   node_class->draw = clutter_actor_node_draw; | ||||
|   node_class->post_draw = clutter_actor_node_post_draw; | ||||
|   node_class->serialize = clutter_actor_node_serialize; | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_actor_node_init (ClutterActorNode *self) | ||||
| { | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * clutter_actor_node_new: | ||||
|  * @actor: the actor to paint | ||||
|  * | ||||
|  * Creates a new #ClutterActorNode. | ||||
|  * | ||||
|  * The actor is painted together with any effects | ||||
|  * applied to it. Children of this node will draw | ||||
|  * over the actor contents. | ||||
|  * | ||||
|  * Return value: (transfer full): the newly created #ClutterActorNode. | ||||
|  *   Use clutter_paint_node_unref() when done. | ||||
|  */ | ||||
| ClutterPaintNode * | ||||
| clutter_actor_node_new (ClutterActor *actor) | ||||
| { | ||||
|   ClutterActorNode *res; | ||||
|  | ||||
|   g_assert (actor != NULL); | ||||
|  | ||||
|   res = _clutter_paint_node_create (CLUTTER_TYPE_ACTOR_NODE); | ||||
|   res->actor = actor; | ||||
|  | ||||
|   return (ClutterPaintNode *) res; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * ClutterLayerNode | ||||
|  */ | ||||
|  | ||||
| struct _ClutterLayerNode | ||||
| { | ||||
| @@ -1268,11 +1376,11 @@ clutter_layer_node_init (ClutterLayerNode *self) | ||||
|  * Since: 1.10 | ||||
|  */ | ||||
| ClutterPaintNode * | ||||
| _clutter_layer_node_new (const CoglMatrix        *projection, | ||||
|                          const cairo_rectangle_t *viewport, | ||||
|                          float                    width, | ||||
|                          float                    height, | ||||
|                          guint8                   opacity) | ||||
| clutter_layer_node_new (const CoglMatrix        *projection, | ||||
|                         const cairo_rectangle_t *viewport, | ||||
|                         float                    width, | ||||
|                         float                    height, | ||||
|                         guint8                   opacity) | ||||
| { | ||||
|   ClutterLayerNode *res; | ||||
|   CoglColor color; | ||||
|   | ||||
| @@ -143,6 +143,25 @@ CLUTTER_EXPORT | ||||
| ClutterPaintNode *      clutter_text_node_new           (PangoLayout           *layout, | ||||
|                                                          const ClutterColor    *color); | ||||
|  | ||||
| #define CLUTTER_TYPE_ACTOR_NODE                 (clutter_actor_node_get_type ()) | ||||
| #define CLUTTER_ACTOR_NODE(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_ACTOR_NODE, ClutterActorNode)) | ||||
| #define CLUTTER_IS_ACTOR_NODE(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_ACTOR_NODE)) | ||||
|  | ||||
| /** | ||||
|  * ClutterActorNode: | ||||
|  * | ||||
|  * The #ClutterActorNode structure is an opaque | ||||
|  * type whose members cannot be directly accessed. | ||||
|  */ | ||||
| typedef struct _ClutterActorNode ClutterActorNode; | ||||
| typedef struct _ClutterActorNode ClutterActorNodeClass; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_actor_node_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterPaintNode * clutter_actor_node_new (ClutterActor *actor); | ||||
|  | ||||
| #define CLUTTER_TYPE_ROOT_NODE                  (clutter_root_node_get_type ()) | ||||
| #define CLUTTER_ROOT_NODE(obj)                  (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_ROOT_NODE, ClutterRootNode)) | ||||
| #define CLUTTER_IS_ROOT_NODE(obj)               (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_ROOT_NODE)) | ||||
| @@ -163,6 +182,54 @@ CLUTTER_EXPORT | ||||
| ClutterPaintNode *      clutter_root_node_new           (CoglFramebuffer       *framebuffer, | ||||
|                                                          const ClutterColor    *clear_color, | ||||
|                                                          CoglBufferBit          clear_flags); | ||||
|  | ||||
| #define CLUTTER_TYPE_LAYER_NODE                 (clutter_layer_node_get_type ()) | ||||
| #define CLUTTER_LAYER_NODE(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_LAYER_NODE, ClutterLayerNode)) | ||||
| #define CLUTTER_IS_LAYER_NODE(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_LAYER_NODE)) | ||||
|  | ||||
| /* | ||||
|  * ClutterLayerNode: | ||||
|  * | ||||
|  * The #ClutterLayerNode structure is an opaque | ||||
|  * type whose members cannot be directly accessed. | ||||
|  * | ||||
|  * Since: 1.10 | ||||
|  */ | ||||
| typedef struct _ClutterLayerNode                ClutterLayerNode; | ||||
| typedef struct _ClutterLayerNodeClass           ClutterLayerNodeClass; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_layer_node_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterPaintNode *      clutter_layer_node_new          (const CoglMatrix        *projection, | ||||
|                                                          const cairo_rectangle_t *viewport, | ||||
|                                                          float                    width, | ||||
|                                                          float                    height, | ||||
|                                                          guint8                   opacity); | ||||
|  | ||||
|  | ||||
| #define CLUTTER_TYPE_TRANSFORM_NODE             (clutter_transform_node_get_type ()) | ||||
| #define CLUTTER_TRANSFORM_NODE(obj)             (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_TRANSFORM_NODE, ClutterTransformNode)) | ||||
| #define CLUTTER_IS_TRANSFORM_NODE(obj)          (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_TRANSFORM_NODE)) | ||||
|  | ||||
| /* | ||||
|  * ClutterTransformNode: | ||||
|  * | ||||
|  * The #ClutterLayerNode structure is an opaque | ||||
|  * type whose members cannot be directly accessed. | ||||
|  * | ||||
|  * Since: 1.10 | ||||
|  */ | ||||
| typedef struct _ClutterTransformNode            ClutterTransformNode; | ||||
| typedef struct _ClutterPaintNodeClass           ClutterTransformNodeClass; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_transform_node_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterPaintNode *      clutter_transform_node_new          (const CoglMatrix *projection); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_PAINT_NODES_H__ */ | ||||
|   | ||||
| @@ -58,7 +58,7 @@ struct _ClutterPaintVolume | ||||
|    * elements 4, 5, 6 and 7 most of the time for 2D actors when | ||||
|    * calculating the projected paint box. | ||||
|    */ | ||||
|   ClutterVertex vertices[8]; | ||||
|   graphene_point3d_t vertices[8]; | ||||
|  | ||||
|   /* As an optimization for internally managed PaintVolumes we allow | ||||
|    * initializing ClutterPaintVolume variables allocated on the stack | ||||
|   | ||||
| @@ -63,7 +63,7 @@ _clutter_paint_volume_new (ClutterActor *actor) | ||||
|  | ||||
|   pv->actor = actor; | ||||
|  | ||||
|   memset (pv->vertices, 0, 8 * sizeof (ClutterVertex)); | ||||
|   memset (pv->vertices, 0, 8 * sizeof (graphene_point3d_t)); | ||||
|  | ||||
|   pv->is_static = FALSE; | ||||
|   pv->is_empty = TRUE; | ||||
| @@ -96,7 +96,7 @@ _clutter_paint_volume_init_static (ClutterPaintVolume *pv, | ||||
| { | ||||
|   pv->actor = actor; | ||||
|  | ||||
|   memset (pv->vertices, 0, 8 * sizeof (ClutterVertex)); | ||||
|   memset (pv->vertices, 0, 8 * sizeof (graphene_point3d_t)); | ||||
|  | ||||
|   pv->is_static = TRUE; | ||||
|   pv->is_empty = TRUE; | ||||
| @@ -170,7 +170,7 @@ clutter_paint_volume_free (ClutterPaintVolume *pv) | ||||
| /** | ||||
|  * clutter_paint_volume_set_origin: | ||||
|  * @pv: a #ClutterPaintVolume | ||||
|  * @origin: a #ClutterVertex | ||||
|  * @origin: a #graphene_point3d_t | ||||
|  * | ||||
|  * Sets the origin of the paint volume. | ||||
|  * | ||||
| @@ -182,8 +182,8 @@ clutter_paint_volume_free (ClutterPaintVolume *pv) | ||||
|  * Since: 1.6 | ||||
|  */ | ||||
| void | ||||
| clutter_paint_volume_set_origin (ClutterPaintVolume  *pv, | ||||
|                                  const ClutterVertex *origin) | ||||
| clutter_paint_volume_set_origin (ClutterPaintVolume       *pv, | ||||
|                                  const graphene_point3d_t *origin) | ||||
| { | ||||
|   static const int key_vertices[4] = { 0, 1, 3, 4 }; | ||||
|   float dx, dy, dz; | ||||
| @@ -210,7 +210,7 @@ clutter_paint_volume_set_origin (ClutterPaintVolume  *pv, | ||||
| /** | ||||
|  * clutter_paint_volume_get_origin: | ||||
|  * @pv: a #ClutterPaintVolume | ||||
|  * @vertex: (out): the return location for a #ClutterVertex | ||||
|  * @vertex: (out): the return location for a #graphene_point3d_t | ||||
|  * | ||||
|  * Retrieves the origin of the #ClutterPaintVolume. | ||||
|  * | ||||
| @@ -218,7 +218,7 @@ clutter_paint_volume_set_origin (ClutterPaintVolume  *pv, | ||||
|  */ | ||||
| void | ||||
| clutter_paint_volume_get_origin (const ClutterPaintVolume *pv, | ||||
|                                  ClutterVertex            *vertex) | ||||
|                                  graphene_point3d_t       *vertex) | ||||
| { | ||||
|   g_return_if_fail (pv != NULL); | ||||
|   g_return_if_fail (vertex != NULL); | ||||
| @@ -659,7 +659,7 @@ clutter_paint_volume_union_box (ClutterPaintVolume    *pv, | ||||
|                                 const ClutterActorBox *box) | ||||
| { | ||||
|   ClutterPaintVolume volume; | ||||
|   ClutterVertex origin; | ||||
|   graphene_point3d_t origin; | ||||
|  | ||||
|   g_return_if_fail (pv != NULL); | ||||
|   g_return_if_fail (box != NULL); | ||||
| @@ -757,7 +757,7 @@ _clutter_paint_volume_get_bounding_box (ClutterPaintVolume *pv, | ||||
|                                         ClutterActorBox *box) | ||||
| { | ||||
|   gfloat x_min, y_min, x_max, y_max; | ||||
|   ClutterVertex *vertices; | ||||
|   graphene_point3d_t *vertices; | ||||
|   int count; | ||||
|   gint i; | ||||
|  | ||||
| @@ -878,9 +878,9 @@ _clutter_paint_volume_transform (ClutterPaintVolume *pv, | ||||
|  | ||||
|   cogl_matrix_transform_points (matrix, | ||||
|                                 3, | ||||
|                                 sizeof (ClutterVertex), | ||||
|                                 sizeof (graphene_point3d_t), | ||||
|                                 pv->vertices, | ||||
|                                 sizeof (ClutterVertex), | ||||
|                                 sizeof (graphene_point3d_t), | ||||
|                                 pv->vertices, | ||||
|                                 transform_count); | ||||
|  | ||||
| @@ -896,7 +896,7 @@ _clutter_paint_volume_axis_align (ClutterPaintVolume *pv) | ||||
| { | ||||
|   int count; | ||||
|   int i; | ||||
|   ClutterVertex origin; | ||||
|   graphene_point3d_t origin; | ||||
|   float max_x; | ||||
|   float max_y; | ||||
|   float max_z; | ||||
| @@ -1075,7 +1075,7 @@ _clutter_paint_volume_cull (ClutterPaintVolume *pv, | ||||
|                             const ClutterPlane *planes) | ||||
| { | ||||
|   int vertex_count; | ||||
|   ClutterVertex *vertices = pv->vertices; | ||||
|   graphene_point3d_t *vertices = pv->vertices; | ||||
|   gboolean partial = FALSE; | ||||
|   int i; | ||||
|   int j; | ||||
| @@ -1097,24 +1097,18 @@ _clutter_paint_volume_cull (ClutterPaintVolume *pv, | ||||
|  | ||||
|   for (i = 0; i < 4; i++) | ||||
|     { | ||||
|       const ClutterPlane *plane = &planes[i]; | ||||
|       int out = 0; | ||||
|       for (j = 0; j < vertex_count; j++) | ||||
|         { | ||||
|           ClutterVertex p; | ||||
|           float distance; | ||||
|           graphene_vec3_t v; | ||||
|  | ||||
|           /* XXX: for perspective projections this can be optimized | ||||
|            * out because all the planes should pass through the origin | ||||
|            * so (0,0,0) is a valid v0. */ | ||||
|           p.x = vertices[j].x - planes[i].v0[0]; | ||||
|           p.y = vertices[j].y - planes[i].v0[1]; | ||||
|           p.z = vertices[j].z - planes[i].v0[2]; | ||||
|           graphene_vec3_init (&v, | ||||
|                               vertices[j].x - graphene_vec3_get_x (&plane->v0), | ||||
|                               vertices[j].y - graphene_vec3_get_y (&plane->v0), | ||||
|                               vertices[j].z - graphene_vec3_get_z (&plane->v0)); | ||||
|  | ||||
|           distance = (planes[i].n[0] * p.x + | ||||
|                       planes[i].n[1] * p.y + | ||||
|                       planes[i].n[2] * p.z); | ||||
|  | ||||
|           if (distance < 0) | ||||
|           if (graphene_vec3_dot (&plane->n, &v) < 0) | ||||
|             out++; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -27,8 +27,7 @@ | ||||
|  * and bezier curves. | ||||
|  * | ||||
|  * A #ClutterPath contains a description of a path consisting of | ||||
|  * straight lines and bezier curves. This can be used in a | ||||
|  * #ClutterBehaviourPath to animate an actor moving along the path. | ||||
|  * straight lines and bezier curves. | ||||
|  * | ||||
|  * The path consists of a series of nodes. Each node is one of the | ||||
|  * following four types: | ||||
| @@ -244,9 +243,6 @@ clutter_path_finalize (GObject *object) | ||||
|  * | ||||
|  * Creates a new #ClutterPath instance with no nodes. | ||||
|  * | ||||
|  * The object has a floating reference so if you add it to a | ||||
|  * #ClutterBehaviourPath then you do not need to unref it. | ||||
|  * | ||||
|  * Return value: the newly created #ClutterPath | ||||
|  * | ||||
|  * Since: 1.0 | ||||
| @@ -267,9 +263,6 @@ clutter_path_new (void) | ||||
|  * @desc. See clutter_path_add_string() for details of the format of | ||||
|  * the string. | ||||
|  * | ||||
|  * The object has a floating reference so if you add it to a | ||||
|  * #ClutterBehaviourPath then you do not need to unref it. | ||||
|  * | ||||
|  * Return value: the newly created #ClutterPath | ||||
|  * | ||||
|  * Since: 1.0 | ||||
|   | ||||
| @@ -64,10 +64,10 @@ typedef struct _ClutterVertex4          ClutterVertex4; | ||||
| #define CLUTTER_UNSET_PRIVATE_FLAGS(a,f) (CLUTTER_PRIVATE_FLAGS (a) &= ~(f)) | ||||
|  | ||||
| #define CLUTTER_ACTOR_IS_TOPLEVEL(a)            ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IS_TOPLEVEL) != FALSE) | ||||
| #define CLUTTER_ACTOR_IS_INTERNAL_CHILD(a)      ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_INTERNAL_CHILD) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_DESTRUCTION(a)         ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_DESTRUCTION) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_REPARENT(a)            ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_REPARENT) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_PAINT(a)               ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_PAINT) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_PICK(a)                ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_PICK) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_RELAYOUT(a)            ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_RELAYOUT) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_PREF_WIDTH(a)          ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_PREF_WIDTH) != FALSE) | ||||
| #define CLUTTER_ACTOR_IN_PREF_HEIGHT(a)         ((CLUTTER_PRIVATE_FLAGS (a) & CLUTTER_IN_PREF_HEIGHT) != FALSE) | ||||
| @@ -105,12 +105,10 @@ typedef enum | ||||
|  | ||||
|   /* Used to avoid recursion */ | ||||
|   CLUTTER_IN_PAINT       = 1 << 5, | ||||
|   CLUTTER_IN_PICK        = 1 << 6, | ||||
|  | ||||
|   /* Used to avoid recursion */ | ||||
|   CLUTTER_IN_RELAYOUT    = 1 << 6, | ||||
|  | ||||
|   /* a flag for internal children of Containers (DEPRECATED) */ | ||||
|   CLUTTER_INTERNAL_CHILD = 1 << 7 | ||||
|   CLUTTER_IN_RELAYOUT    = 1 << 7, | ||||
| } ClutterPrivateFlags; | ||||
|  | ||||
| /* | ||||
| @@ -224,17 +222,17 @@ void _clutter_run_repaint_functions (ClutterRepaintFlags flags); | ||||
|  | ||||
| GType _clutter_layout_manager_get_child_meta_type (ClutterLayoutManager *manager); | ||||
|  | ||||
| void  _clutter_util_fully_transform_vertices (const CoglMatrix    *modelview, | ||||
|                                               const CoglMatrix    *projection, | ||||
|                                               const float         *viewport, | ||||
|                                               const ClutterVertex *vertices_in, | ||||
|                                               ClutterVertex       *vertices_out, | ||||
|                                               int                  n_vertices); | ||||
| void  _clutter_util_fully_transform_vertices (const CoglMatrix         *modelview, | ||||
|                                               const CoglMatrix         *projection, | ||||
|                                               const float              *viewport, | ||||
|                                               const graphene_point3d_t *vertices_in, | ||||
|                                               graphene_point3d_t       *vertices_out, | ||||
|                                               int                       n_vertices); | ||||
|  | ||||
| void _clutter_util_rect_from_rectangle (const cairo_rectangle_int_t *src, | ||||
|                                         ClutterRect                 *dest); | ||||
|                                         graphene_rect_t             *dest); | ||||
|  | ||||
| void _clutter_util_rectangle_int_extents (const ClutterRect     *src, | ||||
| void _clutter_util_rectangle_int_extents (const graphene_rect_t *src, | ||||
|                                           cairo_rectangle_int_t *dest); | ||||
|  | ||||
| void _clutter_util_rectangle_offset (const cairo_rectangle_int_t *src, | ||||
| @@ -282,10 +280,10 @@ void    _clutter_util_matrix_skew_yz            (ClutterMatrix *matrix, | ||||
|                                                  float          factor); | ||||
|  | ||||
| gboolean        _clutter_util_matrix_decompose  (const ClutterMatrix *src, | ||||
|                                                  ClutterVertex       *scale_p, | ||||
|                                                  graphene_point3d_t  *scale_p, | ||||
|                                                  float                shear_p[3], | ||||
|                                                  ClutterVertex       *rotate_p, | ||||
|                                                  ClutterVertex       *translate_p, | ||||
|                                                  graphene_point3d_t  *rotate_p, | ||||
|                                                  graphene_point3d_t  *translate_p, | ||||
|                                                  ClutterVertex4      *perspective_p); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| @@ -296,8 +294,8 @@ PangoDirection _clutter_pango_find_base_dir     (const gchar *text, | ||||
|  | ||||
| typedef struct _ClutterPlane | ||||
| { | ||||
|   float v0[3]; | ||||
|   float n[3]; | ||||
|   graphene_vec3_t v0; | ||||
|   graphene_vec3_t n; | ||||
| } ClutterPlane; | ||||
|  | ||||
| typedef enum _ClutterCullResult | ||||
|   | ||||
| @@ -352,63 +352,64 @@ _clutter_script_parse_knot (ClutterScript *script, | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_geometry_from_array (JsonArray       *array, | ||||
|                            ClutterGeometry *geometry) | ||||
| parse_rect_from_array (JsonArray       *array, | ||||
|                        graphene_rect_t *rect) | ||||
| { | ||||
|   if (json_array_get_length (array) != 4) | ||||
|     return FALSE; | ||||
|  | ||||
|   geometry->x = json_array_get_int_element (array, 0); | ||||
|   geometry->y = json_array_get_int_element (array, 1); | ||||
|   geometry->width = json_array_get_int_element (array, 2); | ||||
|   geometry->height = json_array_get_int_element (array, 3); | ||||
|   graphene_rect_init (rect, | ||||
|                       json_array_get_int_element (array, 0), | ||||
|                       json_array_get_int_element (array, 1), | ||||
|                       json_array_get_int_element (array, 2), | ||||
|                       json_array_get_int_element (array, 3)); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_geometry_from_object (JsonObject      *object, | ||||
|                             ClutterGeometry *geometry) | ||||
| parse_rect_from_object (JsonObject      *object, | ||||
|                             graphene_rect_t *rect) | ||||
| { | ||||
|   if (json_object_has_member (object, "x")) | ||||
|     geometry->x = json_object_get_int_member (object, "x"); | ||||
|     rect->origin.x = json_object_get_int_member (object, "x"); | ||||
|   else | ||||
|     geometry->x = 0; | ||||
|     rect->origin.x = 0; | ||||
|  | ||||
|   if (json_object_has_member (object, "y")) | ||||
|     geometry->y = json_object_get_int_member (object, "y"); | ||||
|     rect->origin.y = json_object_get_int_member (object, "y"); | ||||
|   else | ||||
|     geometry->y = 0; | ||||
|     rect->origin.y = 0; | ||||
|  | ||||
|   if (json_object_has_member (object, "width")) | ||||
|     geometry->width = json_object_get_int_member (object, "width"); | ||||
|     rect->size.width = json_object_get_int_member (object, "width"); | ||||
|   else | ||||
|     geometry->width = 0; | ||||
|     rect->size.width = 0; | ||||
|  | ||||
|   if (json_object_has_member (object, "height")) | ||||
|     geometry->height = json_object_get_int_member (object, "height"); | ||||
|     rect->size.height = json_object_get_int_member (object, "height"); | ||||
|   else | ||||
|     geometry->height = 0; | ||||
|     rect->size.height = 0; | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| _clutter_script_parse_geometry (ClutterScript   *script, | ||||
|                                 JsonNode        *node, | ||||
|                                 ClutterGeometry *geometry) | ||||
| _clutter_script_parse_rect (ClutterScript   *script, | ||||
|                             JsonNode        *node, | ||||
|                             graphene_rect_t *rect) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SCRIPT (script), FALSE); | ||||
|   g_return_val_if_fail (node != NULL, FALSE); | ||||
|   g_return_val_if_fail (geometry != NULL, FALSE); | ||||
|   g_return_val_if_fail (rect != NULL, FALSE); | ||||
|  | ||||
|   switch (JSON_NODE_TYPE (node)) | ||||
|     { | ||||
|     case JSON_NODE_ARRAY: | ||||
|       return parse_geometry_from_array (json_node_get_array (node), geometry); | ||||
|       return parse_rect_from_array (json_node_get_array (node), rect); | ||||
|  | ||||
|     case JSON_NODE_OBJECT: | ||||
|       return parse_geometry_from_object (json_node_get_object (node), geometry); | ||||
|       return parse_rect_from_object (json_node_get_object (node), rect); | ||||
|  | ||||
|     default: | ||||
|       break; | ||||
| @@ -492,8 +493,8 @@ _clutter_script_parse_color (ClutterScript *script, | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_point_from_array (JsonArray    *array, | ||||
|                         ClutterPoint *point) | ||||
| parse_point_from_array (JsonArray        *array, | ||||
|                         graphene_point_t *point) | ||||
| { | ||||
|   if (json_array_get_length (array) != 2) | ||||
|     return FALSE; | ||||
| @@ -505,8 +506,8 @@ parse_point_from_array (JsonArray    *array, | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_point_from_object (JsonObject   *object, | ||||
|                          ClutterPoint *point) | ||||
| parse_point_from_object (JsonObject       *object, | ||||
|                          graphene_point_t *point) | ||||
| { | ||||
|   if (json_object_has_member (object, "x")) | ||||
|     point->x = json_object_get_double_member (object, "x"); | ||||
| @@ -522,9 +523,9 @@ parse_point_from_object (JsonObject   *object, | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| _clutter_script_parse_point (ClutterScript *script, | ||||
|                              JsonNode      *node, | ||||
|                              ClutterPoint  *point) | ||||
| _clutter_script_parse_point (ClutterScript    *script, | ||||
|                              JsonNode         *node, | ||||
|                              graphene_point_t *point) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SCRIPT (script), FALSE); | ||||
|   g_return_val_if_fail (node != NULL, FALSE); | ||||
| @@ -546,8 +547,8 @@ _clutter_script_parse_point (ClutterScript *script, | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_size_from_array (JsonArray   *array, | ||||
|                        ClutterSize *size) | ||||
| parse_size_from_array (JsonArray       *array, | ||||
|                        graphene_size_t *size) | ||||
| { | ||||
|   if (json_array_get_length (array) != 2) | ||||
|     return FALSE; | ||||
| @@ -559,8 +560,8 @@ parse_size_from_array (JsonArray   *array, | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| parse_size_from_object (JsonObject  *object, | ||||
|                         ClutterSize *size) | ||||
| parse_size_from_object (JsonObject      *object, | ||||
|                         graphene_size_t *size) | ||||
| { | ||||
|   if (json_object_has_member (object, "width")) | ||||
|     size->width = json_object_get_double_member (object, "width"); | ||||
| @@ -576,9 +577,9 @@ parse_size_from_object (JsonObject  *object, | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| _clutter_script_parse_size (ClutterScript *script, | ||||
|                             JsonNode      *node, | ||||
|                             ClutterSize   *size) | ||||
| _clutter_script_parse_size (ClutterScript   *script, | ||||
|                             JsonNode        *node, | ||||
|                             graphene_size_t *size) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SCRIPT (script), FALSE); | ||||
|   g_return_val_if_fail (node != NULL, FALSE); | ||||
| @@ -1328,11 +1329,11 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (p_type == CLUTTER_TYPE_GEOMETRY) | ||||
|           else if (p_type == GRAPHENE_TYPE_RECT) | ||||
|             { | ||||
|               ClutterGeometry geom = { 0, }; | ||||
|               graphene_rect_t rect = GRAPHENE_RECT_INIT_ZERO; | ||||
|  | ||||
|               /* geometry := { | ||||
|               /* rect := { | ||||
|                *        "x" : (int), | ||||
|                *        "y" : (int), | ||||
|                *        "width" : (int), | ||||
| @@ -1340,9 +1341,9 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                * } | ||||
|                */ | ||||
|  | ||||
|               if (_clutter_script_parse_geometry (script, node, &geom)) | ||||
|               if (_clutter_script_parse_rect (script, node, &rect)) | ||||
|                 { | ||||
|                   g_value_set_boxed (value, &geom); | ||||
|                   g_value_set_boxed (value, &rect); | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
| @@ -1364,9 +1365,9 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (p_type == CLUTTER_TYPE_POINT) | ||||
|           else if (p_type == GRAPHENE_TYPE_POINT) | ||||
|             { | ||||
|               ClutterPoint point = CLUTTER_POINT_INIT_ZERO; | ||||
|               graphene_point_t point = GRAPHENE_POINT_INIT_ZERO; | ||||
|  | ||||
|               if (_clutter_script_parse_point (script, node, &point)) | ||||
|                 { | ||||
| @@ -1374,9 +1375,9 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (p_type == CLUTTER_TYPE_SIZE) | ||||
|           else if (p_type == GRAPHENE_TYPE_SIZE) | ||||
|             { | ||||
|               ClutterSize size = CLUTTER_SIZE_INIT_ZERO; | ||||
|               graphene_size_t size = GRAPHENE_SIZE_INIT_ZERO; | ||||
|  | ||||
|               if (_clutter_script_parse_size (script, node, &size)) | ||||
|                 { | ||||
| @@ -1417,15 +1418,15 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (G_VALUE_HOLDS (value, CLUTTER_TYPE_GEOMETRY)) | ||||
|           else if (G_VALUE_HOLDS (value, GRAPHENE_TYPE_RECT)) | ||||
|             { | ||||
|               ClutterGeometry geom = { 0, }; | ||||
|               graphene_rect_t rect = GRAPHENE_RECT_INIT_ZERO; | ||||
|  | ||||
|               /* geometry := [ (int), (int), (int), (int) ] */ | ||||
|               /* rect := [ (int), (int), (int), (int) ] */ | ||||
|  | ||||
|               if (_clutter_script_parse_geometry (script, node, &geom)) | ||||
|               if (_clutter_script_parse_rect (script, node, &rect)) | ||||
|                 { | ||||
|                   g_value_set_boxed (value, &geom); | ||||
|                   g_value_set_boxed (value, &rect); | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
| @@ -1441,9 +1442,9 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (G_VALUE_HOLDS (value, CLUTTER_TYPE_POINT)) | ||||
|           else if (G_VALUE_HOLDS (value, GRAPHENE_TYPE_POINT)) | ||||
|             { | ||||
|               ClutterPoint point = CLUTTER_POINT_INIT_ZERO; | ||||
|               graphene_point_t point = GRAPHENE_POINT_INIT_ZERO; | ||||
|  | ||||
|               if (_clutter_script_parse_point (script, node, &point)) | ||||
|                 { | ||||
| @@ -1451,9 +1452,9 @@ _clutter_script_parse_node (ClutterScript *script, | ||||
|                   return TRUE; | ||||
|                 } | ||||
|             } | ||||
|           else if (G_VALUE_HOLDS (value, CLUTTER_TYPE_SIZE)) | ||||
|           else if (G_VALUE_HOLDS (value, GRAPHENE_TYPE_SIZE)) | ||||
|             { | ||||
|               ClutterSize size = CLUTTER_SIZE_INIT_ZERO; | ||||
|               graphene_size_t size = GRAPHENE_SIZE_INIT_ZERO; | ||||
|  | ||||
|               if (_clutter_script_parse_size (script, node, &size)) | ||||
|                 { | ||||
|   | ||||
| @@ -122,20 +122,20 @@ gboolean _clutter_script_flags_from_string (GType          gtype, | ||||
| gboolean _clutter_script_parse_knot        (ClutterScript   *script, | ||||
|                                             JsonNode        *node, | ||||
|                                             ClutterKnot     *knot); | ||||
| gboolean _clutter_script_parse_geometry    (ClutterScript   *script, | ||||
| gboolean _clutter_script_parse_rect        (ClutterScript   *script, | ||||
|                                             JsonNode        *node, | ||||
|                                             ClutterGeometry *geometry); | ||||
|                                             graphene_rect_t *rect); | ||||
| gboolean _clutter_script_parse_color       (ClutterScript   *script, | ||||
|                                             JsonNode        *node, | ||||
|                                             ClutterColor    *color); | ||||
| GObject *_clutter_script_parse_alpha       (ClutterScript   *script, | ||||
|                                             JsonNode        *node); | ||||
| gboolean _clutter_script_parse_point       (ClutterScript   *script, | ||||
|                                             JsonNode        *node, | ||||
|                                             ClutterPoint    *point); | ||||
| gboolean _clutter_script_parse_point       (ClutterScript    *script, | ||||
|                                             JsonNode         *node, | ||||
|                                             graphene_point_t *point); | ||||
| gboolean _clutter_script_parse_size        (ClutterScript   *script, | ||||
|                                             JsonNode        *node, | ||||
|                                             ClutterSize     *size); | ||||
|                                             graphene_size_t *size); | ||||
|  | ||||
| gboolean _clutter_script_parse_translatable_string (ClutterScript *script, | ||||
|                                                     JsonNode      *node, | ||||
|   | ||||
| @@ -75,65 +75,6 @@ | ||||
|  * packing rules of Clutter still apply, and an actor cannot be packed | ||||
|  * in multiple containers without unparenting it in between). | ||||
|  * | ||||
|  * Behaviours and timelines can also be defined inside a UI definition | ||||
|  * buffer: | ||||
|  * | ||||
|  * <informalexample><programlisting><![CDATA[ | ||||
|  * { | ||||
|  *   "id"          : "rotate-behaviour", | ||||
|  *   "type"        : "ClutterBehaviourRotate", | ||||
|  *   "angle-start" : 0.0, | ||||
|  *   "angle-end"   : 360.0, | ||||
|  *   "axis"        : "z-axis", | ||||
|  *   "alpha"       : { | ||||
|  *     "timeline" : { "duration" : 4000, "loop" : true }, | ||||
|  *     "mode"     : "easeInSine" | ||||
|  *   } | ||||
|  * } | ||||
|  * ]]></programlisting></informalexample> | ||||
|  * | ||||
|  * And then to apply a defined behaviour to an actor defined inside the | ||||
|  * definition of an actor, the "behaviour" member can be used: | ||||
|  * | ||||
|  * <informalexample><programlisting><![CDATA[ | ||||
|  * { | ||||
|  *   "id" : "my-rotating-actor", | ||||
|  *   "type" : "ClutterTexture", | ||||
|  *   ... | ||||
|  *   "behaviours" : [ "rotate-behaviour" ] | ||||
|  * } | ||||
|  * ]]></programlisting></informalexample> | ||||
|  * | ||||
|  * A #ClutterAlpha belonging to a #ClutterBehaviour can only be defined | ||||
|  * implicitly like in the example above, or explicitly by setting the | ||||
|  * "alpha" property to point to a previously defined #ClutterAlpha, e.g.: | ||||
|  * | ||||
|  * <informalexample><programlisting><![CDATA[ | ||||
|  * { | ||||
|  *   "id"          : "rotate-behaviour", | ||||
|  *   "type"        : "ClutterBehaviourRotate", | ||||
|  *   "angle-start" : 0.0, | ||||
|  *   "angle-end"   : 360.0, | ||||
|  *   "axis"        : "z-axis", | ||||
|  *   "alpha"       : { | ||||
|  *     "id"       : "rotate-alpha", | ||||
|  *     "type"     : "ClutterAlpha", | ||||
|  *     "timeline" : { | ||||
|  *       "id"       : "rotate-timeline", | ||||
|  *       "type      : "ClutterTimeline", | ||||
|  *       "duration" : 4000, | ||||
|  *       "loop"     : true | ||||
|  *     }, | ||||
|  *     "function" : "custom_sine_alpha" | ||||
|  *   } | ||||
|  * } | ||||
|  * ]]></programlisting></informalexample> | ||||
|  * | ||||
|  * Implicitely defined #ClutterAlpha<!-- -->s and #ClutterTimeline<!-- -->s | ||||
|  * can omit the `id`, as well as the `type` members, but will not be available | ||||
|  * using clutter_script_get_object() (they can, however, be extracted using the | ||||
|  * #ClutterBehaviour and #ClutterAlpha API respectively). | ||||
|  * | ||||
|  * Signal handlers can be defined inside a Clutter UI definition file and | ||||
|  * then autoconnected to their respective signals using the | ||||
|  * clutter_script_connect_signals() function: | ||||
| @@ -210,7 +151,6 @@ | ||||
|  *                   function | ||||
|  *   "type_func"  := the GType function name, for non-standard classes | ||||
|  *   "children"   := an array of names or objects to add as children | ||||
|  *   "behaviours" := an array of names or objects to apply to an actor | ||||
|  *   "signals"    := an array of signal definitions to connect to an object | ||||
|  *   "is-default" := a boolean flag used when defining the #ClutterStage; | ||||
|  *                   if set to "true" the default stage will be used instead | ||||
| @@ -235,7 +175,6 @@ | ||||
|  | ||||
| #include "clutter-actor.h" | ||||
| #include "clutter-stage.h" | ||||
| #include "clutter-texture.h" | ||||
|  | ||||
| #include "clutter-script.h" | ||||
| #include "clutter-script-private.h" | ||||
| @@ -246,7 +185,6 @@ | ||||
| #include "clutter-debug.h" | ||||
|  | ||||
| #include "deprecated/clutter-alpha.h" | ||||
| #include "deprecated/clutter-behaviour.h" | ||||
| #include "deprecated/clutter-container.h" | ||||
| #include "deprecated/clutter-state.h" | ||||
|  | ||||
| @@ -524,11 +462,10 @@ clutter_script_init (ClutterScript *script) | ||||
| /** | ||||
|  * clutter_script_new: | ||||
|  * | ||||
|  * Creates a new #ClutterScript instance. #ClutterScript can be used | ||||
|  * to load objects definitions for scenegraph elements, like actors, | ||||
|  * or behavioural elements, like behaviours and timelines. The | ||||
|  * definitions must be encoded using the JavaScript Object Notation (JSON) | ||||
|  * language. | ||||
|  * Creates a new #ClutterScript instance. #ClutterScript can be used to load | ||||
|  * objects definitions for scenegraph elements, like actors, or behavioural | ||||
|  * elements, like timelines. The definitions must be encoded using the | ||||
|  * JavaScript Object Notation (JSON) language. | ||||
|  * | ||||
|  * Return value: the newly created #ClutterScript instance. Use | ||||
|  *   g_object_unref() when done. | ||||
| @@ -863,9 +800,7 @@ construct_each_objects (gpointer key, | ||||
|       if (oinfo->object == NULL) | ||||
|         _clutter_script_construct_object (script, oinfo); | ||||
|  | ||||
|       /* this will take care of setting up properties, | ||||
|        * adding children and applying behaviours | ||||
|        */ | ||||
|       /* this will take care of setting up properties and adding children */ | ||||
|       _clutter_script_apply_properties (script, oinfo); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -56,7 +56,7 @@ | ||||
|  | ||||
| struct _ClutterScrollActorPrivate | ||||
| { | ||||
|   ClutterPoint scroll_to; | ||||
|   graphene_point_t scroll_to; | ||||
|  | ||||
|   ClutterScrollMode scroll_mode; | ||||
|  | ||||
| @@ -94,19 +94,19 @@ G_DEFINE_TYPE_WITH_CODE (ClutterScrollActor, clutter_scroll_actor, CLUTTER_TYPE_ | ||||
|                                                 clutter_animatable_iface_init)) | ||||
|  | ||||
| static void | ||||
| clutter_scroll_actor_set_scroll_to_internal (ClutterScrollActor *self, | ||||
|                                              const ClutterPoint *point) | ||||
| clutter_scroll_actor_set_scroll_to_internal (ClutterScrollActor     *self, | ||||
|                                              const graphene_point_t *point) | ||||
| { | ||||
|   ClutterScrollActorPrivate *priv = self->priv; | ||||
|   ClutterActor *actor = CLUTTER_ACTOR (self); | ||||
|   ClutterMatrix m = CLUTTER_MATRIX_INIT_IDENTITY; | ||||
|   float dx, dy; | ||||
|  | ||||
|   if (clutter_point_equals (&priv->scroll_to, point)) | ||||
|   if (graphene_point_equal (&priv->scroll_to, point)) | ||||
|     return; | ||||
|  | ||||
|   if (point == NULL) | ||||
|     clutter_point_init (&priv->scroll_to, 0.f, 0.f); | ||||
|     graphene_point_init (&priv->scroll_to, 0.f, 0.f); | ||||
|   else | ||||
|     priv->scroll_to = *point; | ||||
|  | ||||
| @@ -216,7 +216,7 @@ clutter_scroll_actor_set_final_state (ClutterAnimatable *animatable, | ||||
|   if (strcmp (property_name, "scroll-to") == 0) | ||||
|     { | ||||
|       ClutterScrollActor *self = CLUTTER_SCROLL_ACTOR (animatable); | ||||
|       const ClutterPoint *point = g_value_get_boxed (value); | ||||
|       const graphene_point_t *point = g_value_get_boxed (value); | ||||
|  | ||||
|       clutter_scroll_actor_set_scroll_to_internal (self, point); | ||||
|     } | ||||
| @@ -248,7 +248,7 @@ clutter_animatable_iface_init (ClutterAnimatableInterface *iface) | ||||
|     g_param_spec_boxed ("scroll-to", | ||||
|                         "Scroll To", | ||||
|                         "The point to scroll the actor to", | ||||
|                         CLUTTER_TYPE_POINT, | ||||
|                         GRAPHENE_TYPE_POINT, | ||||
|                         G_PARAM_READWRITE | | ||||
|                         G_PARAM_STATIC_STRINGS | | ||||
|                         CLUTTER_PARAM_ANIMATABLE); | ||||
| @@ -322,7 +322,7 @@ clutter_scroll_actor_get_scroll_mode (ClutterScrollActor *actor) | ||||
| /** | ||||
|  * clutter_scroll_actor_scroll_to_point: | ||||
|  * @actor: a #ClutterScrollActor | ||||
|  * @point: a #ClutterPoint | ||||
|  * @point: a #graphene_point_t | ||||
|  * | ||||
|  * Scrolls the contents of @actor so that @point is the new origin | ||||
|  * of the visible area. | ||||
| @@ -335,8 +335,8 @@ clutter_scroll_actor_get_scroll_mode (ClutterScrollActor *actor) | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| void | ||||
| clutter_scroll_actor_scroll_to_point (ClutterScrollActor *actor, | ||||
|                                       const ClutterPoint *point) | ||||
| clutter_scroll_actor_scroll_to_point (ClutterScrollActor     *actor, | ||||
|                                       const graphene_point_t *point) | ||||
| { | ||||
|   ClutterScrollActorPrivate *priv; | ||||
|   const ClutterAnimationInfo *info; | ||||
| @@ -390,10 +390,10 @@ clutter_scroll_actor_scroll_to_point (ClutterScrollActor *actor, | ||||
|  | ||||
|   /* if a transition already exist, update its bounds */ | ||||
|   clutter_transition_set_from (priv->transition, | ||||
|                                CLUTTER_TYPE_POINT, | ||||
|                                GRAPHENE_TYPE_POINT, | ||||
|                                &priv->scroll_to); | ||||
|   clutter_transition_set_to (priv->transition, | ||||
|                              CLUTTER_TYPE_POINT, | ||||
|                              GRAPHENE_TYPE_POINT, | ||||
|                              point); | ||||
|  | ||||
|   /* always use the current easing state */ | ||||
| @@ -417,10 +417,10 @@ clutter_scroll_actor_scroll_to_point (ClutterScrollActor *actor, | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| void | ||||
| clutter_scroll_actor_scroll_to_rect (ClutterScrollActor *actor, | ||||
|                                      const ClutterRect  *rect) | ||||
| clutter_scroll_actor_scroll_to_rect (ClutterScrollActor    *actor, | ||||
|                                      const graphene_rect_t *rect) | ||||
| { | ||||
|   ClutterRect n_rect; | ||||
|   graphene_rect_t n_rect; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SCROLL_ACTOR (actor)); | ||||
|   g_return_if_fail (rect != NULL); | ||||
| @@ -428,7 +428,7 @@ clutter_scroll_actor_scroll_to_rect (ClutterScrollActor *actor, | ||||
|   n_rect = *rect; | ||||
|  | ||||
|   /* normalize, so that we have a valid origin */ | ||||
|   clutter_rect_normalize (&n_rect); | ||||
|   graphene_rect_normalize (&n_rect); | ||||
|  | ||||
|   clutter_scroll_actor_scroll_to_point (actor, &n_rect.origin); | ||||
| } | ||||
|   | ||||
| @@ -86,11 +86,11 @@ CLUTTER_EXPORT | ||||
| ClutterScrollMode       clutter_scroll_actor_get_scroll_mode    (ClutterScrollActor *actor); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_scroll_actor_scroll_to_point    (ClutterScrollActor *actor, | ||||
|                                                                  const ClutterPoint *point); | ||||
| void                    clutter_scroll_actor_scroll_to_point    (ClutterScrollActor     *actor, | ||||
|                                                                  const graphene_point_t *point); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_scroll_actor_scroll_to_rect     (ClutterScrollActor *actor, | ||||
|                                                                  const ClutterRect  *rect); | ||||
| void                    clutter_scroll_actor_scroll_to_rect     (ClutterScrollActor    *actor, | ||||
|                                                                  const graphene_rect_t *rect); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
|   | ||||
							
								
								
									
										568
									
								
								clutter/clutter/clutter-seat.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										568
									
								
								clutter/clutter/clutter-seat.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,568 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2019 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, see <http://www.gnu.org/licenses/>. | ||||
|  * | ||||
|  * Author: Carlos Garnacho <carlosg@gnome.org> | ||||
|  */ | ||||
|  | ||||
| #include "clutter-build-config.h" | ||||
|  | ||||
| #include "clutter-backend-private.h" | ||||
| #include "clutter-input-device-tool.h" | ||||
| #include "clutter-input-pointer-a11y-private.h" | ||||
| #include "clutter-marshal.h" | ||||
| #include "clutter-private.h" | ||||
| #include "clutter-seat.h" | ||||
| #include "clutter-virtual-input-device.h" | ||||
|  | ||||
| enum | ||||
| { | ||||
|   DEVICE_ADDED, | ||||
|   DEVICE_REMOVED, | ||||
|   TOOL_CHANGED, | ||||
|   KBD_A11Y_MASK_CHANGED, | ||||
|   KBD_A11Y_FLAGS_CHANGED, | ||||
|   PTR_A11Y_DWELL_CLICK_TYPE_CHANGED, | ||||
|   PTR_A11Y_TIMEOUT_STARTED, | ||||
|   PTR_A11Y_TIMEOUT_STOPPED, | ||||
|   N_SIGNALS, | ||||
| }; | ||||
|  | ||||
| static guint signals[N_SIGNALS] = { 0 }; | ||||
|  | ||||
| enum | ||||
| { | ||||
|   PROP_0, | ||||
|   PROP_BACKEND, | ||||
|   N_PROPS | ||||
| }; | ||||
|  | ||||
| static GParamSpec *props[N_PROPS]; | ||||
|  | ||||
| typedef struct _ClutterSeatPrivate ClutterSeatPrivate; | ||||
|  | ||||
| struct _ClutterSeatPrivate | ||||
| { | ||||
|   ClutterBackend *backend; | ||||
|  | ||||
|   /* Keyboard a11y */ | ||||
|   ClutterKbdA11ySettings kbd_a11y_settings; | ||||
|  | ||||
|   /* Pointer a11y */ | ||||
|   ClutterPointerA11ySettings pointer_a11y_settings; | ||||
| }; | ||||
|  | ||||
| G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (ClutterSeat, clutter_seat, G_TYPE_OBJECT) | ||||
|  | ||||
| static void | ||||
| clutter_seat_set_property (GObject      *object, | ||||
|                            guint         prop_id, | ||||
|                            const GValue *value, | ||||
|                            GParamSpec   *pspec) | ||||
| { | ||||
|   ClutterSeat *seat = CLUTTER_SEAT (object); | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   switch (prop_id) | ||||
|     { | ||||
|     case PROP_BACKEND: | ||||
|       priv->backend = g_value_get_object (value); | ||||
|       break; | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_get_property (GObject    *object, | ||||
|                            guint       prop_id, | ||||
|                            GValue     *value, | ||||
|                            GParamSpec *pspec) | ||||
| { | ||||
|   ClutterSeat *seat = CLUTTER_SEAT (object); | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   switch (prop_id) | ||||
|     { | ||||
|     case PROP_BACKEND: | ||||
|       g_value_set_object (value, priv->backend); | ||||
|       break; | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_finalize (GObject *object) | ||||
| { | ||||
|   ClutterSeat *seat = CLUTTER_SEAT (object); | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_clear_object (&priv->backend); | ||||
|  | ||||
|   G_OBJECT_CLASS (clutter_seat_parent_class)->finalize (object); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_class_init (ClutterSeatClass *klass) | ||||
| { | ||||
|   GObjectClass *object_class = G_OBJECT_CLASS (klass); | ||||
|  | ||||
|   object_class->set_property = clutter_seat_set_property; | ||||
|   object_class->get_property = clutter_seat_get_property; | ||||
|   object_class->finalize = clutter_seat_finalize; | ||||
|  | ||||
|   signals[DEVICE_ADDED] = | ||||
|     g_signal_new (I_("device-added"), | ||||
|                   G_TYPE_FROM_CLASS (object_class), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   g_cclosure_marshal_VOID__OBJECT, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE); | ||||
|   g_signal_set_va_marshaller (signals[DEVICE_ADDED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               g_cclosure_marshal_VOID__OBJECTv); | ||||
|  | ||||
|   signals[DEVICE_REMOVED] = | ||||
|     g_signal_new (I_("device-removed"), | ||||
|                   G_TYPE_FROM_CLASS (object_class), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   g_cclosure_marshal_VOID__OBJECT, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE); | ||||
|   g_signal_set_va_marshaller (signals[DEVICE_REMOVED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               g_cclosure_marshal_VOID__OBJECTv); | ||||
|   signals[TOOL_CHANGED] = | ||||
|     g_signal_new (I_("tool-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_OBJECT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE_TOOL); | ||||
|   g_signal_set_va_marshaller (signals[TOOL_CHANGED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               _clutter_marshal_VOID__OBJECT_OBJECTv); | ||||
|  | ||||
|   /** | ||||
|    * ClutterSeat::kbd-a11y-mods-state-changed: | ||||
|    * @seat: the #ClutterSeat that emitted the signal | ||||
|    * @latched_mask: the latched modifier mask from stickykeys | ||||
|    * @locked_mask:  the locked modifier mask from stickykeys | ||||
|    * | ||||
|    * The ::kbd-a11y-mods-state-changed signal is emitted each time either the | ||||
|    * latched modifiers mask or locked modifiers mask are changed as the | ||||
|    * result of keyboard accessibilty's sticky keys operations. | ||||
|    */ | ||||
|   signals[KBD_A11Y_MASK_CHANGED] = | ||||
|     g_signal_new (I_("kbd-a11y-mods-state-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__UINT_UINT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   G_TYPE_UINT, | ||||
|                   G_TYPE_UINT); | ||||
|   g_signal_set_va_marshaller (signals[KBD_A11Y_MASK_CHANGED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               _clutter_marshal_VOID__UINT_UINTv); | ||||
|  | ||||
|   /** | ||||
|    * ClutterSeat::kbd-a11y-flags-changed: | ||||
|    * @seat: the #ClutterSeat that emitted the signal | ||||
|    * @settings_flags: the new ClutterKeyboardA11yFlags configuration | ||||
|    * @changed_mask: the ClutterKeyboardA11yFlags changed | ||||
|    * | ||||
|    * The ::kbd-a11y-flags-changed signal is emitted each time the | ||||
|    * ClutterKeyboardA11yFlags configuration is changed as the result of | ||||
|    * keyboard accessibility operations. | ||||
|    */ | ||||
|   signals[KBD_A11Y_FLAGS_CHANGED] = | ||||
|     g_signal_new (I_("kbd-a11y-flags-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__UINT_UINT, | ||||
|                   G_TYPE_NONE, 2, | ||||
|                   G_TYPE_UINT, | ||||
|                   G_TYPE_UINT); | ||||
|   g_signal_set_va_marshaller (signals[KBD_A11Y_FLAGS_CHANGED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               _clutter_marshal_VOID__UINT_UINTv); | ||||
|  | ||||
|   /** | ||||
|    * ClutterSeat::ptr-a11y-dwell-click-type-changed: | ||||
|    * @seat: the #ClutterSeat that emitted the signal | ||||
|    * @click_type: the new #ClutterPointerA11yDwellClickType mode | ||||
|    * | ||||
|    * The ::ptr-a11y-dwell-click-type-changed signal is emitted each time | ||||
|    * the ClutterPointerA11yDwellClickType mode is changed as the result | ||||
|    * of pointer accessibility operations. | ||||
|    */ | ||||
|   signals[PTR_A11Y_DWELL_CLICK_TYPE_CHANGED] = | ||||
|     g_signal_new (I_("ptr-a11y-dwell-click-type-changed"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   g_cclosure_marshal_VOID__FLAGS, | ||||
|                   G_TYPE_NONE, 1, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_DWELL_CLICK_TYPE); | ||||
|   g_signal_set_va_marshaller (signals[PTR_A11Y_DWELL_CLICK_TYPE_CHANGED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               g_cclosure_marshal_VOID__FLAGSv); | ||||
|  | ||||
|   /** | ||||
|    * ClutterSeat::ptr-a11y-timeout-started: | ||||
|    * @seat: the #ClutterSeat that emitted the signal | ||||
|    * @device: the core pointer #ClutterInputDevice | ||||
|    * @timeout_type: the type of timeout #ClutterPointerA11yTimeoutType | ||||
|    * @delay: the delay in ms before secondary-click is triggered. | ||||
|    * | ||||
|    * The ::ptr-a11y-timeout-started signal is emitted when a | ||||
|    * pointer accessibility timeout delay is started, so that upper | ||||
|    * layers can notify the user with some visual feedback. | ||||
|    */ | ||||
|   signals[PTR_A11Y_TIMEOUT_STARTED] = | ||||
|     g_signal_new (I_("ptr-a11y-timeout-started"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_FLAGS_UINT, | ||||
|                   G_TYPE_NONE, 3, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_TIMEOUT_TYPE, | ||||
|                   G_TYPE_UINT); | ||||
|   g_signal_set_va_marshaller (signals[PTR_A11Y_TIMEOUT_STARTED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               _clutter_marshal_VOID__OBJECT_FLAGS_UINTv); | ||||
|  | ||||
|   /** | ||||
|    * ClutterSeat::ptr-a11y-timeout-stopped: | ||||
|    * @seat: the #ClutterSeat that emitted the signal | ||||
|    * @device: the core pointer #ClutterInputDevice | ||||
|    * @timeout_type: the type of timeout #ClutterPointerA11yTimeoutType | ||||
|    * @clicked: %TRUE if the timeout finished and triggered a click | ||||
|    * | ||||
|    * The ::ptr-a11y-timeout-stopped signal is emitted when a running | ||||
|    * pointer accessibility timeout delay is stopped, either because | ||||
|    * it's triggered at the end of the delay or cancelled, so that | ||||
|    * upper layers can notify the user with some visual feedback. | ||||
|    */ | ||||
|   signals[PTR_A11Y_TIMEOUT_STOPPED] = | ||||
|     g_signal_new (I_("ptr-a11y-timeout-stopped"), | ||||
|                   G_TYPE_FROM_CLASS (klass), | ||||
|                   G_SIGNAL_RUN_LAST, | ||||
|                   0, NULL, NULL, | ||||
|                   _clutter_marshal_VOID__OBJECT_FLAGS_BOOLEAN, | ||||
|                   G_TYPE_NONE, 3, | ||||
|                   CLUTTER_TYPE_INPUT_DEVICE, | ||||
|                   CLUTTER_TYPE_POINTER_A11Y_TIMEOUT_TYPE, | ||||
|                   G_TYPE_BOOLEAN); | ||||
|   g_signal_set_va_marshaller (signals[PTR_A11Y_TIMEOUT_STOPPED], | ||||
|                               G_TYPE_FROM_CLASS (object_class), | ||||
|                               _clutter_marshal_VOID__OBJECT_FLAGS_BOOLEANv); | ||||
|  | ||||
|   props[PROP_BACKEND] = | ||||
|     g_param_spec_object ("backend", | ||||
|                          P_("Backend"), | ||||
|                          P_("Backend"), | ||||
|                          CLUTTER_TYPE_BACKEND, | ||||
|                          CLUTTER_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY); | ||||
|  | ||||
|   g_object_class_install_properties (object_class, N_PROPS, props); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_init (ClutterSeat *seat) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_get_pointer: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * | ||||
|  * Returns the master pointer | ||||
|  * | ||||
|  * Returns: (transfer none): the master pointer | ||||
|  **/ | ||||
| ClutterInputDevice * | ||||
| clutter_seat_get_pointer (ClutterSeat *seat) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SEAT (seat), NULL); | ||||
|  | ||||
|   return CLUTTER_SEAT_GET_CLASS (seat)->get_pointer (seat); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_get_keyboard: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * | ||||
|  * Returns the master keyboard | ||||
|  * | ||||
|  * Returns: (transfer none): the master keyboard | ||||
|  **/ | ||||
| ClutterInputDevice * | ||||
| clutter_seat_get_keyboard (ClutterSeat *seat) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SEAT (seat), NULL); | ||||
|  | ||||
|   return CLUTTER_SEAT_GET_CLASS (seat)->get_keyboard (seat); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_list_devices: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * | ||||
|  * Returns the list of HW devices | ||||
|  * | ||||
|  * Returns: (transfer container) (element-type Clutter.InputDevice): A list of #ClutterInputDevice | ||||
|  **/ | ||||
| GList * | ||||
| clutter_seat_list_devices (ClutterSeat *seat) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SEAT (seat), NULL); | ||||
|  | ||||
|   return CLUTTER_SEAT_GET_CLASS (seat)->list_devices (seat); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_bell_notify (ClutterSeat *seat) | ||||
| { | ||||
|   CLUTTER_SEAT_GET_CLASS (seat)->bell_notify (seat); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_get_keymap: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * | ||||
|  * Returns the seat keymap | ||||
|  * | ||||
|  * Returns: (transfer none): the seat keymap | ||||
|  **/ | ||||
| ClutterKeymap * | ||||
| clutter_seat_get_keymap (ClutterSeat *seat) | ||||
| { | ||||
|   return CLUTTER_SEAT_GET_CLASS (seat)->get_keymap (seat); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| are_kbd_a11y_settings_equal (ClutterKbdA11ySettings *a, | ||||
|                              ClutterKbdA11ySettings *b) | ||||
| { | ||||
|   return (memcmp (a, b, sizeof (ClutterKbdA11ySettings)) == 0); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_set_kbd_a11y_settings (ClutterSeat            *seat, | ||||
|                                     ClutterKbdA11ySettings *settings) | ||||
| { | ||||
|   ClutterSeatClass *seat_class; | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   if (are_kbd_a11y_settings_equal (&priv->kbd_a11y_settings, settings)) | ||||
|     return; | ||||
|  | ||||
|   priv->kbd_a11y_settings = *settings; | ||||
|  | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   if (seat_class->apply_kbd_a11y_settings) | ||||
|     seat_class->apply_kbd_a11y_settings (seat, settings); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_get_kbd_a11y_settings (ClutterSeat            *seat, | ||||
|                                     ClutterKbdA11ySettings *settings) | ||||
| { | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   *settings = priv->kbd_a11y_settings; | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_ensure_a11y_state (ClutterSeat *seat) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_seat_get_pointer (seat); | ||||
|  | ||||
|   if (core_pointer) | ||||
|     { | ||||
|       if (_clutter_is_input_pointer_a11y_enabled (core_pointer)) | ||||
|         _clutter_input_pointer_a11y_add_device (core_pointer); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| are_pointer_a11y_settings_equal (ClutterPointerA11ySettings *a, | ||||
|                                  ClutterPointerA11ySettings *b) | ||||
| { | ||||
|   return (memcmp (a, b, sizeof (ClutterPointerA11ySettings)) == 0); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_enable_pointer_a11y (ClutterSeat *seat) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_seat_get_pointer (seat); | ||||
|  | ||||
|   _clutter_input_pointer_a11y_add_device (core_pointer); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_seat_disable_pointer_a11y (ClutterSeat *seat) | ||||
| { | ||||
|   ClutterInputDevice *core_pointer; | ||||
|  | ||||
|   core_pointer = clutter_seat_get_pointer (seat); | ||||
|  | ||||
|   _clutter_input_pointer_a11y_remove_device (core_pointer); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_set_pointer_a11y_settings: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * @settings: a pointer to a #ClutterPointerA11ySettings | ||||
|  * | ||||
|  * Sets the pointer accessibility settings | ||||
|  **/ | ||||
| void | ||||
| clutter_seat_set_pointer_a11y_settings (ClutterSeat                *seat, | ||||
|                                         ClutterPointerA11ySettings *settings) | ||||
| { | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   if (are_pointer_a11y_settings_equal (&priv->pointer_a11y_settings, settings)) | ||||
|     return; | ||||
|  | ||||
|   if (priv->pointer_a11y_settings.controls == 0 && settings->controls != 0) | ||||
|     clutter_seat_enable_pointer_a11y (seat); | ||||
|   else if (priv->pointer_a11y_settings.controls != 0 && settings->controls == 0) | ||||
|     clutter_seat_disable_pointer_a11y (seat); | ||||
|  | ||||
|   priv->pointer_a11y_settings = *settings; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_get_pointer_a11y_settings: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * @settings: a pointer to a #ClutterPointerA11ySettings | ||||
|  * | ||||
|  * Gets the current pointer accessibility settings | ||||
|  **/ | ||||
| void | ||||
| clutter_seat_get_pointer_a11y_settings (ClutterSeat                *seat, | ||||
|                                         ClutterPointerA11ySettings *settings) | ||||
| { | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   *settings = priv->pointer_a11y_settings; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_set_pointer_a11y_dwell_click_type: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * @click_type: type of click as #ClutterPointerA11yDwellClickType | ||||
|  * | ||||
|  * Sets the dwell click type | ||||
|  **/ | ||||
| void | ||||
| clutter_seat_set_pointer_a11y_dwell_click_type (ClutterSeat                      *seat, | ||||
|                                                 ClutterPointerA11yDwellClickType  click_type) | ||||
| { | ||||
|   ClutterSeatPrivate *priv = clutter_seat_get_instance_private (seat); | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   priv->pointer_a11y_settings.dwell_click_type = click_type; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_create_virtual_device: | ||||
|  * @seat: a #ClutterSeat | ||||
|  * @device_type: the type of the virtual device | ||||
|  * | ||||
|  * Creates a virtual input device. | ||||
|  * | ||||
|  * Returns: (transfer full): a newly created virtual device | ||||
|  **/ | ||||
| ClutterVirtualInputDevice * | ||||
| clutter_seat_create_virtual_device (ClutterSeat            *seat, | ||||
|                                     ClutterInputDeviceType  device_type) | ||||
| { | ||||
|   ClutterSeatClass *seat_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_SEAT (seat), NULL); | ||||
|  | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   return seat_class->create_virtual_device (seat, device_type); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_seat_supported_virtual_device_types: (skip) | ||||
|  */ | ||||
| ClutterVirtualDeviceType | ||||
| clutter_seat_get_supported_virtual_device_types (ClutterSeat *seat) | ||||
| { | ||||
|   ClutterSeatClass *seat_class; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_SEAT (seat), | ||||
|                         CLUTTER_VIRTUAL_DEVICE_TYPE_NONE); | ||||
|  | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   return seat_class->get_supported_virtual_device_types (seat); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_compress_motion (ClutterSeat        *seat, | ||||
|                               ClutterEvent       *event, | ||||
|                               const ClutterEvent *to_discard) | ||||
| { | ||||
|   ClutterSeatClass *seat_class; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   seat_class = CLUTTER_SEAT_GET_CLASS (seat); | ||||
|   if (!seat_class->compress_motion) | ||||
|     return; | ||||
|  | ||||
|   seat_class->compress_motion (seat, event, to_discard); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_seat_warp_pointer (ClutterSeat *seat, | ||||
|                            int          x, | ||||
|                            int          y) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_SEAT (seat)); | ||||
|  | ||||
|   CLUTTER_SEAT_GET_CLASS (seat)->warp_pointer (seat, x, y); | ||||
| } | ||||
							
								
								
									
										178
									
								
								clutter/clutter/clutter-seat.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								clutter/clutter/clutter-seat.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,178 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Copyright (C) 2019 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, see <http://www.gnu.org/licenses/>. | ||||
|  * | ||||
|  * Author: Carlos Garnacho <carlosg@gnome.org> | ||||
|  */ | ||||
| #ifndef CLUTTER_SEAT_H | ||||
| #define CLUTTER_SEAT_H | ||||
|  | ||||
| #if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION) | ||||
| #error "Only <clutter/clutter.h> can be included directly." | ||||
| #endif | ||||
|  | ||||
| #include "clutter/clutter-types.h" | ||||
| #include "clutter/clutter-keymap.h" | ||||
| #include "clutter/clutter-virtual-input-device.h" | ||||
|  | ||||
| #define CLUTTER_TYPE_SEAT (clutter_seat_get_type ()) | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| G_DECLARE_DERIVABLE_TYPE (ClutterSeat, clutter_seat, | ||||
| 			  CLUTTER, SEAT, GObject) | ||||
|  | ||||
| /** | ||||
|  * ClutterKbdA11ySettings: | ||||
|  * | ||||
|  * The #ClutterKbdA11ySettings structure contains keyboard accessibility | ||||
|  * settings | ||||
|  * | ||||
|  */ | ||||
| typedef struct _ClutterKbdA11ySettings | ||||
| { | ||||
|   ClutterKeyboardA11yFlags controls; | ||||
|   gint slowkeys_delay; | ||||
|   gint debounce_delay; | ||||
|   gint timeout_delay; | ||||
|   gint mousekeys_init_delay; | ||||
|   gint mousekeys_max_speed; | ||||
|   gint mousekeys_accel_time; | ||||
| } ClutterKbdA11ySettings; | ||||
|  | ||||
| /** | ||||
|  * ClutterPointerA11ySettings: | ||||
|  * | ||||
|  * The #ClutterPointerA11ySettings structure contains pointer accessibility | ||||
|  * settings | ||||
|  * | ||||
|  */ | ||||
| typedef struct _ClutterPointerA11ySettings | ||||
| { | ||||
|   ClutterPointerA11yFlags controls; | ||||
|   ClutterPointerA11yDwellClickType dwell_click_type; | ||||
|   ClutterPointerA11yDwellMode dwell_mode; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_single; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_double; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_drag; | ||||
|   ClutterPointerA11yDwellDirection dwell_gesture_secondary; | ||||
|   gint secondary_click_delay; | ||||
|   gint dwell_delay; | ||||
|   gint dwell_threshold; | ||||
| } ClutterPointerA11ySettings; | ||||
|  | ||||
| /** | ||||
|  * ClutterVirtualDeviceType: | ||||
|  */ | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_NONE = 0, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_KEYBOARD = 1 << 0, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_POINTER = 1 << 1, | ||||
|   CLUTTER_VIRTUAL_DEVICE_TYPE_TOUCHSCREEN = 1 << 2, | ||||
| } ClutterVirtualDeviceType; | ||||
|  | ||||
| typedef struct _ClutterSeatClass ClutterSeatClass; | ||||
|  | ||||
| struct _ClutterSeatClass | ||||
| { | ||||
|   GObjectClass parent_class; | ||||
|  | ||||
|   ClutterInputDevice * (* get_pointer)  (ClutterSeat *seat); | ||||
|   ClutterInputDevice * (* get_keyboard) (ClutterSeat *seat); | ||||
|  | ||||
|   GList * (* list_devices) (ClutterSeat *seat); | ||||
|  | ||||
|   void (* bell_notify) (ClutterSeat *seat); | ||||
|  | ||||
|   ClutterKeymap * (* get_keymap) (ClutterSeat *seat); | ||||
|  | ||||
|   void (* compress_motion) (ClutterSeat        *seat, | ||||
|                             ClutterEvent       *event, | ||||
|                             const ClutterEvent *to_discard); | ||||
|  | ||||
|   void (* warp_pointer) (ClutterSeat *seat, | ||||
|                          int          x, | ||||
|                          int          y); | ||||
|  | ||||
|   /* Event platform data */ | ||||
|   void (* copy_event_data) (ClutterSeat        *seat, | ||||
|                             const ClutterEvent *src, | ||||
|                             ClutterEvent       *dest); | ||||
|   void (* free_event_data) (ClutterSeat        *seat, | ||||
|                             ClutterEvent       *event); | ||||
|  | ||||
|   /* Keyboard accessibility */ | ||||
|   void (* apply_kbd_a11y_settings) (ClutterSeat            *seat, | ||||
|                                     ClutterKbdA11ySettings *settings); | ||||
|  | ||||
|   /* Virtual devices */ | ||||
|   ClutterVirtualInputDevice * (* create_virtual_device) (ClutterSeat            *seat, | ||||
|                                                          ClutterInputDeviceType  device_type); | ||||
|   ClutterVirtualDeviceType (* get_supported_virtual_device_types) (ClutterSeat *seat); | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDevice * clutter_seat_get_pointer  (ClutterSeat *seat); | ||||
| CLUTTER_EXPORT | ||||
| ClutterInputDevice * clutter_seat_get_keyboard (ClutterSeat *seat); | ||||
| CLUTTER_EXPORT | ||||
| GList * clutter_seat_list_devices (ClutterSeat *seat); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_bell_notify (ClutterSeat *seat); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterKeymap * clutter_seat_get_keymap (ClutterSeat *seat); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_set_kbd_a11y_settings (ClutterSeat            *seat, | ||||
|                                          ClutterKbdA11ySettings *settings); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_get_kbd_a11y_settings (ClutterSeat            *seat, | ||||
|                                          ClutterKbdA11ySettings *settings); | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_ensure_a11y_state     (ClutterSeat            *seat); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_set_pointer_a11y_settings (ClutterSeat                *seat, | ||||
|                                              ClutterPointerA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_get_pointer_a11y_settings (ClutterSeat                *seat, | ||||
|                                              ClutterPointerA11ySettings *settings); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_set_pointer_a11y_dwell_click_type (ClutterSeat                      *seat, | ||||
|                                                      ClutterPointerA11yDwellClickType  click_type); | ||||
| CLUTTER_EXPORT | ||||
| ClutterVirtualInputDevice *clutter_seat_create_virtual_device (ClutterSeat            *seat, | ||||
|                                                                ClutterInputDeviceType  device_type); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterVirtualDeviceType clutter_seat_get_supported_virtual_device_types (ClutterSeat *seat); | ||||
|  | ||||
| void clutter_seat_compress_motion (ClutterSeat        *seat, | ||||
|                                    ClutterEvent       *event, | ||||
|                                    const ClutterEvent *to_discard); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void clutter_seat_warp_pointer (ClutterSeat *seat, | ||||
|                                 int          x, | ||||
|                                 int          y); | ||||
|  | ||||
| #endif /* CLUTTER_SEAT_H */ | ||||
| @@ -177,18 +177,18 @@ clutter_shader_effect_clear (ClutterShaderEffect *self, | ||||
| { | ||||
|   ClutterShaderEffectPrivate *priv = self->priv; | ||||
|  | ||||
|   if (priv->shader != COGL_INVALID_HANDLE) | ||||
|   if (priv->shader != NULL) | ||||
|     { | ||||
|       cogl_handle_unref (priv->shader); | ||||
|       cogl_object_unref (priv->shader); | ||||
|  | ||||
|       priv->shader = COGL_INVALID_HANDLE; | ||||
|       priv->shader = NULL; | ||||
|     } | ||||
|  | ||||
|   if (priv->program != COGL_INVALID_HANDLE) | ||||
|   if (priv->program != NULL) | ||||
|     { | ||||
|       cogl_handle_unref (priv->program); | ||||
|       cogl_object_unref (priv->program); | ||||
|  | ||||
|       priv->program = COGL_INVALID_HANDLE; | ||||
|       priv->program = NULL; | ||||
|     } | ||||
|  | ||||
|   if (reset_uniforms && priv->uniforms != NULL) | ||||
| @@ -208,7 +208,7 @@ clutter_shader_effect_update_uniforms (ClutterShaderEffect *effect) | ||||
|   gpointer key, value; | ||||
|   gsize size; | ||||
|  | ||||
|   if (priv->program == COGL_INVALID_HANDLE) | ||||
|   if (priv->program == NULL) | ||||
|     return; | ||||
|  | ||||
|   if (priv->uniforms == NULL) | ||||
| @@ -333,7 +333,7 @@ clutter_shader_effect_create_shader (ClutterShaderEffect *self) | ||||
|  | ||||
|     default: | ||||
|       g_assert_not_reached (); | ||||
|       return COGL_INVALID_HANDLE; | ||||
|       return NULL; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -353,7 +353,7 @@ clutter_shader_effect_try_static_source (ClutterShaderEffect *self) | ||||
|                                   CLUTTER_TYPE_SHADER_EFFECT, | ||||
|                                   ClutterShaderEffectClassPrivate); | ||||
|  | ||||
|       if (class_priv->shader == COGL_INVALID_HANDLE) | ||||
|       if (class_priv->shader == NULL) | ||||
|         { | ||||
|           gchar *source; | ||||
|  | ||||
| @@ -387,10 +387,10 @@ clutter_shader_effect_try_static_source (ClutterShaderEffect *self) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|       priv->shader = cogl_handle_ref (class_priv->shader); | ||||
|       priv->shader = cogl_object_ref (class_priv->shader); | ||||
|  | ||||
|       if (class_priv->program != COGL_INVALID_HANDLE) | ||||
|         priv->program = cogl_handle_ref (class_priv->program); | ||||
|       if (class_priv->program != NULL) | ||||
|         priv->program = cogl_object_ref (class_priv->program); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -404,13 +404,13 @@ clutter_shader_effect_paint_target (ClutterOffscreenEffect *effect) | ||||
|  | ||||
|   /* If the source hasn't been set then we'll try to get it from the | ||||
|      static source instead */ | ||||
|   if (priv->shader == COGL_INVALID_HANDLE) | ||||
|   if (priv->shader == NULL) | ||||
|     clutter_shader_effect_try_static_source (self); | ||||
|  | ||||
|   /* we haven't been prepared or we don't have support for | ||||
|    * GLSL shaders in Clutter | ||||
|    */ | ||||
|   if (priv->program == COGL_INVALID_HANDLE) | ||||
|   if (priv->program == NULL) | ||||
|     goto out; | ||||
|  | ||||
|   CLUTTER_NOTE (SHADER, "Applying the shader effect of type '%s'", | ||||
| @@ -534,7 +534,7 @@ clutter_shader_effect_new (ClutterShaderType shader_type) | ||||
|  * Retrieves a pointer to the shader's handle | ||||
|  * | ||||
|  * Return value: (transfer none): a pointer to the shader's handle, | ||||
|  *   or %COGL_INVALID_HANDLE | ||||
|  *   or %NULL | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| @@ -542,7 +542,7 @@ CoglHandle | ||||
| clutter_shader_effect_get_shader (ClutterShaderEffect *effect) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SHADER_EFFECT (effect), | ||||
|                         COGL_INVALID_HANDLE); | ||||
|                         NULL); | ||||
|  | ||||
|   return effect->priv->shader; | ||||
| } | ||||
| @@ -554,7 +554,7 @@ clutter_shader_effect_get_shader (ClutterShaderEffect *effect) | ||||
|  * Retrieves a pointer to the program's handle | ||||
|  * | ||||
|  * Return value: (transfer none): a pointer to the program's handle, | ||||
|  *   or %COGL_INVALID_HANDLE | ||||
|  *   or %NULL | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| @@ -562,7 +562,7 @@ CoglHandle | ||||
| clutter_shader_effect_get_program (ClutterShaderEffect *effect) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_SHADER_EFFECT (effect), | ||||
|                         COGL_INVALID_HANDLE); | ||||
|                         NULL); | ||||
|  | ||||
|   return effect->priv->program; | ||||
| } | ||||
| @@ -892,7 +892,7 @@ clutter_shader_effect_set_shader_source (ClutterShaderEffect *effect, | ||||
|  | ||||
|   priv = effect->priv; | ||||
|  | ||||
|   if (priv->shader != COGL_INVALID_HANDLE) | ||||
|   if (priv->shader != NULL) | ||||
|     return TRUE; | ||||
|  | ||||
|   priv->shader = clutter_shader_effect_create_shader (effect); | ||||
|   | ||||
| @@ -44,8 +44,6 @@ | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-private.h" | ||||
|  | ||||
| #include "deprecated/clutter-stage-manager.h" | ||||
|  | ||||
| enum | ||||
| { | ||||
|   PROP_0, | ||||
| @@ -183,23 +181,6 @@ clutter_stage_manager_get_default (void) | ||||
|   return context->stage_manager; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_manager_set_default_stage: | ||||
|  * @stage_manager: a #ClutterStageManager | ||||
|  * @stage: a #ClutterStage | ||||
|  * | ||||
|  * Sets @stage as the default stage. | ||||
|  * | ||||
|  * Since: 0.8 | ||||
|  * | ||||
|  * Deprecated: 1.2: Calling this function has no effect | ||||
|  */ | ||||
| void | ||||
| clutter_stage_manager_set_default_stage (ClutterStageManager *stage_manager, | ||||
|                                          ClutterStage        *stage) | ||||
| { | ||||
| } | ||||
|  | ||||
| /*< private > | ||||
|  * _clutter_stage_manager_set_default_stage: | ||||
|  * @stage_manager: a #ClutterStageManager | ||||
|   | ||||
| @@ -79,18 +79,18 @@ gint64    _clutter_stage_get_update_time                  (ClutterStage *stage); | ||||
| void     _clutter_stage_clear_update_time                 (ClutterStage *stage); | ||||
| gboolean _clutter_stage_has_full_redraw_queued            (ClutterStage *stage); | ||||
|  | ||||
| void clutter_stage_log_pick (ClutterStage       *stage, | ||||
|                              const ClutterPoint *vertices, | ||||
|                              ClutterActor       *actor); | ||||
| void clutter_stage_log_pick (ClutterStage           *stage, | ||||
|                              const graphene_point_t *vertices, | ||||
|                              ClutterActor           *actor); | ||||
|  | ||||
| void clutter_stage_push_pick_clip (ClutterStage       *stage, | ||||
|                                    const ClutterPoint *vertices); | ||||
| void clutter_stage_push_pick_clip (ClutterStage           *stage, | ||||
|                                    const graphene_point_t *vertices); | ||||
|  | ||||
| void clutter_stage_pop_pick_clip (ClutterStage *stage); | ||||
|  | ||||
| ClutterActor *_clutter_stage_do_pick (ClutterStage    *stage, | ||||
|                                       gint             x, | ||||
|                                       gint             y, | ||||
|                                       float            x, | ||||
|                                       float            y, | ||||
|                                       ClutterPickMode  mode); | ||||
|  | ||||
| ClutterPaintVolume *_clutter_stage_paint_volume_stack_allocate (ClutterStage *stage); | ||||
| @@ -133,9 +133,9 @@ gboolean                _clutter_stage_update_state     (ClutterStage      *stag | ||||
|  | ||||
| void                    _clutter_stage_set_scale_factor (ClutterStage      *stage, | ||||
|                                                          int                factor); | ||||
| gboolean                _clutter_stage_get_max_view_scale_factor_for_rect (ClutterStage *stage, | ||||
|                                                                            ClutterRect  *rect, | ||||
|                                                                            float        *view_scale); | ||||
| gboolean                _clutter_stage_get_max_view_scale_factor_for_rect (ClutterStage    *stage, | ||||
|                                                                            graphene_rect_t *rect, | ||||
|                                                                            float           *view_scale); | ||||
|  | ||||
| void            _clutter_stage_presented                (ClutterStage      *stage, | ||||
|                                                          CoglFrameEvent     frame_event, | ||||
|   | ||||
| @@ -20,8 +20,8 @@ | ||||
|  | ||||
| #include "clutter/clutter-stage-view.h" | ||||
|  | ||||
| void clutter_stage_view_blit_offscreen (ClutterStageView            *view, | ||||
|                                         const cairo_rectangle_int_t *clip); | ||||
| void clutter_stage_view_after_paint (ClutterStageView            *view, | ||||
|                                      const cairo_rectangle_int_t *clip); | ||||
|  | ||||
| gboolean clutter_stage_view_is_dirty_viewport (ClutterStageView *view); | ||||
|  | ||||
|   | ||||
| @@ -30,6 +30,7 @@ enum | ||||
|   PROP_LAYOUT, | ||||
|   PROP_FRAMEBUFFER, | ||||
|   PROP_OFFSCREEN, | ||||
|   PROP_SHADOWFB, | ||||
|   PROP_SCALE, | ||||
|  | ||||
|   PROP_LAST | ||||
| @@ -44,7 +45,10 @@ typedef struct _ClutterStageViewPrivate | ||||
|   CoglFramebuffer *framebuffer; | ||||
|  | ||||
|   CoglOffscreen *offscreen; | ||||
|   CoglPipeline *pipeline; | ||||
|   CoglPipeline *offscreen_pipeline; | ||||
|  | ||||
|   CoglOffscreen *shadowfb; | ||||
|   CoglPipeline *shadowfb_pipeline; | ||||
|  | ||||
|   guint dirty_viewport   : 1; | ||||
|   guint dirty_projection : 1; | ||||
| @@ -78,6 +82,8 @@ clutter_stage_view_get_framebuffer (ClutterStageView *view) | ||||
|  | ||||
|   if (priv->offscreen) | ||||
|     return priv->offscreen; | ||||
|   else if (priv->shadowfb) | ||||
|     return priv->shadowfb; | ||||
|   else | ||||
|     return priv->framebuffer; | ||||
| } | ||||
| @@ -99,6 +105,24 @@ clutter_stage_view_get_onscreen (ClutterStageView *view) | ||||
|   return priv->framebuffer; | ||||
| } | ||||
|  | ||||
| static CoglPipeline * | ||||
| clutter_stage_view_create_framebuffer_pipeline (CoglFramebuffer *framebuffer) | ||||
| { | ||||
|   CoglPipeline *pipeline; | ||||
|  | ||||
|   pipeline = cogl_pipeline_new (cogl_framebuffer_get_context (framebuffer)); | ||||
|  | ||||
|   cogl_pipeline_set_layer_filters (pipeline, 0, | ||||
|                                    COGL_PIPELINE_FILTER_NEAREST, | ||||
|                                    COGL_PIPELINE_FILTER_NEAREST); | ||||
|   cogl_pipeline_set_layer_texture (pipeline, 0, | ||||
|                                    cogl_offscreen_get_texture (framebuffer)); | ||||
|   cogl_pipeline_set_layer_wrap_mode (pipeline, 0, | ||||
|                                      COGL_PIPELINE_WRAP_MODE_CLAMP_TO_EDGE); | ||||
|  | ||||
|   return pipeline; | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_view_ensure_offscreen_blit_pipeline (ClutterStageView *view) | ||||
| { | ||||
| @@ -109,21 +133,27 @@ clutter_stage_view_ensure_offscreen_blit_pipeline (ClutterStageView *view) | ||||
|  | ||||
|   g_assert (priv->offscreen != NULL); | ||||
|  | ||||
|   if (priv->pipeline) | ||||
|   if (priv->offscreen_pipeline) | ||||
|     return; | ||||
|  | ||||
|   priv->pipeline = | ||||
|     cogl_pipeline_new (cogl_framebuffer_get_context (priv->offscreen)); | ||||
|   cogl_pipeline_set_layer_filters (priv->pipeline, 0, | ||||
|                                    COGL_PIPELINE_FILTER_NEAREST, | ||||
|                                    COGL_PIPELINE_FILTER_NEAREST); | ||||
|   cogl_pipeline_set_layer_texture (priv->pipeline, 0, | ||||
|                                    cogl_offscreen_get_texture (priv->offscreen)); | ||||
|   cogl_pipeline_set_layer_wrap_mode (priv->pipeline, 0, | ||||
|                                      COGL_PIPELINE_WRAP_MODE_CLAMP_TO_EDGE); | ||||
|   priv->offscreen_pipeline = | ||||
|     clutter_stage_view_create_framebuffer_pipeline (priv->offscreen); | ||||
|  | ||||
|   if (view_class->setup_offscreen_blit_pipeline) | ||||
|     view_class->setup_offscreen_blit_pipeline (view, priv->pipeline); | ||||
|     view_class->setup_offscreen_blit_pipeline (view, priv->offscreen_pipeline); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_view_ensure_shadowfb_blit_pipeline (ClutterStageView *view) | ||||
| { | ||||
|   ClutterStageViewPrivate *priv = | ||||
|     clutter_stage_view_get_instance_private (view); | ||||
|  | ||||
|   if (priv->shadowfb_pipeline) | ||||
|     return; | ||||
|  | ||||
|   priv->shadowfb_pipeline = | ||||
|     clutter_stage_view_create_framebuffer_pipeline (priv->shadowfb); | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -132,48 +162,93 @@ clutter_stage_view_invalidate_offscreen_blit_pipeline (ClutterStageView *view) | ||||
|   ClutterStageViewPrivate *priv = | ||||
|     clutter_stage_view_get_instance_private (view); | ||||
|  | ||||
|   g_clear_pointer (&priv->pipeline, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->offscreen_pipeline, cogl_object_unref); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_stage_view_blit_offscreen (ClutterStageView            *view, | ||||
|                                    const cairo_rectangle_int_t *rect) | ||||
| static void | ||||
| clutter_stage_view_copy_to_framebuffer (ClutterStageView            *view, | ||||
|                                         const cairo_rectangle_int_t *rect, | ||||
|                                         CoglPipeline                *pipeline, | ||||
|                                         CoglFramebuffer             *src_framebuffer, | ||||
|                                         CoglFramebuffer             *dst_framebuffer, | ||||
|                                         gboolean                     can_blit) | ||||
| { | ||||
|   ClutterStageViewPrivate *priv = | ||||
|     clutter_stage_view_get_instance_private (view); | ||||
|   CoglMatrix matrix; | ||||
|  | ||||
|   clutter_stage_view_get_offscreen_transformation_matrix (view, &matrix); | ||||
|   if (cogl_matrix_is_identity (&matrix)) | ||||
|   /* First, try with blit */ | ||||
|   if (can_blit) | ||||
|     { | ||||
|       int fb_width = cogl_framebuffer_get_width (priv->framebuffer); | ||||
|       int fb_height = cogl_framebuffer_get_height (priv->framebuffer); | ||||
|  | ||||
|       if (cogl_blit_framebuffer (priv->offscreen, | ||||
|                                  priv->framebuffer, | ||||
|       if (cogl_blit_framebuffer (src_framebuffer, | ||||
|                                  dst_framebuffer, | ||||
|                                  0, 0, | ||||
|                                  0, 0, | ||||
|                                  fb_width, fb_height, | ||||
|                                  cogl_framebuffer_get_width (dst_framebuffer), | ||||
|                                  cogl_framebuffer_get_height (dst_framebuffer), | ||||
|                                  NULL)) | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|   clutter_stage_view_ensure_offscreen_blit_pipeline (view); | ||||
|   cogl_framebuffer_push_matrix (priv->framebuffer); | ||||
|   /* If blit fails, fallback to the slower painting method */ | ||||
|   cogl_framebuffer_push_matrix (dst_framebuffer); | ||||
|  | ||||
|   /* Set transform so 0,0 is on the top left corner and 1,1 on | ||||
|    * the bottom right corner. | ||||
|    */ | ||||
|   cogl_matrix_init_identity (&matrix); | ||||
|   cogl_matrix_translate (&matrix, -1, 1, 0); | ||||
|   cogl_matrix_scale (&matrix, 2, -2, 0); | ||||
|   cogl_framebuffer_set_projection_matrix (priv->framebuffer, &matrix); | ||||
|   cogl_framebuffer_set_projection_matrix (dst_framebuffer, &matrix); | ||||
|  | ||||
|   cogl_framebuffer_draw_rectangle (priv->framebuffer, | ||||
|                                    priv->pipeline, | ||||
|   cogl_framebuffer_draw_rectangle (dst_framebuffer, | ||||
|                                    pipeline, | ||||
|                                    0, 0, 1, 1); | ||||
|  | ||||
|   cogl_framebuffer_pop_matrix (priv->framebuffer); | ||||
|   cogl_framebuffer_pop_matrix (dst_framebuffer); | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_stage_view_after_paint (ClutterStageView            *view, | ||||
|                                 const cairo_rectangle_int_t *rect) | ||||
| { | ||||
|   ClutterStageViewPrivate *priv = | ||||
|     clutter_stage_view_get_instance_private (view); | ||||
|  | ||||
|   if (priv->offscreen) | ||||
|     { | ||||
|       gboolean can_blit; | ||||
|       CoglMatrix matrix; | ||||
|  | ||||
|       clutter_stage_view_ensure_offscreen_blit_pipeline (view); | ||||
|       clutter_stage_view_get_offscreen_transformation_matrix (view, &matrix); | ||||
|       can_blit = cogl_matrix_is_identity (&matrix); | ||||
|  | ||||
|       if (priv->shadowfb) | ||||
|         { | ||||
|           clutter_stage_view_copy_to_framebuffer (view, | ||||
|                                                   rect, | ||||
|                                                   priv->offscreen_pipeline, | ||||
|                                                   priv->offscreen, | ||||
|                                                   priv->shadowfb, | ||||
|                                                   can_blit); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           clutter_stage_view_copy_to_framebuffer (view, | ||||
|                                                   rect, | ||||
|                                                   priv->offscreen_pipeline, | ||||
|                                                   priv->offscreen, | ||||
|                                                   priv->framebuffer, | ||||
|                                                   can_blit); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   if (priv->shadowfb) | ||||
|     { | ||||
|       clutter_stage_view_ensure_shadowfb_blit_pipeline (view); | ||||
|       clutter_stage_view_copy_to_framebuffer (view, | ||||
|                                               rect, | ||||
|                                               priv->shadowfb_pipeline, | ||||
|                                               priv->shadowfb, | ||||
|                                               priv->framebuffer, | ||||
|                                               TRUE); | ||||
|     } | ||||
| } | ||||
|  | ||||
| float | ||||
| @@ -273,6 +348,9 @@ clutter_stage_view_get_property (GObject    *object, | ||||
|     case PROP_OFFSCREEN: | ||||
|       g_value_set_boxed (value, priv->offscreen); | ||||
|       break; | ||||
|     case PROP_SHADOWFB: | ||||
|       g_value_set_boxed (value, priv->shadowfb); | ||||
|       break; | ||||
|     case PROP_SCALE: | ||||
|       g_value_set_float (value, priv->scale); | ||||
|       break; | ||||
| @@ -318,6 +396,9 @@ clutter_stage_view_set_property (GObject      *object, | ||||
|     case PROP_OFFSCREEN: | ||||
|       priv->offscreen = g_value_dup_boxed (value); | ||||
|       break; | ||||
|     case PROP_SHADOWFB: | ||||
|       priv->shadowfb = g_value_dup_boxed (value); | ||||
|       break; | ||||
|     case PROP_SCALE: | ||||
|       priv->scale = g_value_get_float (value); | ||||
|       break; | ||||
| @@ -334,8 +415,10 @@ clutter_stage_view_dispose (GObject *object) | ||||
|     clutter_stage_view_get_instance_private (view); | ||||
|  | ||||
|   g_clear_pointer (&priv->framebuffer, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->shadowfb, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->offscreen, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->pipeline, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->offscreen_pipeline, cogl_object_unref); | ||||
|   g_clear_pointer (&priv->shadowfb_pipeline, cogl_object_unref); | ||||
|  | ||||
|   G_OBJECT_CLASS (clutter_stage_view_parent_class)->dispose (object); | ||||
| } | ||||
| @@ -390,6 +473,15 @@ clutter_stage_view_class_init (ClutterStageViewClass *klass) | ||||
|                         G_PARAM_CONSTRUCT_ONLY | | ||||
|                         G_PARAM_STATIC_STRINGS); | ||||
|  | ||||
|   obj_props[PROP_SHADOWFB] = | ||||
|     g_param_spec_boxed ("shadowfb", | ||||
|                         "Shadow framebuffer", | ||||
|                         "Framebuffer used as intermediate shadow buffer", | ||||
|                         COGL_TYPE_HANDLE, | ||||
|                         G_PARAM_READWRITE | | ||||
|                         G_PARAM_CONSTRUCT_ONLY | | ||||
|                         G_PARAM_STATIC_STRINGS); | ||||
|  | ||||
|   obj_props[PROP_SCALE] = | ||||
|     g_param_spec_float ("scale", | ||||
|                         "View scale", | ||||
|   | ||||
| @@ -235,19 +235,18 @@ _clutter_stage_window_ignoring_redraw_clips (ClutterStageWindow *window) | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| _clutter_stage_window_get_redraw_clip_bounds (ClutterStageWindow    *window, | ||||
|                                               cairo_rectangle_int_t *stage_clip) | ||||
| cairo_region_t * | ||||
| _clutter_stage_window_get_redraw_clip (ClutterStageWindow *window) | ||||
| { | ||||
|   ClutterStageWindowInterface *iface; | ||||
|  | ||||
|   g_return_val_if_fail (CLUTTER_IS_STAGE_WINDOW (window), FALSE); | ||||
|  | ||||
|   iface = CLUTTER_STAGE_WINDOW_GET_IFACE (window); | ||||
|   if (iface->get_redraw_clip_bounds != NULL) | ||||
|     return iface->get_redraw_clip_bounds (window, stage_clip); | ||||
|   if (iface->get_redraw_clip != NULL) | ||||
|     return iface->get_redraw_clip (window); | ||||
|  | ||||
|   return FALSE; | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| void | ||||
|   | ||||
| @@ -55,9 +55,7 @@ struct _ClutterStageWindowInterface | ||||
|                                                  cairo_rectangle_int_t *stage_rectangle); | ||||
|   gboolean          (* has_redraw_clips)        (ClutterStageWindow    *stage_window); | ||||
|   gboolean          (* ignoring_redraw_clips)   (ClutterStageWindow    *stage_window); | ||||
|   gboolean          (* get_redraw_clip_bounds)  (ClutterStageWindow    *stage_window, | ||||
|                                                  cairo_rectangle_int_t *clip); | ||||
|  | ||||
|   cairo_region_t *  (* get_redraw_clip)         (ClutterStageWindow    *stage_window); | ||||
|  | ||||
|   void              (* set_accept_focus)        (ClutterStageWindow *stage_window, | ||||
|                                                  gboolean            accept_focus); | ||||
| @@ -100,8 +98,7 @@ void              _clutter_stage_window_add_redraw_clip         (ClutterStageWin | ||||
|                                                                  cairo_rectangle_int_t *stage_clip); | ||||
| gboolean          _clutter_stage_window_has_redraw_clips        (ClutterStageWindow    *window); | ||||
| gboolean          _clutter_stage_window_ignoring_redraw_clips   (ClutterStageWindow    *window); | ||||
| gboolean          _clutter_stage_window_get_redraw_clip_bounds  (ClutterStageWindow    *window, | ||||
|                                                                  cairo_rectangle_int_t *clip); | ||||
| cairo_region_t *  _clutter_stage_window_get_redraw_clip         (ClutterStageWindow    *window); | ||||
|  | ||||
| void              _clutter_stage_window_set_accept_focus        (ClutterStageWindow *window, | ||||
|                                                                  gboolean            accept_focus); | ||||
|   | ||||
| @@ -60,10 +60,10 @@ | ||||
| #include "clutter-color.h" | ||||
| #include "clutter-container.h" | ||||
| #include "clutter-debug.h" | ||||
| #include "clutter-device-manager-private.h" | ||||
| #include "clutter-enum-types.h" | ||||
| #include "clutter-event-private.h" | ||||
| #include "clutter-id-pool.h" | ||||
| #include "clutter-input-device-private.h" | ||||
| #include "clutter-main.h" | ||||
| #include "clutter-marshal.h" | ||||
| #include "clutter-master-clock.h" | ||||
| @@ -78,26 +78,6 @@ | ||||
| #include "cogl/cogl.h" | ||||
| #include "cogl/cogl-trace.h" | ||||
|  | ||||
| /* <private> | ||||
|  * ClutterStageHint: | ||||
|  * @CLUTTER_STAGE_NONE: No hint set | ||||
|  * @CLUTTER_STAGE_NO_CLEAR_ON_PAINT: When this hint is set, the stage | ||||
|  *   should not clear the viewport; this flag is useful when painting | ||||
|  *   fully opaque actors covering the whole visible area of the stage, | ||||
|  *   i.e. when no blending with the stage color happens over the whole | ||||
|  *   stage viewport | ||||
|  * | ||||
|  * A series of hints that enable or disable behaviours on the stage | ||||
|  */ | ||||
| typedef enum /*< prefix=CLUTTER_STAGE >*/ | ||||
| { | ||||
|   CLUTTER_STAGE_HINT_NONE = 0, | ||||
|  | ||||
|   CLUTTER_STAGE_NO_CLEAR_ON_PAINT = 1 << 0 | ||||
| } ClutterStageHint; | ||||
|  | ||||
| #define STAGE_NO_CLEAR_ON_PAINT(s)      ((((ClutterStage *) (s))->priv->stage_hints & CLUTTER_STAGE_NO_CLEAR_ON_PAINT) != 0) | ||||
|  | ||||
| struct _ClutterStageQueueRedrawEntry | ||||
| { | ||||
|   ClutterActor *actor; | ||||
| @@ -107,7 +87,7 @@ struct _ClutterStageQueueRedrawEntry | ||||
|  | ||||
| typedef struct _PickRecord | ||||
| { | ||||
|   ClutterPoint vertex[4]; | ||||
|   graphene_point_t vertex[4]; | ||||
|   ClutterActor *actor; | ||||
|   int clip_stack_top; | ||||
| } PickRecord; | ||||
| @@ -115,7 +95,7 @@ typedef struct _PickRecord | ||||
| typedef struct _PickClipRecord | ||||
| { | ||||
|   int prev; | ||||
|   ClutterPoint vertex[4]; | ||||
|   graphene_point_t vertex[4]; | ||||
| } PickClipRecord; | ||||
|  | ||||
| struct _ClutterStagePrivate | ||||
| @@ -129,15 +109,11 @@ struct _ClutterStagePrivate | ||||
|   CoglMatrix view; | ||||
|   float viewport[4]; | ||||
|  | ||||
|   ClutterFog fog; | ||||
|  | ||||
|   gchar *title; | ||||
|   ClutterActor *key_focused_actor; | ||||
|  | ||||
|   GQueue *event_queue; | ||||
|  | ||||
|   ClutterStageHint stage_hints; | ||||
|  | ||||
|   GArray *paint_volume_stack; | ||||
|  | ||||
|   ClutterPlane current_clip_planes[4]; | ||||
| @@ -173,7 +149,6 @@ struct _ClutterStagePrivate | ||||
|   guint relayout_pending       : 1; | ||||
|   guint redraw_pending         : 1; | ||||
|   guint is_cursor_visible      : 1; | ||||
|   guint use_fog                : 1; | ||||
|   guint throttle_motion_events : 1; | ||||
|   guint use_alpha              : 1; | ||||
|   guint min_size_changed       : 1; | ||||
| @@ -191,11 +166,8 @@ enum | ||||
|   PROP_CURSOR_VISIBLE, | ||||
|   PROP_PERSPECTIVE, | ||||
|   PROP_TITLE, | ||||
|   PROP_USE_FOG, | ||||
|   PROP_FOG, | ||||
|   PROP_USE_ALPHA, | ||||
|   PROP_KEY_FOCUS, | ||||
|   PROP_NO_CLEAR_HINT, | ||||
|   PROP_ACCEPT_FOCUS, | ||||
|   PROP_LAST | ||||
| }; | ||||
| @@ -249,20 +221,6 @@ clutter_stage_real_remove (ClutterContainer *container, | ||||
|   clutter_actor_remove_child (CLUTTER_ACTOR (container), child); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_real_foreach (ClutterContainer *container, | ||||
|                             ClutterCallback   callback, | ||||
|                             gpointer          user_data) | ||||
| { | ||||
|   ClutterActorIter iter; | ||||
|   ClutterActor *child; | ||||
|  | ||||
|   clutter_actor_iter_init (&iter, CLUTTER_ACTOR (container)); | ||||
|  | ||||
|   while (clutter_actor_iter_next (&iter, &child)) | ||||
|     callback (child, user_data); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_real_raise (ClutterContainer *container, | ||||
|                           ClutterActor     *child, | ||||
| @@ -293,7 +251,6 @@ clutter_container_iface_init (ClutterContainerIface *iface) | ||||
| { | ||||
|   iface->add = clutter_stage_real_add; | ||||
|   iface->remove = clutter_stage_real_remove; | ||||
|   iface->foreach = clutter_stage_real_foreach; | ||||
|   iface->raise = clutter_stage_real_raise; | ||||
|   iface->lower = clutter_stage_real_lower; | ||||
|   iface->sort_depth_order = clutter_stage_real_sort_depth_order; | ||||
| @@ -396,9 +353,9 @@ _clutter_stage_clear_pick_stack (ClutterStage *stage) | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_stage_log_pick (ClutterStage       *stage, | ||||
|                         const ClutterPoint *vertices, | ||||
|                         ClutterActor       *actor) | ||||
| clutter_stage_log_pick (ClutterStage           *stage, | ||||
|                         const graphene_point_t *vertices, | ||||
|                         ClutterActor           *actor) | ||||
| { | ||||
|   ClutterStagePrivate *priv; | ||||
|   PickRecord rec; | ||||
| @@ -410,7 +367,7 @@ clutter_stage_log_pick (ClutterStage       *stage, | ||||
|  | ||||
|   g_assert (!priv->pick_stack_frozen); | ||||
|  | ||||
|   memcpy (rec.vertex, vertices, 4 * sizeof (ClutterPoint)); | ||||
|   memcpy (rec.vertex, vertices, 4 * sizeof (graphene_point_t)); | ||||
|   rec.actor = actor; | ||||
|   rec.clip_stack_top = priv->pick_clip_stack_top; | ||||
|  | ||||
| @@ -418,8 +375,8 @@ clutter_stage_log_pick (ClutterStage       *stage, | ||||
| } | ||||
|  | ||||
| void | ||||
| clutter_stage_push_pick_clip (ClutterStage       *stage, | ||||
|                               const ClutterPoint *vertices) | ||||
| clutter_stage_push_pick_clip (ClutterStage           *stage, | ||||
|                               const graphene_point_t *vertices) | ||||
| { | ||||
|   ClutterStagePrivate *priv; | ||||
|   PickClipRecord clip; | ||||
| @@ -431,7 +388,7 @@ clutter_stage_push_pick_clip (ClutterStage       *stage, | ||||
|   g_assert (!priv->pick_stack_frozen); | ||||
|  | ||||
|   clip.prev = priv->pick_clip_stack_top; | ||||
|   memcpy (clip.vertex, vertices, 4 * sizeof (ClutterPoint)); | ||||
|   memcpy (clip.vertex, vertices, 4 * sizeof (graphene_point_t)); | ||||
|  | ||||
|   g_array_append_val (priv->pick_clip_stack, clip); | ||||
|   priv->pick_clip_stack_top = priv->pick_clip_stack->len - 1; | ||||
| @@ -464,7 +421,7 @@ clutter_stage_pop_pick_clip (ClutterStage *stage) | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| is_quadrilateral_axis_aligned_rectangle (const ClutterPoint *vertices) | ||||
| is_quadrilateral_axis_aligned_rectangle (const graphene_point_t *vertices) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
| @@ -482,8 +439,8 @@ is_quadrilateral_axis_aligned_rectangle (const ClutterPoint *vertices) | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| is_inside_axis_aligned_rectangle (const ClutterPoint *point, | ||||
|                                   const ClutterPoint *vertices) | ||||
| is_inside_axis_aligned_rectangle (const graphene_point_t *point, | ||||
|                                   const graphene_point_t *vertices) | ||||
| { | ||||
|   float min_x = FLT_MAX; | ||||
|   float max_x = FLT_MIN; | ||||
| @@ -505,24 +462,79 @@ is_inside_axis_aligned_rectangle (const ClutterPoint *point, | ||||
|           point->y < max_y); | ||||
| } | ||||
|  | ||||
| static int | ||||
| clutter_point_compare_line (const graphene_point_t *p, | ||||
|                             const graphene_point_t *a, | ||||
|                             const graphene_point_t *b) | ||||
| { | ||||
|   graphene_vec3_t vec_pa; | ||||
|   graphene_vec3_t vec_pb; | ||||
|   graphene_vec3_t cross; | ||||
|   float cross_z; | ||||
|  | ||||
|   graphene_vec3_init (&vec_pa, p->x - a->x, p->y - a->y, 0.f); | ||||
|   graphene_vec3_init (&vec_pb, p->x - b->x, p->y - b->y, 0.f); | ||||
|   graphene_vec3_cross (&vec_pa, &vec_pb, &cross); | ||||
|   cross_z = graphene_vec3_get_z (&cross); | ||||
|  | ||||
|   if (cross_z > 0.f) | ||||
|     return 1; | ||||
|   else if (cross_z < 0.f) | ||||
|     return -1; | ||||
|   else | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| is_inside_input_region (const ClutterPoint *point, | ||||
|                         const ClutterPoint *vertices) | ||||
| is_inside_unaligned_rectangle (const graphene_point_t *point, | ||||
|                                const graphene_point_t *vertices) | ||||
| { | ||||
|   unsigned int i; | ||||
|   int first_side; | ||||
|  | ||||
|   first_side = 0; | ||||
|  | ||||
|   for (i = 0; i < 4; i++) | ||||
|     { | ||||
|       int side; | ||||
|  | ||||
|       side = clutter_point_compare_line (point, | ||||
|                                          &vertices[i], | ||||
|                                          &vertices[(i + 1) % 4]); | ||||
|  | ||||
|       if (side) | ||||
|         { | ||||
|           if (first_side == 0) | ||||
|             first_side = side; | ||||
|           else if (side != first_side) | ||||
|             return FALSE; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   if (first_side == 0) | ||||
|     return FALSE; | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| is_inside_input_region (const graphene_point_t *point, | ||||
|                         const graphene_point_t *vertices) | ||||
| { | ||||
|  | ||||
|   if (is_quadrilateral_axis_aligned_rectangle (vertices)) | ||||
|     return is_inside_axis_aligned_rectangle (point, vertices); | ||||
|   else | ||||
|     return clutter_point_inside_quadrilateral (point, vertices); | ||||
|     return is_inside_unaligned_rectangle (point, vertices); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| pick_record_contains_pixel (ClutterStage     *stage, | ||||
| pick_record_contains_point (ClutterStage     *stage, | ||||
|                             const PickRecord *rec, | ||||
|                             int               x, | ||||
|                             int               y) | ||||
|                             float             x, | ||||
|                             float             y) | ||||
| { | ||||
|   const ClutterPoint point = CLUTTER_POINT_INIT (x, y); | ||||
|   const graphene_point_t point = GRAPHENE_POINT_INIT (x, y); | ||||
|   ClutterStagePrivate *priv; | ||||
|   int clip_index; | ||||
|  | ||||
| @@ -684,17 +696,6 @@ clutter_stage_allocate (ClutterActor           *self, | ||||
|                                     flags | CLUTTER_DELEGATE_LAYOUT); | ||||
|     } | ||||
|  | ||||
|   /* XXX: Until Cogl becomes fully responsible for backend windows | ||||
|    * Clutter need to manually keep it informed of the current window | ||||
|    * size. We do this after the allocation above so that the stage | ||||
|    * window has a chance to update the window size based on the | ||||
|    * allocation. | ||||
|    */ | ||||
|   _clutter_stage_window_get_geometry (priv->impl, &window_size); | ||||
|  | ||||
|   cogl_onscreen_clutter_backend_set_size (window_size.width, | ||||
|                                           window_size.height); | ||||
|  | ||||
|   /* reset the viewport if the allocation effectively changed */ | ||||
|   clutter_actor_get_allocation_box (self, &alloc); | ||||
|   clutter_actor_box_get_size (&alloc, &new_width, &new_height); | ||||
| @@ -735,8 +736,9 @@ _cogl_util_get_eye_planes_for_screen_poly (float *polygon, | ||||
|   Vector4 *tmp_poly; | ||||
|   ClutterPlane *plane; | ||||
|   int i; | ||||
|   float b[3]; | ||||
|   float c[3]; | ||||
|   Vector4 *poly; | ||||
|   graphene_vec3_t b; | ||||
|   graphene_vec3_t c; | ||||
|   int count; | ||||
|  | ||||
|   tmp_poly = g_alloca (sizeof (Vector4) * n_vertices * 2); | ||||
| @@ -803,23 +805,37 @@ _cogl_util_get_eye_planes_for_screen_poly (float *polygon, | ||||
|   for (i = 0; i < count; i++) | ||||
|     { | ||||
|       plane = &planes[i]; | ||||
|       memcpy (plane->v0, tmp_poly + i, sizeof (float) * 3); | ||||
|       memcpy (b, tmp_poly + n_vertices + i, sizeof (float) * 3); | ||||
|       memcpy (c, tmp_poly + n_vertices + i + 1, sizeof (float) * 3); | ||||
|       cogl_vector3_subtract (b, b, plane->v0); | ||||
|       cogl_vector3_subtract (c, c, plane->v0); | ||||
|       cogl_vector3_cross_product (plane->n, b, c); | ||||
|       cogl_vector3_normalize (plane->n); | ||||
|  | ||||
|       poly = &tmp_poly[i]; | ||||
|       graphene_vec3_init (&plane->v0, poly->x, poly->y, poly->z); | ||||
|  | ||||
|       poly = &tmp_poly[n_vertices + i]; | ||||
|       graphene_vec3_init (&b, poly->x, poly->y, poly->z); | ||||
|  | ||||
|       poly = &tmp_poly[n_vertices + i + 1]; | ||||
|       graphene_vec3_init (&c, poly->x, poly->y, poly->z); | ||||
|  | ||||
|       graphene_vec3_subtract (&b, &plane->v0, &b); | ||||
|       graphene_vec3_subtract (&c, &plane->v0, &c); | ||||
|       graphene_vec3_cross (&b, &c, &plane->n); | ||||
|       graphene_vec3_normalize (&plane->n, &plane->n); | ||||
|     } | ||||
|  | ||||
|   plane = &planes[n_vertices - 1]; | ||||
|   memcpy (plane->v0, tmp_poly + 0, sizeof (float) * 3); | ||||
|   memcpy (b, tmp_poly + (2 * n_vertices - 1), sizeof (float) * 3); | ||||
|   memcpy (c, tmp_poly + n_vertices, sizeof (float) * 3); | ||||
|   cogl_vector3_subtract (b, b, plane->v0); | ||||
|   cogl_vector3_subtract (c, c, plane->v0); | ||||
|   cogl_vector3_cross_product (plane->n, b, c); | ||||
|   cogl_vector3_normalize (plane->n); | ||||
|  | ||||
|   poly = &tmp_poly[0]; | ||||
|   graphene_vec3_init (&plane->v0, poly->x, poly->y, poly->z); | ||||
|  | ||||
|   poly = &tmp_poly[2 * n_vertices - 1]; | ||||
|   graphene_vec3_init (&b, poly->x, poly->y, poly->z); | ||||
|  | ||||
|   poly = &tmp_poly[n_vertices]; | ||||
|   graphene_vec3_init (&c, poly->x, poly->y, poly->z); | ||||
|  | ||||
|   graphene_vec3_subtract (&b, &plane->v0, &b); | ||||
|   graphene_vec3_subtract (&c, &plane->v0, &c); | ||||
|   graphene_vec3_cross (&b, &c, &plane->n); | ||||
|   graphene_vec3_normalize (&plane->n, &plane->n); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -842,9 +858,9 @@ _clutter_stage_update_active_framebuffer (ClutterStage    *stage, | ||||
|  * be able to cull them. | ||||
|  */ | ||||
| static void | ||||
| clutter_stage_do_paint_view (ClutterStage                *stage, | ||||
|                              ClutterStageView            *view, | ||||
|                              const cairo_rectangle_int_t *clip) | ||||
| setup_view_for_pick_or_paint (ClutterStage                *stage, | ||||
|                               ClutterStageView            *view, | ||||
|                               const cairo_rectangle_int_t *clip) | ||||
| { | ||||
|   ClutterStagePrivate *priv = stage->priv; | ||||
|   CoglFramebuffer *framebuffer = clutter_stage_view_get_framebuffer (view); | ||||
| @@ -899,6 +915,14 @@ clutter_stage_do_paint_view (ClutterStage                *stage, | ||||
|  | ||||
|   _clutter_stage_paint_volume_stack_free_all (stage); | ||||
|   _clutter_stage_update_active_framebuffer (stage, framebuffer); | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_do_paint_view (ClutterStage                *stage, | ||||
|                              ClutterStageView            *view, | ||||
|                              const cairo_rectangle_int_t *clip) | ||||
| { | ||||
|   setup_view_for_pick_or_paint (stage, view, clip); | ||||
|   clutter_actor_paint (CLUTTER_ACTOR (stage)); | ||||
| } | ||||
|  | ||||
| @@ -950,8 +974,7 @@ clutter_stage_paint (ClutterActor *self) | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_stage_pick (ClutterActor       *self, | ||||
| 		    const ClutterColor *color) | ||||
| clutter_stage_pick (ClutterActor *self) | ||||
| { | ||||
|   ClutterActorIter iter; | ||||
|   ClutterActor *child; | ||||
| @@ -962,7 +985,7 @@ clutter_stage_pick (ClutterActor       *self, | ||||
|    */ | ||||
|   clutter_actor_iter_init (&iter, self); | ||||
|   while (clutter_actor_iter_next (&iter, &child)) | ||||
|     clutter_actor_paint (child); | ||||
|     clutter_actor_pick (child); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| @@ -1066,10 +1089,7 @@ clutter_stage_emit_key_focus_event (ClutterStage *stage, | ||||
|   if (priv->key_focused_actor == NULL) | ||||
|     return; | ||||
|  | ||||
|   if (focus_in) | ||||
|     g_signal_emit_by_name (priv->key_focused_actor, "key-focus-in"); | ||||
|   else | ||||
|     g_signal_emit_by_name (priv->key_focused_actor, "key-focus-out"); | ||||
|   _clutter_actor_set_has_key_focus (CLUTTER_ACTOR (stage), focus_in); | ||||
|  | ||||
|   g_object_notify_by_pspec (G_OBJECT (stage), obj_props[PROP_KEY_FOCUS]); | ||||
| } | ||||
| @@ -1228,11 +1248,9 @@ _clutter_stage_process_queued_events (ClutterStage *stage) | ||||
|  | ||||
|               if (next_event->type == CLUTTER_MOTION) | ||||
|                 { | ||||
|                   ClutterDeviceManager *device_manager = | ||||
|                     clutter_device_manager_get_default (); | ||||
|                   ClutterSeat *seat = clutter_input_device_get_seat (device); | ||||
|  | ||||
|                   _clutter_device_manager_compress_motion (device_manager, | ||||
|                                                            next_event, event); | ||||
|                   clutter_seat_compress_motion (seat, next_event, event); | ||||
|                 } | ||||
|  | ||||
|               goto next_event; | ||||
| @@ -1371,21 +1389,22 @@ static GSList * | ||||
| _clutter_stage_check_updated_pointers (ClutterStage *stage) | ||||
| { | ||||
|   ClutterStagePrivate *priv = stage->priv; | ||||
|   ClutterDeviceManager *device_manager; | ||||
|   ClutterBackend *backend; | ||||
|   ClutterSeat *seat; | ||||
|   GSList *updating = NULL; | ||||
|   const GSList *devices; | ||||
|   cairo_rectangle_int_t clip; | ||||
|   ClutterPoint point; | ||||
|   gboolean has_clip; | ||||
|   GList *l, *devices; | ||||
|   cairo_region_t *clip; | ||||
|   graphene_point_t point; | ||||
|  | ||||
|   has_clip = _clutter_stage_window_get_redraw_clip_bounds (priv->impl, &clip); | ||||
|   clip = _clutter_stage_window_get_redraw_clip (priv->impl); | ||||
|  | ||||
|   device_manager = clutter_device_manager_get_default (); | ||||
|   devices = clutter_device_manager_peek_devices (device_manager); | ||||
|   backend = clutter_get_default_backend (); | ||||
|   seat = clutter_backend_get_default_seat (backend); | ||||
|   devices = clutter_seat_list_devices (seat); | ||||
|  | ||||
|   for (; devices != NULL; devices = devices->next) | ||||
|   for (l = devices; l; l = l->next) | ||||
|     { | ||||
|       ClutterInputDevice *dev = devices->data; | ||||
|       ClutterInputDevice *dev = l->data; | ||||
|  | ||||
|       if (clutter_input_device_get_device_mode (dev) != | ||||
|           CLUTTER_INPUT_MODE_MASTER) | ||||
| @@ -1401,9 +1420,7 @@ _clutter_stage_check_updated_pointers (ClutterStage *stage) | ||||
|           if (!clutter_input_device_get_coords (dev, NULL, &point)) | ||||
|             continue; | ||||
|  | ||||
|           if (!has_clip || | ||||
|               (point.x >= clip.x && point.x < clip.x + clip.width && | ||||
|                point.y >= clip.y && point.y < clip.y + clip.height)) | ||||
|           if (!clip || cairo_region_contains_point (clip, point.x, point.y)) | ||||
|             updating = g_slist_prepend (updating, dev); | ||||
|           break; | ||||
|         default: | ||||
| @@ -1416,6 +1433,8 @@ _clutter_stage_check_updated_pointers (ClutterStage *stage) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   g_list_free (devices); | ||||
|  | ||||
|   return updating; | ||||
| } | ||||
|  | ||||
| @@ -1592,45 +1611,30 @@ _clutter_stage_has_full_redraw_queued (ClutterStage *stage) | ||||
|     return FALSE; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_get_redraw_clip_bounds: | ||||
|  * @stage: A #ClutterStage | ||||
|  * @clip: (out caller-allocates): Return location for the clip bounds | ||||
|  * | ||||
|  * Gets the bounds of the current redraw for @stage in stage pixel | ||||
|  * coordinates. E.g., if only a single actor has queued a redraw then | ||||
|  * Clutter may redraw the stage with a clip so that it doesn't have to | ||||
|  * paint every pixel in the stage. This function would then return the | ||||
|  * bounds of that clip. An application can use this information to | ||||
|  * avoid some extra work if it knows that some regions of the stage | ||||
|  * aren't going to be painted. This should only be called while the | ||||
|  * stage is being painted. If there is no current redraw clip then | ||||
|  * this function will set @clip to the full extents of the stage. | ||||
|  * | ||||
|  * Since: 1.8 | ||||
|  */ | ||||
| void | ||||
| clutter_stage_get_redraw_clip_bounds (ClutterStage          *stage, | ||||
|                                       cairo_rectangle_int_t *clip) | ||||
| cairo_region_t * | ||||
| clutter_stage_get_redraw_clip (ClutterStage *stage) | ||||
| { | ||||
|   ClutterStagePrivate *priv; | ||||
|   cairo_rectangle_int_t clip; | ||||
|   cairo_region_t *region; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_STAGE (stage)); | ||||
|   g_return_if_fail (clip != NULL); | ||||
|   g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL); | ||||
|  | ||||
|   priv = stage->priv; | ||||
|  | ||||
|   if (!_clutter_stage_window_get_redraw_clip_bounds (priv->impl, clip)) | ||||
|     { | ||||
|       /* Set clip to the full extents of the stage */ | ||||
|       _clutter_stage_window_get_geometry (priv->impl, clip); | ||||
|     } | ||||
|   region = _clutter_stage_window_get_redraw_clip (priv->impl); | ||||
|   if (region) | ||||
|     return region; | ||||
|  | ||||
|   /* Set clip to the full extents of the stage */ | ||||
|   _clutter_stage_window_get_geometry (priv->impl, &clip); | ||||
|   return cairo_region_create_rectangle (&clip); | ||||
| } | ||||
|  | ||||
| static ClutterActor * | ||||
| _clutter_stage_do_pick_on_view (ClutterStage     *stage, | ||||
|                                 gint              x, | ||||
|                                 gint              y, | ||||
|                                 float             x, | ||||
|                                 float             y, | ||||
|                                 ClutterPickMode   mode, | ||||
|                                 ClutterStageView *view) | ||||
| { | ||||
| @@ -1648,7 +1652,8 @@ _clutter_stage_do_pick_on_view (ClutterStage     *stage, | ||||
|       cogl_push_framebuffer (fb); | ||||
|  | ||||
|       context->pick_mode = mode; | ||||
|       clutter_stage_do_paint_view (stage, view, NULL); | ||||
|       setup_view_for_pick_or_paint (stage, view, NULL); | ||||
|       clutter_actor_pick (CLUTTER_ACTOR (stage)); | ||||
|       context->pick_mode = CLUTTER_PICK_NONE; | ||||
|       priv->cached_pick_mode = mode; | ||||
|  | ||||
| @@ -1665,7 +1670,7 @@ _clutter_stage_do_pick_on_view (ClutterStage     *stage, | ||||
|     { | ||||
|       const PickRecord *rec = &g_array_index (priv->pick_stack, PickRecord, i); | ||||
|  | ||||
|       if (rec->actor && pick_record_contains_pixel (stage, rec, x, y)) | ||||
|       if (rec->actor && pick_record_contains_point (stage, rec, x, y)) | ||||
|         return rec->actor; | ||||
|     } | ||||
|  | ||||
| @@ -1701,8 +1706,8 @@ clutter_stage_get_view_at (ClutterStage *stage, | ||||
|  | ||||
| ClutterActor * | ||||
| _clutter_stage_do_pick (ClutterStage   *stage, | ||||
|                         gint            x, | ||||
|                         gint            y, | ||||
|                         float           x, | ||||
|                         float           y, | ||||
|                         ClutterPickMode mode) | ||||
| { | ||||
|   ClutterActor *actor = CLUTTER_ACTOR (stage); | ||||
| @@ -1819,14 +1824,6 @@ clutter_stage_set_property (GObject      *object, | ||||
|       clutter_stage_set_title (stage, g_value_get_string (value)); | ||||
|       break; | ||||
|  | ||||
|     case PROP_USE_FOG: | ||||
|       clutter_stage_set_use_fog (stage, g_value_get_boolean (value)); | ||||
|       break; | ||||
|  | ||||
|     case PROP_FOG: | ||||
|       clutter_stage_set_fog (stage, g_value_get_boxed (value)); | ||||
|       break; | ||||
|  | ||||
|     case PROP_USE_ALPHA: | ||||
|       clutter_stage_set_use_alpha (stage, g_value_get_boolean (value)); | ||||
|       break; | ||||
| @@ -1835,10 +1832,6 @@ clutter_stage_set_property (GObject      *object, | ||||
|       clutter_stage_set_key_focus (stage, g_value_get_object (value)); | ||||
|       break; | ||||
|  | ||||
|     case PROP_NO_CLEAR_HINT: | ||||
|       clutter_stage_set_no_clear_hint (stage, g_value_get_boolean (value)); | ||||
|       break; | ||||
|  | ||||
|     case PROP_ACCEPT_FOCUS: | ||||
|       clutter_stage_set_accept_focus (stage, g_value_get_boolean (value)); | ||||
|       break; | ||||
| @@ -1881,14 +1874,6 @@ clutter_stage_get_property (GObject    *gobject, | ||||
|       g_value_set_string (value, priv->title); | ||||
|       break; | ||||
|  | ||||
|     case PROP_USE_FOG: | ||||
|       g_value_set_boolean (value, priv->use_fog); | ||||
|       break; | ||||
|  | ||||
|     case PROP_FOG: | ||||
|       g_value_set_boxed (value, &priv->fog); | ||||
|       break; | ||||
|  | ||||
|     case PROP_USE_ALPHA: | ||||
|       g_value_set_boolean (value, priv->use_alpha); | ||||
|       break; | ||||
| @@ -1897,15 +1882,6 @@ clutter_stage_get_property (GObject    *gobject, | ||||
|       g_value_set_object (value, priv->key_focused_actor); | ||||
|       break; | ||||
|  | ||||
|     case PROP_NO_CLEAR_HINT: | ||||
|       { | ||||
|         gboolean hint = | ||||
|           (priv->stage_hints & CLUTTER_STAGE_NO_CLEAR_ON_PAINT) != 0; | ||||
|  | ||||
|         g_value_set_boolean (value, hint); | ||||
|       } | ||||
|       break; | ||||
|  | ||||
|     case PROP_ACCEPT_FOCUS: | ||||
|       g_value_set_boolean (value, priv->accept_focus); | ||||
|       break; | ||||
| @@ -2074,41 +2050,6 @@ clutter_stage_class_init (ClutterStageClass *klass) | ||||
|                            NULL, | ||||
|                            CLUTTER_PARAM_READWRITE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterStage:use-fog: | ||||
|    * | ||||
|    * Whether the stage should use a linear GL "fog" in creating the | ||||
|    * depth-cueing effect, to enhance the perception of depth by fading | ||||
|    * actors farther from the viewpoint. | ||||
|    * | ||||
|    * Since: 0.6 | ||||
|    * | ||||
|    * Deprecated: 1.10: This property does not do anything. | ||||
|    */ | ||||
|   obj_props[PROP_USE_FOG] = | ||||
|       g_param_spec_boolean ("use-fog", | ||||
|                             P_("Use Fog"), | ||||
|                             P_("Whether to enable depth cueing"), | ||||
|                             FALSE, | ||||
|                             CLUTTER_PARAM_READWRITE | G_PARAM_DEPRECATED); | ||||
|  | ||||
|   /** | ||||
|    * ClutterStage:fog: | ||||
|    * | ||||
|    * The settings for the GL "fog", used only if #ClutterStage:use-fog | ||||
|    * is set to %TRUE | ||||
|    * | ||||
|    * Since: 1.0 | ||||
|    * | ||||
|    * Deprecated: 1.10: This property does not do anything. | ||||
|    */ | ||||
|   obj_props[PROP_FOG] = | ||||
|       g_param_spec_boxed ("fog", | ||||
|                           P_("Fog"), | ||||
|                           P_("Settings for the depth cueing"), | ||||
|                           CLUTTER_TYPE_FOG, | ||||
|                           CLUTTER_PARAM_READWRITE | G_PARAM_DEPRECATED); | ||||
|  | ||||
|   /** | ||||
|    * ClutterStage:use-alpha: | ||||
|    * | ||||
| @@ -2143,23 +2084,6 @@ clutter_stage_class_init (ClutterStageClass *klass) | ||||
|                            CLUTTER_TYPE_ACTOR, | ||||
|                            CLUTTER_PARAM_READWRITE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterStage:no-clear-hint: | ||||
|    * | ||||
|    * Whether or not the #ClutterStage should clear its contents | ||||
|    * before each paint cycle. | ||||
|    * | ||||
|    * See clutter_stage_set_no_clear_hint() for further information. | ||||
|    * | ||||
|    * Since: 1.4 | ||||
|    */ | ||||
|   obj_props[PROP_NO_CLEAR_HINT] = | ||||
|       g_param_spec_boolean ("no-clear-hint", | ||||
|                             P_("No Clear Hint"), | ||||
|                             P_("Whether the stage should clear its contents"), | ||||
|                             FALSE, | ||||
|                             CLUTTER_PARAM_READWRITE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterStage:accept-focus: | ||||
|    * | ||||
| @@ -2346,7 +2270,6 @@ clutter_stage_init (ClutterStage *self) | ||||
|   priv->event_queue = g_queue_new (); | ||||
|  | ||||
|   priv->is_cursor_visible = TRUE; | ||||
|   priv->use_fog = FALSE; | ||||
|   priv->throttle_motion_events = TRUE; | ||||
|   priv->min_size_changed = FALSE; | ||||
|   priv->sync_delay = -1; | ||||
| @@ -2355,10 +2278,6 @@ clutter_stage_init (ClutterStage *self) | ||||
|   clutter_actor_set_background_color (CLUTTER_ACTOR (self), | ||||
|                                       &default_stage_color); | ||||
|  | ||||
|   /* FIXME - remove for 2.0 */ | ||||
|   priv->fog.z_near = 1.0; | ||||
|   priv->fog.z_far  = 2.0; | ||||
|  | ||||
|   priv->relayout_pending = TRUE; | ||||
|  | ||||
|   clutter_actor_set_reactive (CLUTTER_ACTOR (self), TRUE); | ||||
| @@ -2902,8 +2821,8 @@ clutter_stage_read_pixels (ClutterStage *stage, | ||||
| ClutterActor * | ||||
| clutter_stage_get_actor_at_pos (ClutterStage    *stage, | ||||
|                                 ClutterPickMode  pick_mode, | ||||
|                                 gint             x, | ||||
|                                 gint             y) | ||||
|                                 float            x, | ||||
|                                 float            y) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL); | ||||
|  | ||||
| @@ -3011,14 +2930,6 @@ clutter_stage_get_title (ClutterStage       *stage) | ||||
|   return stage->priv->title; | ||||
| } | ||||
|  | ||||
| static void | ||||
| on_key_focus_destroy (ClutterActor *actor, | ||||
|                       ClutterStage *stage) | ||||
| { | ||||
|   /* unset the key focus */ | ||||
|   clutter_stage_set_key_focus (stage, NULL); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_set_key_focus: | ||||
|  * @stage: the #ClutterStage | ||||
| @@ -3058,18 +2969,14 @@ clutter_stage_set_key_focus (ClutterStage *stage, | ||||
|       old_focused_actor = priv->key_focused_actor; | ||||
|  | ||||
|       /* set key_focused_actor to NULL before emitting the signal or someone | ||||
|        * might hide the previously focused actor in the signal handler and we'd | ||||
|        * get re-entrant call and get glib critical from g_object_weak_unref | ||||
|        * might hide the previously focused actor in the signal handler | ||||
|        */ | ||||
|       g_signal_handlers_disconnect_by_func (priv->key_focused_actor, | ||||
|                                             G_CALLBACK (on_key_focus_destroy), | ||||
|                                             stage); | ||||
|       priv->key_focused_actor = NULL; | ||||
|  | ||||
|       g_signal_emit_by_name (old_focused_actor, "key-focus-out"); | ||||
|       _clutter_actor_set_has_key_focus (old_focused_actor, FALSE); | ||||
|     } | ||||
|   else | ||||
|     g_signal_emit_by_name (stage, "key-focus-out"); | ||||
|     _clutter_actor_set_has_key_focus (CLUTTER_ACTOR (stage), FALSE); | ||||
|  | ||||
|   /* Note, if someone changes key focus in focus-out signal handler we'd be | ||||
|    * overriding the latter call below moving the focus where it was originally | ||||
| @@ -3079,14 +2986,10 @@ clutter_stage_set_key_focus (ClutterStage *stage, | ||||
|   if (actor != NULL) | ||||
|     { | ||||
|       priv->key_focused_actor = actor; | ||||
|  | ||||
|       g_signal_connect (actor, | ||||
|                         "destroy", G_CALLBACK (on_key_focus_destroy), | ||||
|                         stage); | ||||
|       g_signal_emit_by_name (priv->key_focused_actor, "key-focus-in"); | ||||
|       _clutter_actor_set_has_key_focus (actor, TRUE); | ||||
|     } | ||||
|   else | ||||
|     g_signal_emit_by_name (stage, "key-focus-in"); | ||||
|     _clutter_actor_set_has_key_focus (CLUTTER_ACTOR (stage), TRUE); | ||||
|  | ||||
|   g_object_notify_by_pspec (G_OBJECT (stage), obj_props[PROP_KEY_FOCUS]); | ||||
| } | ||||
| @@ -3112,136 +3015,6 @@ clutter_stage_get_key_focus (ClutterStage *stage) | ||||
|   return CLUTTER_ACTOR (stage); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_get_use_fog: | ||||
|  * @stage: the #ClutterStage | ||||
|  * | ||||
|  * Gets whether the depth cueing effect is enabled on @stage. | ||||
|  * | ||||
|  * Return value: %TRUE if the depth cueing effect is enabled | ||||
|  * | ||||
|  * Since: 0.6 | ||||
|  * | ||||
|  * Deprecated: 1.10: This function will always return %FALSE | ||||
|  */ | ||||
| gboolean | ||||
| clutter_stage_get_use_fog (ClutterStage *stage) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE); | ||||
|  | ||||
|   return stage->priv->use_fog; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_set_use_fog: | ||||
|  * @stage: the #ClutterStage | ||||
|  * @fog: %TRUE for enabling the depth cueing effect | ||||
|  * | ||||
|  * Sets whether the depth cueing effect on the stage should be enabled | ||||
|  * or not. | ||||
|  * | ||||
|  * Depth cueing is a 3D effect that makes actors farther away from the | ||||
|  * viewing point less opaque, by fading them with the stage color. | ||||
|  | ||||
|  * The parameters of the GL fog used can be changed using the | ||||
|  * clutter_stage_set_fog() function. | ||||
|  * | ||||
|  * Since: 0.6 | ||||
|  * | ||||
|  * Deprecated: 1.10: Calling this function produces no visible effect | ||||
|  */ | ||||
| void | ||||
| clutter_stage_set_use_fog (ClutterStage *stage, | ||||
|                            gboolean      fog) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_set_fog: | ||||
|  * @stage: the #ClutterStage | ||||
|  * @fog: a #ClutterFog structure | ||||
|  * | ||||
|  * Sets the fog (also known as "depth cueing") settings for the @stage. | ||||
|  * | ||||
|  * A #ClutterStage will only use a linear fog progression, which | ||||
|  * depends solely on the distance from the viewer. The cogl_set_fog() | ||||
|  * function in COGL exposes more of the underlying implementation, | ||||
|  * and allows changing the for progression function. It can be directly | ||||
|  * used by disabling the #ClutterStage:use-fog property and connecting | ||||
|  * a signal handler to the #ClutterActor::paint signal on the @stage, | ||||
|  * like: | ||||
|  * | ||||
|  * |[ | ||||
|  *   clutter_stage_set_use_fog (stage, FALSE); | ||||
|  *   g_signal_connect (stage, "paint", G_CALLBACK (on_stage_paint), NULL); | ||||
|  * ]| | ||||
|  * | ||||
|  * The paint signal handler will call cogl_set_fog() with the | ||||
|  * desired settings: | ||||
|  * | ||||
|  * |[ | ||||
|  *   static void | ||||
|  *   on_stage_paint (ClutterActor *actor) | ||||
|  *   { | ||||
|  *     ClutterColor stage_color = { 0, }; | ||||
|  *     CoglColor fog_color = { 0, }; | ||||
|  * | ||||
|  *     // set the fog color to the stage background color | ||||
|  *     clutter_stage_get_color (CLUTTER_STAGE (actor), &stage_color); | ||||
|  *     cogl_color_init_from_4ub (&fog_color, | ||||
|  *                               stage_color.red, | ||||
|  *                               stage_color.green, | ||||
|  *                               stage_color.blue, | ||||
|  *                               stage_color.alpha); | ||||
|  * | ||||
|  *     // enable fog // | ||||
|  *     cogl_set_fog (&fog_color, | ||||
|  *                   COGL_FOG_MODE_EXPONENTIAL, // mode | ||||
|  *                   0.5,                       // density | ||||
|  *                   5.0, 30.0);                // z_near and z_far | ||||
|  *   } | ||||
|  * ]| | ||||
|  * | ||||
|  * The fogging functions only work correctly when the visible actors use | ||||
|  * unmultiplied alpha colors. By default Cogl will premultiply textures and | ||||
|  * cogl_set_source_color() will premultiply colors, so unless you explicitly | ||||
|  * load your textures requesting an unmultiplied internal format and use | ||||
|  * cogl_material_set_color() you can only use fogging with fully opaque actors. | ||||
|  * Support for premultiplied colors will improve in the future when we can | ||||
|  * depend on fragment shaders. | ||||
|  * | ||||
|  * Since: 0.6 | ||||
|  * | ||||
|  * Deprecated: 1.10: Fog settings are ignored. | ||||
|  */ | ||||
| void | ||||
| clutter_stage_set_fog (ClutterStage *stage, | ||||
|                        ClutterFog   *fog) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_get_fog: | ||||
|  * @stage: the #ClutterStage | ||||
|  * @fog: (out): return location for a #ClutterFog structure | ||||
|  * | ||||
|  * Retrieves the current depth cueing settings from the stage. | ||||
|  * | ||||
|  * Since: 0.6 | ||||
|  * | ||||
|  * Deprecated: 1.10: This function will always return the default | ||||
|  *   values of #ClutterFog | ||||
|  */ | ||||
| void | ||||
| clutter_stage_get_fog (ClutterStage *stage, | ||||
|                         ClutterFog   *fog) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_STAGE (stage)); | ||||
|   g_return_if_fail (fog != NULL); | ||||
|  | ||||
|   *fog = stage->priv->fog; | ||||
| } | ||||
|  | ||||
| /*** Perspective boxed type ******/ | ||||
|  | ||||
| static gpointer | ||||
| @@ -3264,24 +3037,6 @@ G_DEFINE_BOXED_TYPE (ClutterPerspective, clutter_perspective, | ||||
|                      clutter_perspective_copy, | ||||
|                      clutter_perspective_free); | ||||
|  | ||||
| static gpointer | ||||
| clutter_fog_copy (gpointer data) | ||||
| { | ||||
|   if (G_LIKELY (data)) | ||||
|     return g_slice_dup (ClutterFog, data); | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| static void | ||||
| clutter_fog_free (gpointer data) | ||||
| { | ||||
|   if (G_LIKELY (data)) | ||||
|     g_slice_free (ClutterFog, data); | ||||
| } | ||||
|  | ||||
| G_DEFINE_BOXED_TYPE (ClutterFog, clutter_fog, clutter_fog_copy, clutter_fog_free); | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_new: | ||||
|  * | ||||
| @@ -3946,72 +3701,6 @@ _clutter_stage_clear_update_time (ClutterStage *stage) | ||||
|     _clutter_stage_window_clear_update_time (stage_window); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_set_no_clear_hint: | ||||
|  * @stage: a #ClutterStage | ||||
|  * @no_clear: %TRUE if the @stage should not clear itself on every | ||||
|  *   repaint cycle | ||||
|  * | ||||
|  * Sets whether the @stage should clear itself at the beginning | ||||
|  * of each paint cycle or not. | ||||
|  * | ||||
|  * Clearing the #ClutterStage can be a costly operation, especially | ||||
|  * if the stage is always covered - for instance, in a full-screen | ||||
|  * video player or in a game with a background texture. | ||||
|  * | ||||
|  * This setting is a hint; Clutter might discard this hint | ||||
|  * depending on its internal state. | ||||
|  * | ||||
|  * If parts of the stage are visible and you disable clearing you | ||||
|  * might end up with visual artifacts while painting the contents of | ||||
|  * the stage. | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| void | ||||
| clutter_stage_set_no_clear_hint (ClutterStage *stage, | ||||
|                                  gboolean      no_clear) | ||||
| { | ||||
|   ClutterStagePrivate *priv; | ||||
|   ClutterStageHint new_hints; | ||||
|  | ||||
|   g_return_if_fail (CLUTTER_IS_STAGE (stage)); | ||||
|  | ||||
|   priv = stage->priv; | ||||
|   new_hints = priv->stage_hints; | ||||
|  | ||||
|   if (no_clear) | ||||
|     new_hints |= CLUTTER_STAGE_NO_CLEAR_ON_PAINT; | ||||
|   else | ||||
|     new_hints &= ~CLUTTER_STAGE_NO_CLEAR_ON_PAINT; | ||||
|  | ||||
|   if (priv->stage_hints == new_hints) | ||||
|     return; | ||||
|  | ||||
|   priv->stage_hints = new_hints; | ||||
|  | ||||
|   g_object_notify_by_pspec (G_OBJECT (stage), obj_props[PROP_NO_CLEAR_HINT]); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * clutter_stage_get_no_clear_hint: | ||||
|  * @stage: a #ClutterStage | ||||
|  * | ||||
|  * Retrieves the hint set with clutter_stage_set_no_clear_hint() | ||||
|  * | ||||
|  * Return value: %TRUE if the stage should not clear itself on every paint | ||||
|  *   cycle, and %FALSE otherwise | ||||
|  * | ||||
|  * Since: 1.4 | ||||
|  */ | ||||
| gboolean | ||||
| clutter_stage_get_no_clear_hint (ClutterStage *stage) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE); | ||||
|  | ||||
|   return (stage->priv->stage_hints & CLUTTER_STAGE_NO_CLEAR_ON_PAINT) != 0; | ||||
| } | ||||
|  | ||||
| ClutterPaintVolume * | ||||
| _clutter_stage_paint_volume_stack_allocate (ClutterStage *stage) | ||||
| { | ||||
| @@ -4685,7 +4374,7 @@ clutter_stage_get_capture_final_size (ClutterStage          *stage, | ||||
|  | ||||
|   if (rect) | ||||
|     { | ||||
|       ClutterRect capture_rect; | ||||
|       graphene_rect_t capture_rect; | ||||
|  | ||||
|       _clutter_util_rect_from_rectangle (rect, &capture_rect); | ||||
|       if (!_clutter_stage_get_max_view_scale_factor_for_rect (stage, | ||||
| @@ -4892,9 +4581,9 @@ clutter_stage_update_resource_scales (ClutterStage *stage) | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| _clutter_stage_get_max_view_scale_factor_for_rect (ClutterStage *stage, | ||||
|                                                    ClutterRect  *rect, | ||||
|                                                    float        *view_scale) | ||||
| _clutter_stage_get_max_view_scale_factor_for_rect (ClutterStage    *stage, | ||||
|                                                    graphene_rect_t *rect, | ||||
|                                                    float           *view_scale) | ||||
| { | ||||
|   ClutterStagePrivate *priv = stage->priv; | ||||
|   float scale = 0.0f; | ||||
| @@ -4904,12 +4593,12 @@ _clutter_stage_get_max_view_scale_factor_for_rect (ClutterStage *stage, | ||||
|     { | ||||
|       ClutterStageView *view = l->data; | ||||
|       cairo_rectangle_int_t view_layout; | ||||
|       ClutterRect view_rect; | ||||
|       graphene_rect_t view_rect; | ||||
|  | ||||
|       clutter_stage_view_get_layout (view, &view_layout); | ||||
|       _clutter_util_rect_from_rectangle (&view_layout, &view_rect); | ||||
|  | ||||
|       if (clutter_rect_intersection (&view_rect, rect, NULL)) | ||||
|       if (graphene_rect_intersection (&view_rect, rect, NULL)) | ||||
|         scale = MAX (clutter_stage_view_get_scale (view), scale); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -115,26 +115,6 @@ struct _ClutterPerspective | ||||
|   gfloat z_far; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * ClutterFog: | ||||
|  * @z_near: starting distance from the viewer to the near clipping | ||||
|  *   plane (always positive) | ||||
|  * @z_far: final distance from the viewer to the far clipping | ||||
|  *   plane (always positive) | ||||
|  * | ||||
|  * Fog settings used to create the depth cueing effect. | ||||
|  * | ||||
|  * Since: 0.6 | ||||
|  * | ||||
|  * Deprecated: 1.10: The fog-related API in #ClutterStage has been | ||||
|  *   deprecated as well. | ||||
|  */ | ||||
| struct _ClutterFog | ||||
| { | ||||
|   gfloat z_near; | ||||
|   gfloat z_far; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * ClutterFrameInfo: (skip) | ||||
|  */ | ||||
| @@ -153,8 +133,6 @@ typedef struct _ClutterCapture | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_perspective_get_type (void) G_GNUC_CONST; | ||||
| CLUTTER_DEPRECATED | ||||
| GType clutter_fog_get_type (void) G_GNUC_CONST; | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_stage_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| @@ -186,11 +164,6 @@ void            clutter_stage_get_minimum_size                  (ClutterStage | ||||
|                                                                  guint                 *width, | ||||
|                                                                  guint                 *height); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_stage_set_no_clear_hint                 (ClutterStage          *stage, | ||||
|                                                                  gboolean               no_clear); | ||||
| CLUTTER_EXPORT | ||||
| gboolean        clutter_stage_get_no_clear_hint                 (ClutterStage          *stage); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_stage_set_use_alpha                     (ClutterStage          *stage, | ||||
|                                                                  gboolean               use_alpha); | ||||
| CLUTTER_EXPORT | ||||
| @@ -223,8 +196,8 @@ gboolean        clutter_stage_event                             (ClutterStage | ||||
| CLUTTER_EXPORT | ||||
| ClutterActor *  clutter_stage_get_actor_at_pos                  (ClutterStage          *stage, | ||||
|                                                                  ClutterPickMode        pick_mode, | ||||
|                                                                  gint                   x, | ||||
|                                                                  gint                   y); | ||||
|                                                                  float                  x, | ||||
|                                                                  float                  y); | ||||
| CLUTTER_EXPORT | ||||
| guchar *        clutter_stage_read_pixels                       (ClutterStage          *stage, | ||||
|                                                                  gint                   x, | ||||
| @@ -233,8 +206,7 @@ guchar *        clutter_stage_read_pixels                       (ClutterStage | ||||
|                                                                  gint                   height); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_stage_get_redraw_clip_bounds            (ClutterStage          *stage, | ||||
|                                                                  cairo_rectangle_int_t *clip); | ||||
| cairo_region_t * clutter_stage_get_redraw_clip                  (ClutterStage          *stage); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_stage_ensure_viewport                   (ClutterStage          *stage); | ||||
| CLUTTER_EXPORT | ||||
|   | ||||
| @@ -157,7 +157,7 @@ struct _ClutterTextPrivate | ||||
|   gint text_logical_y; | ||||
|  | ||||
|   /* Where to draw the cursor */ | ||||
|   ClutterRect cursor_rect; | ||||
|   graphene_rect_t cursor_rect; | ||||
|   ClutterColor cursor_color; | ||||
|   guint cursor_size; | ||||
|  | ||||
| @@ -178,17 +178,17 @@ struct _ClutterTextPrivate | ||||
|   guint password_hint_timeout; | ||||
|  | ||||
|   /* Signal handler for when the backend changes its font settings */ | ||||
|   guint settings_changed_id; | ||||
|   gulong settings_changed_id; | ||||
|  | ||||
|   /* Signal handler for when the :text-direction changes */ | ||||
|   guint direction_changed_id; | ||||
|   gulong direction_changed_id; | ||||
|  | ||||
|   ClutterInputFocus *input_focus; | ||||
|   ClutterInputContentHintFlags input_hints; | ||||
|   ClutterInputContentPurpose input_purpose; | ||||
|  | ||||
|   /* Signal handler for when the :resource-scale changes */ | ||||
|   guint resource_scale_changed_id; | ||||
|   gulong resource_scale_changed_id; | ||||
|  | ||||
|   /* bitfields */ | ||||
|   guint alignment               : 2; | ||||
| @@ -759,7 +759,14 @@ clutter_text_create_layout_no_cache (ClutterText       *text, | ||||
|           ClutterTextDirection text_dir; | ||||
|  | ||||
|           if (clutter_actor_has_key_focus (CLUTTER_ACTOR (text))) | ||||
|             pango_dir = _clutter_backend_get_keymap_direction (backend); | ||||
|             { | ||||
|               ClutterSeat *seat; | ||||
|               ClutterKeymap *keymap; | ||||
|  | ||||
|               seat = clutter_backend_get_default_seat (backend); | ||||
|               keymap = clutter_seat_get_keymap (seat); | ||||
|               pango_dir = clutter_keymap_get_direction (keymap); | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               text_dir = clutter_actor_get_text_direction (CLUTTER_ACTOR (text)); | ||||
| @@ -1304,7 +1311,7 @@ static inline void | ||||
| update_cursor_location (ClutterText *self) | ||||
| { | ||||
|   ClutterTextPrivate *priv = self->priv; | ||||
|   ClutterRect rect; | ||||
|   graphene_rect_t rect; | ||||
|   float x, y; | ||||
|  | ||||
|   if (!priv->editable) | ||||
| @@ -1312,7 +1319,7 @@ update_cursor_location (ClutterText *self) | ||||
|  | ||||
|   rect = priv->cursor_rect; | ||||
|   clutter_actor_get_transformed_position (CLUTTER_ACTOR (self), &x, &y); | ||||
|   clutter_rect_offset (&rect, x, y); | ||||
|   graphene_rect_offset (&rect, x, y); | ||||
|   clutter_input_focus_set_cursor_location (priv->input_focus, &rect); | ||||
| } | ||||
|  | ||||
| @@ -1322,7 +1329,7 @@ clutter_text_ensure_cursor_position (ClutterText *self, | ||||
| { | ||||
|   ClutterTextPrivate *priv = self->priv; | ||||
|   gfloat x, y, cursor_height; | ||||
|   ClutterRect cursor_rect = CLUTTER_RECT_INIT_ZERO; | ||||
|   graphene_rect_t cursor_rect = GRAPHENE_RECT_INIT_ZERO; | ||||
|   gint position; | ||||
|  | ||||
|   position = priv->position; | ||||
| @@ -1345,25 +1352,17 @@ clutter_text_ensure_cursor_position (ClutterText *self, | ||||
|                                             &x, &y, | ||||
|                                             &cursor_height); | ||||
|  | ||||
|   clutter_rect_init (&cursor_rect, | ||||
|                      x, | ||||
|                      y + CURSOR_Y_PADDING * scale, | ||||
|                      priv->cursor_size * scale, | ||||
|                      cursor_height - 2 * CURSOR_Y_PADDING * scale); | ||||
|   graphene_rect_init (&cursor_rect, | ||||
|                       x, | ||||
|                       y + CURSOR_Y_PADDING * scale, | ||||
|                       priv->cursor_size * scale, | ||||
|                       cursor_height - 2 * CURSOR_Y_PADDING * scale); | ||||
|  | ||||
|   if (!clutter_rect_equals (&priv->cursor_rect, &cursor_rect)) | ||||
|   if (!graphene_rect_equal (&priv->cursor_rect, &cursor_rect)) | ||||
|     { | ||||
|       ClutterGeometry cursor_pos; | ||||
|  | ||||
|       priv->cursor_rect = cursor_rect; | ||||
|  | ||||
|       /* XXX:2.0 - remove */ | ||||
|       cursor_pos.x = clutter_rect_get_x (&priv->cursor_rect); | ||||
|       cursor_pos.y = clutter_rect_get_y (&priv->cursor_rect); | ||||
|       cursor_pos.width = clutter_rect_get_width (&priv->cursor_rect); | ||||
|       cursor_pos.height = clutter_rect_get_height (&priv->cursor_rect); | ||||
|       g_signal_emit (self, text_signals[CURSOR_EVENT], 0, &cursor_pos); | ||||
|  | ||||
|       g_signal_emit (self, text_signals[CURSOR_EVENT], 0, &cursor_rect); | ||||
|       g_signal_emit (self, text_signals[CURSOR_CHANGED], 0); | ||||
|  | ||||
|       update_cursor_location (self); | ||||
| @@ -1766,30 +1765,12 @@ clutter_text_dispose (GObject *gobject) | ||||
|   /* get rid of the entire cache */ | ||||
|   clutter_text_dirty_cache (self); | ||||
|  | ||||
|   if (priv->direction_changed_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (self, priv->direction_changed_id); | ||||
|       priv->direction_changed_id = 0; | ||||
|     } | ||||
|   g_clear_signal_handler (&priv->direction_changed_id, self); | ||||
|   g_clear_signal_handler (&priv->resource_scale_changed_id, self); | ||||
|   g_clear_signal_handler (&priv->settings_changed_id, | ||||
|                           clutter_get_default_backend ()); | ||||
|  | ||||
|   if (priv->resource_scale_changed_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (self, priv->resource_scale_changed_id); | ||||
|       priv->resource_scale_changed_id = 0; | ||||
|     } | ||||
|  | ||||
|   if (priv->settings_changed_id) | ||||
|     { | ||||
|       g_signal_handler_disconnect (clutter_get_default_backend (), | ||||
|                                    priv->settings_changed_id); | ||||
|       priv->settings_changed_id = 0; | ||||
|     } | ||||
|  | ||||
|   if (priv->password_hint_id) | ||||
|     { | ||||
|       g_source_remove (priv->password_hint_id); | ||||
|       priv->password_hint_id = 0; | ||||
|     } | ||||
|   g_clear_handle_id (&priv->password_hint_id, g_source_remove); | ||||
|  | ||||
|   clutter_text_set_buffer (self, NULL); | ||||
|  | ||||
| @@ -2472,8 +2453,7 @@ clutter_text_key_press (ClutterActor    *actor, | ||||
|  | ||||
|           if (priv->show_password_hint) | ||||
|             { | ||||
|               if (priv->password_hint_id != 0) | ||||
|                 g_source_remove (priv->password_hint_id); | ||||
|               g_clear_handle_id (&priv->password_hint_id, g_source_remove); | ||||
|  | ||||
|               priv->password_hint_visible = TRUE; | ||||
|               priv->password_hint_id = | ||||
| @@ -2712,7 +2692,7 @@ clutter_text_paint (ClutterActor *self) | ||||
|  | ||||
|       if (actor_width < text_width) | ||||
|         { | ||||
|           gint cursor_x = clutter_rect_get_x (&priv->cursor_rect); | ||||
|           gint cursor_x = graphene_rect_get_x (&priv->cursor_rect); | ||||
|  | ||||
|           if (priv->position == -1) | ||||
|             { | ||||
| @@ -2799,7 +2779,7 @@ add_selection_to_paint_volume (ClutterText           *text, | ||||
| { | ||||
|   ClutterPaintVolume *total_volume = user_data; | ||||
|   ClutterPaintVolume rect_volume; | ||||
|   ClutterVertex vertex; | ||||
|   graphene_point3d_t vertex; | ||||
|  | ||||
|   _clutter_paint_volume_init_static (&rect_volume, CLUTTER_ACTOR (text)); | ||||
|  | ||||
| @@ -2821,7 +2801,7 @@ clutter_text_get_paint_volume_for_cursor (ClutterText        *text, | ||||
|                                           ClutterPaintVolume *volume) | ||||
| { | ||||
|   ClutterTextPrivate *priv = text->priv; | ||||
|   ClutterVertex origin; | ||||
|   graphene_point3d_t origin; | ||||
|  | ||||
|   clutter_text_ensure_cursor_position (text, resource_scale); | ||||
|  | ||||
| @@ -2864,7 +2844,7 @@ clutter_text_get_paint_volume (ClutterActor       *self, | ||||
|     { | ||||
|       PangoLayout *layout; | ||||
|       PangoRectangle ink_rect; | ||||
|       ClutterVertex origin; | ||||
|       graphene_point3d_t origin; | ||||
|       float resource_scale; | ||||
|  | ||||
|       /* If the text is single line editable then it gets clipped to | ||||
| @@ -4399,10 +4379,10 @@ clutter_text_class_init (ClutterTextClass *klass) | ||||
|   /** | ||||
|    * ClutterText::cursor-event: | ||||
|    * @self: the #ClutterText that emitted the signal | ||||
|    * @geometry: the coordinates of the cursor | ||||
|    * @rect: the coordinates of the cursor | ||||
|    * | ||||
|    * The ::cursor-event signal is emitted whenever the cursor position | ||||
|    * changes inside a #ClutterText actor. Inside @geometry it is stored | ||||
|    * changes inside a #ClutterText actor. Inside @rect it is stored | ||||
|    * the current position and size of the cursor, relative to the actor | ||||
|    * itself. | ||||
|    * | ||||
| @@ -4417,7 +4397,7 @@ clutter_text_class_init (ClutterTextClass *klass) | ||||
| 		  G_STRUCT_OFFSET (ClutterTextClass, cursor_event), | ||||
| 		  NULL, NULL, NULL, | ||||
| 		  G_TYPE_NONE, 1, | ||||
| 		  CLUTTER_TYPE_GEOMETRY | G_SIGNAL_TYPE_STATIC_SCOPE); | ||||
| 		  GRAPHENE_TYPE_RECT | G_SIGNAL_TYPE_STATIC_SCOPE); | ||||
|  | ||||
|   /** | ||||
|    * ClutterText::cursor-changed: | ||||
| @@ -6780,8 +6760,8 @@ clutter_text_get_layout_offsets (ClutterText *self, | ||||
|  * Since: 1.16 | ||||
|  */ | ||||
| void | ||||
| clutter_text_get_cursor_rect (ClutterText *self, | ||||
|                               ClutterRect *rect) | ||||
| clutter_text_get_cursor_rect (ClutterText     *self, | ||||
|                               graphene_rect_t *rect) | ||||
| { | ||||
|   g_return_if_fail (CLUTTER_IS_TEXT (self)); | ||||
|   g_return_if_fail (rect != NULL); | ||||
|   | ||||
| @@ -82,7 +82,7 @@ struct _ClutterTextClass | ||||
|   void (* text_changed)   (ClutterText           *self); | ||||
|   void (* activate)       (ClutterText           *self); | ||||
|   void (* cursor_event)   (ClutterText           *self, | ||||
|                            const ClutterGeometry *geometry); | ||||
|                            const graphene_rect_t *rect); | ||||
|   void (* cursor_changed) (ClutterText           *self); | ||||
|  | ||||
|   /*< private >*/ | ||||
| @@ -230,7 +230,7 @@ CLUTTER_EXPORT | ||||
| guint                 clutter_text_get_cursor_size      (ClutterText          *self); | ||||
| CLUTTER_EXPORT | ||||
| void                  clutter_text_get_cursor_rect      (ClutterText          *self, | ||||
|                                                          ClutterRect          *rect); | ||||
|                                                          graphene_rect_t      *rect); | ||||
| CLUTTER_EXPORT | ||||
| void                  clutter_text_set_selectable       (ClutterText          *self, | ||||
|                                                          gboolean              selectable); | ||||
|   | ||||
| @@ -1,131 +0,0 @@ | ||||
| /* | ||||
|  * Clutter. | ||||
|  * | ||||
|  * An OpenGL based 'interactive canvas' library. | ||||
|  * | ||||
|  * Authored By Matthew Allum  <mallum@openedhand.com> | ||||
|  * | ||||
|  * Copyright (C) 2006 OpenedHand | ||||
|  * | ||||
|  * 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.1 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_TEXTURE_H__ | ||||
| #define __CLUTTER_TEXTURE_H__ | ||||
|  | ||||
| #include <cogl/cogl.h> | ||||
| #include <clutter/clutter-actor.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| #define CLUTTER_TYPE_TEXTURE            (clutter_texture_get_type ()) | ||||
| #define CLUTTER_TEXTURE(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_TEXTURE, ClutterTexture)) | ||||
| #define CLUTTER_TEXTURE_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_TEXTURE, ClutterTextureClass)) | ||||
| #define CLUTTER_IS_TEXTURE(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_TEXTURE)) | ||||
| #define CLUTTER_IS_TEXTURE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), CLUTTER_TYPE_TEXTURE)) | ||||
| #define CLUTTER_TEXTURE_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), CLUTTER_TYPE_TEXTURE, ClutterTextureClass)) | ||||
|  | ||||
| /** | ||||
|  * ClutterTextureError: | ||||
|  * @CLUTTER_TEXTURE_ERROR_OUT_OF_MEMORY: OOM condition | ||||
|  * @CLUTTER_TEXTURE_ERROR_NO_YUV: YUV operation attempted but no YUV support | ||||
|  *   found | ||||
|  * @CLUTTER_TEXTURE_ERROR_BAD_FORMAT: The requested format for | ||||
|  * clutter_texture_set_from_rgb_data or | ||||
|  * clutter_texture_set_from_yuv_data is unsupported. | ||||
|  * | ||||
|  * Error enumeration for #ClutterTexture | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  */ | ||||
| typedef enum | ||||
| { | ||||
|   CLUTTER_TEXTURE_ERROR_OUT_OF_MEMORY, | ||||
|   CLUTTER_TEXTURE_ERROR_NO_YUV, | ||||
|   CLUTTER_TEXTURE_ERROR_BAD_FORMAT | ||||
| } ClutterTextureError; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_TEXTURE_ERROR: | ||||
|  * | ||||
|  * Error domain for #ClutterTexture errors | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  */ | ||||
| #define CLUTTER_TEXTURE_ERROR   (clutter_texture_error_quark ()) | ||||
| CLUTTER_EXPORT | ||||
| GQuark clutter_texture_error_quark (void); | ||||
|  | ||||
| typedef struct _ClutterTexture        ClutterTexture; | ||||
| typedef struct _ClutterTextureClass   ClutterTextureClass; | ||||
| typedef struct _ClutterTexturePrivate ClutterTexturePrivate; | ||||
|  | ||||
| /** | ||||
|  * ClutterTexture: | ||||
|  * | ||||
|  * The #ClutterTexture structure contains only private data | ||||
|  * and should be accessed using the provided API | ||||
|  * | ||||
|  * Since: 0.2 | ||||
|  */ | ||||
| struct _ClutterTexture | ||||
| { | ||||
|   /*< private >*/ | ||||
|   ClutterActor         parent; | ||||
|  | ||||
|   ClutterTexturePrivate *priv; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * ClutterTextureClass: | ||||
|  * @size_change: handler for the #ClutterTexture::size-change signal | ||||
|  * @pixbuf_change: handler for the #ClutterTexture::pixbuf-change signal | ||||
|  * @load_finished: handler for the #ClutterTexture::load-finished signal | ||||
|  * | ||||
|  * The #ClutterTextureClass structure contains only private data | ||||
|  * | ||||
|  * Since: 0.2 | ||||
|  */ | ||||
| struct _ClutterTextureClass | ||||
| { | ||||
|   /*< private >*/ | ||||
|   ClutterActorClass parent_class; | ||||
|  | ||||
|   /*< public >*/ | ||||
|   void (* size_change)   (ClutterTexture *texture, | ||||
|                           gint            width, | ||||
|                           gint            height); | ||||
|   void (* pixbuf_change) (ClutterTexture *texture); | ||||
|   void (* load_finished) (ClutterTexture *texture, | ||||
|                           const GError   *error); | ||||
|  | ||||
|   /*< private >*/ | ||||
|   /* padding, for future expansion */ | ||||
|   void (*_clutter_texture1) (void); | ||||
|   void (*_clutter_texture2) (void); | ||||
|   void (*_clutter_texture3) (void); | ||||
|   void (*_clutter_texture4) (void); | ||||
|   void (*_clutter_texture5) (void); | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_texture_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __CLUTTER_TEXTURE_H__ */ | ||||
| @@ -145,8 +145,8 @@ struct _ClutterTimelinePrivate | ||||
|   ClutterStepMode step_mode; | ||||
|  | ||||
|   /* cubic-bezier() parameters */ | ||||
|   ClutterPoint cb_1; | ||||
|   ClutterPoint cb_2; | ||||
|   graphene_point_t cb_1; | ||||
|   graphene_point_t cb_2; | ||||
|  | ||||
|   guint is_playing         : 1; | ||||
|  | ||||
| @@ -846,8 +846,8 @@ clutter_timeline_init (ClutterTimeline *self) | ||||
|   self->priv->step_mode = CLUTTER_STEP_MODE_END; | ||||
|  | ||||
|   /* default cubic-bezier() paramereters are (0, 0, 1, 1) */ | ||||
|   clutter_point_init (&self->priv->cb_1, 0, 0); | ||||
|   clutter_point_init (&self->priv->cb_2, 1, 1); | ||||
|   graphene_point_init (&self->priv->cb_1, 0, 0); | ||||
|   graphene_point_init (&self->priv->cb_2, 1, 1); | ||||
| } | ||||
|  | ||||
| struct CheckIfMarkerHitClosure | ||||
| @@ -2485,9 +2485,9 @@ clutter_timeline_get_step_progress (ClutterTimeline *timeline, | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| void | ||||
| clutter_timeline_set_cubic_bezier_progress (ClutterTimeline    *timeline, | ||||
|                                             const ClutterPoint *c_1, | ||||
|                                             const ClutterPoint *c_2) | ||||
| clutter_timeline_set_cubic_bezier_progress (ClutterTimeline        *timeline, | ||||
|                                             const graphene_point_t *c_1, | ||||
|                                             const graphene_point_t *c_2) | ||||
| { | ||||
|   ClutterTimelinePrivate *priv; | ||||
|  | ||||
| @@ -2522,9 +2522,9 @@ clutter_timeline_set_cubic_bezier_progress (ClutterTimeline    *timeline, | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| gboolean | ||||
| clutter_timeline_get_cubic_bezier_progress (ClutterTimeline *timeline, | ||||
|                                             ClutterPoint    *c_1, | ||||
|                                             ClutterPoint    *c_2) | ||||
| clutter_timeline_get_cubic_bezier_progress (ClutterTimeline  *timeline, | ||||
|                                             graphene_point_t *c_1, | ||||
|                                             graphene_point_t *c_2) | ||||
| { | ||||
|   g_return_val_if_fail (CLUTTER_IS_TIMELINE (timeline), FALSE); | ||||
|  | ||||
|   | ||||
| @@ -208,13 +208,13 @@ gboolean                        clutter_timeline_get_step_progress | ||||
|                                                                                  gint                     *n_steps, | ||||
|                                                                                  ClutterStepMode          *step_mode); | ||||
| CLUTTER_EXPORT | ||||
| void                            clutter_timeline_set_cubic_bezier_progress      (ClutterTimeline          *timeline, | ||||
|                                                                                  const ClutterPoint       *c_1, | ||||
|                                                                                  const ClutterPoint       *c_2); | ||||
| void                            clutter_timeline_set_cubic_bezier_progress      (ClutterTimeline        *timeline, | ||||
|                                                                                  const graphene_point_t *c_1, | ||||
|                                                                                  const graphene_point_t *c_2); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                        clutter_timeline_get_cubic_bezier_progress      (ClutterTimeline          *timeline, | ||||
|                                                                                  ClutterPoint             *c_1, | ||||
|                                                                                  ClutterPoint             *c_2); | ||||
| gboolean                        clutter_timeline_get_cubic_bezier_progress      (ClutterTimeline  *timeline, | ||||
|                                                                                  graphene_point_t *c_1, | ||||
|                                                                                  graphene_point_t *c_2); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| gint64                          clutter_timeline_get_duration_hint              (ClutterTimeline          *timeline); | ||||
|   | ||||
| @@ -33,20 +33,16 @@ | ||||
| #include <clutter/clutter-macros.h> | ||||
| #include <clutter/clutter-enums.h> | ||||
|  | ||||
| #include <graphene-gobject.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| #define CLUTTER_TYPE_ACTOR_BOX          (clutter_actor_box_get_type ()) | ||||
| #define CLUTTER_TYPE_FOG                (clutter_fog_get_type ()) | ||||
| #define CLUTTER_TYPE_GEOMETRY           (clutter_geometry_get_type ()) | ||||
| #define CLUTTER_TYPE_KNOT               (clutter_knot_get_type ()) | ||||
| #define CLUTTER_TYPE_MARGIN             (clutter_margin_get_type ()) | ||||
| #define CLUTTER_TYPE_MATRIX             (clutter_matrix_get_type ()) | ||||
| #define CLUTTER_TYPE_PAINT_VOLUME       (clutter_paint_volume_get_type ()) | ||||
| #define CLUTTER_TYPE_PERSPECTIVE        (clutter_perspective_get_type ()) | ||||
| #define CLUTTER_TYPE_VERTEX             (clutter_vertex_get_type ()) | ||||
| #define CLUTTER_TYPE_POINT              (clutter_point_get_type ()) | ||||
| #define CLUTTER_TYPE_SIZE               (clutter_size_get_type ()) | ||||
| #define CLUTTER_TYPE_RECT               (clutter_rect_get_type ()) | ||||
|  | ||||
| typedef struct _ClutterActor                    ClutterActor; | ||||
|  | ||||
| @@ -79,14 +75,9 @@ typedef struct _ClutterPathNode                 ClutterPathNode; | ||||
|  | ||||
| typedef struct _ClutterActorBox                 ClutterActorBox; | ||||
| typedef struct _ClutterColor                    ClutterColor; | ||||
| typedef struct _ClutterGeometry                 ClutterGeometry; /* XXX:2.0 - remove */ | ||||
| typedef struct _ClutterKnot                     ClutterKnot; | ||||
| typedef struct _ClutterMargin                   ClutterMargin; | ||||
| typedef struct _ClutterPerspective              ClutterPerspective; | ||||
| typedef struct _ClutterPoint                    ClutterPoint; | ||||
| typedef struct _ClutterRect                     ClutterRect; | ||||
| typedef struct _ClutterSize                     ClutterSize; | ||||
| typedef struct _ClutterVertex                   ClutterVertex; | ||||
|  | ||||
| typedef struct _ClutterAlpha            	ClutterAlpha; | ||||
| typedef struct _ClutterAnimation                ClutterAnimation; | ||||
| @@ -113,8 +104,6 @@ typedef union _ClutterEvent                     ClutterEvent; | ||||
|  */ | ||||
| typedef struct _ClutterEventSequence            ClutterEventSequence; | ||||
|  | ||||
| typedef struct _ClutterFog                      ClutterFog; /* deprecated */ | ||||
| typedef struct _ClutterBehaviour                ClutterBehaviour; /* deprecated */ | ||||
| typedef struct _ClutterShader                   ClutterShader; /* deprecated */ | ||||
|  | ||||
| /** | ||||
| @@ -137,310 +126,6 @@ typedef struct _ClutterShader                   ClutterShader; /* deprecated */ | ||||
|  */ | ||||
| typedef struct _ClutterPaintVolume      ClutterPaintVolume; | ||||
|  | ||||
| /** | ||||
|  * ClutterPoint: | ||||
|  * @x: X coordinate, in pixels | ||||
|  * @y: Y coordinate, in pixels | ||||
|  * | ||||
|  * A point in 2D space. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| struct _ClutterPoint | ||||
| { | ||||
|   float x; | ||||
|   float y; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_POINT_INIT: | ||||
|  * @x: X coordinate | ||||
|  * @y: Y coordinate | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterPoint when declaring it, e.g.: | ||||
|  * | ||||
|  * |[ | ||||
|  *   ClutterPoint p = CLUTTER_POINT_INIT (100, 100); | ||||
|  * ]| | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_POINT_INIT(x,y)         { (x), (y) } | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_POINT_INIT_ZERO: | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterPoint to (0, 0) when | ||||
|  * declaring it. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_POINT_INIT_ZERO         CLUTTER_POINT_INIT (0.f, 0.f) | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_point_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| const ClutterPoint *    clutter_point_zero      (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterPoint *          clutter_point_alloc     (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterPoint *          clutter_point_init      (ClutterPoint       *point, | ||||
|                                                  float               x, | ||||
|                                                  float               y); | ||||
| CLUTTER_EXPORT | ||||
| ClutterPoint *          clutter_point_copy      (const ClutterPoint *point); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_point_free      (ClutterPoint       *point); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_point_equals    (const ClutterPoint *a, | ||||
|                                                  const ClutterPoint *b); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_point_distance  (const ClutterPoint *a, | ||||
|                                                  const ClutterPoint *b, | ||||
|                                                  float              *x_distance, | ||||
|                                                  float              *y_distance); | ||||
| CLUTTER_EXPORT | ||||
| gboolean clutter_point_inside_quadrilateral     (const ClutterPoint *point, | ||||
|                                                  const ClutterPoint *vertices); | ||||
|  | ||||
| /** | ||||
|  * ClutterSize: | ||||
|  * @width: the width, in pixels | ||||
|  * @height: the height, in pixels | ||||
|  * | ||||
|  * A size, in 2D space. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| struct _ClutterSize | ||||
| { | ||||
|   float width; | ||||
|   float height; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_SIZE_INIT: | ||||
|  * @width: the width | ||||
|  * @height: the height | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterSize when declaring it, e.g.: | ||||
|  * | ||||
|  * |[ | ||||
|  *   ClutterSize s = CLUTTER_SIZE_INIT (200, 200); | ||||
|  * ]| | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_SIZE_INIT(width,height) { (width), (height) } | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_SIZE_INIT_ZERO: | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterSize to (0, 0) when | ||||
|  * declaring it. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_SIZE_INIT_ZERO          CLUTTER_SIZE_INIT (0.f, 0.f) | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_size_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterSize *   clutter_size_alloc      (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterSize *   clutter_size_init       (ClutterSize       *size, | ||||
|                                          float              width, | ||||
|                                          float              height); | ||||
| CLUTTER_EXPORT | ||||
| ClutterSize *   clutter_size_copy       (const ClutterSize *size); | ||||
| CLUTTER_EXPORT | ||||
| void            clutter_size_free       (ClutterSize       *size); | ||||
| CLUTTER_EXPORT | ||||
| gboolean        clutter_size_equals     (const ClutterSize *a, | ||||
|                                          const ClutterSize *b); | ||||
|  | ||||
| /** | ||||
|  * ClutterRect: | ||||
|  * @origin: the origin of the rectangle | ||||
|  * @size: the size of the rectangle | ||||
|  * | ||||
|  * The location and size of a rectangle. | ||||
|  * | ||||
|  * The width and height of a #ClutterRect can be negative; Clutter considers | ||||
|  * a rectangle with an origin of [ 0.0, 0.0 ] and a size of [ 10.0, 10.0 ] to | ||||
|  * be equivalent to a rectangle with origin of [ 10.0, 10.0 ] and size of | ||||
|  * [ -10.0, -10.0 ]. | ||||
|  * | ||||
|  * Application code can normalize rectangles using clutter_rect_normalize(): | ||||
|  * this function will ensure that the width and height of a #ClutterRect are | ||||
|  * positive values. All functions taking a #ClutterRect as an argument will | ||||
|  * implicitly normalize it before computing eventual results. For this reason | ||||
|  * it is safer to access the contents of a #ClutterRect by using the provided | ||||
|  * API at all times, instead of directly accessing the structure members. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| struct _ClutterRect | ||||
| { | ||||
|   ClutterPoint origin; | ||||
|   ClutterSize size; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_RECT_INIT: | ||||
|  * @x: the X coordinate | ||||
|  * @y: the Y coordinate | ||||
|  * @width: the width | ||||
|  * @height: the height | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterRect when declaring it, e.g.: | ||||
|  * | ||||
|  * |[ | ||||
|  *   ClutterRect r = CLUTTER_RECT_INIT (100, 100, 200, 200); | ||||
|  * ]| | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_RECT_INIT(x,y,width,height)     { { (x), (y) }, { (width), (height) } } | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_RECT_INIT_ZERO: | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterRect to (0, 0, 0, 0) when | ||||
|  * declaring it. | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_RECT_INIT_ZERO                  CLUTTER_RECT_INIT (0.f, 0.f, 0.f, 0.f) | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_rect_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| const ClutterRect *     clutter_rect_zero               (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterRect *           clutter_rect_alloc              (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterRect *           clutter_rect_init               (ClutterRect       *rect, | ||||
|                                                          float              x, | ||||
|                                                          float              y, | ||||
|                                                          float              width, | ||||
|                                                          float              height); | ||||
| CLUTTER_EXPORT | ||||
| ClutterRect *           clutter_rect_copy               (const ClutterRect *rect); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_free               (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_rect_equals             (ClutterRect       *a, | ||||
|                                                          ClutterRect       *b); | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| ClutterRect *           clutter_rect_normalize          (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_get_center         (ClutterRect       *rect, | ||||
|                                                          ClutterPoint      *center); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_rect_contains_point     (ClutterRect       *rect, | ||||
|                                                          ClutterPoint      *point); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_rect_contains_rect      (ClutterRect       *a, | ||||
|                                                          ClutterRect       *b); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_union              (ClutterRect       *a, | ||||
|                                                          ClutterRect       *b, | ||||
|                                                          ClutterRect       *res); | ||||
| CLUTTER_EXPORT | ||||
| gboolean                clutter_rect_intersection       (ClutterRect       *a, | ||||
|                                                          ClutterRect       *b, | ||||
|                                                          ClutterRect       *res); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_offset             (ClutterRect       *rect, | ||||
|                                                          float              d_x, | ||||
|                                                          float              d_y); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_inset              (ClutterRect       *rect, | ||||
|                                                          float              d_x, | ||||
|                                                          float              d_y); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_scale              (ClutterRect       *rect, | ||||
|                                                          float              s_x, | ||||
|                                                          float              s_y); | ||||
| CLUTTER_EXPORT | ||||
| void                    clutter_rect_clamp_to_pixel     (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_rect_get_x              (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_rect_get_y              (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_rect_get_width          (ClutterRect       *rect); | ||||
| CLUTTER_EXPORT | ||||
| float                   clutter_rect_get_height         (ClutterRect       *rect); | ||||
|  | ||||
| /** | ||||
|  * ClutterVertex: | ||||
|  * @x: X coordinate of the vertex | ||||
|  * @y: Y coordinate of the vertex | ||||
|  * @z: Z coordinate of the vertex | ||||
|  * | ||||
|  * A point in 3D space, expressed in pixels | ||||
|  * | ||||
|  * Since: 0.4 | ||||
|  */ | ||||
| struct _ClutterVertex | ||||
| { | ||||
|   gfloat x; | ||||
|   gfloat y; | ||||
|   gfloat z; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_VERTEX_INIT: | ||||
|  * @x: the X coordinate of the vertex | ||||
|  * @y: the Y coordinate of the vertex | ||||
|  * @z: the Z coordinate of the vertex | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterVertex when declaring it, e.g.: | ||||
|  * | ||||
|  * |[ | ||||
|  *   ClutterVertex v = CLUTTER_VERTEX_INIT (x, y, z); | ||||
|  * ]| | ||||
|  * | ||||
|  * Since: 1.10 | ||||
|  */ | ||||
| #define CLUTTER_VERTEX_INIT(x,y,z)      { (x), (y), (z) } | ||||
|  | ||||
| /** | ||||
|  * CLUTTER_VERTEX_INIT_ZERO: | ||||
|  * | ||||
|  * A simple macro for initializing a #ClutterVertex to (0, 0, 0). | ||||
|  * | ||||
|  * Since: 1.12 | ||||
|  */ | ||||
| #define CLUTTER_VERTEX_INIT_ZERO        CLUTTER_VERTEX_INIT (0.f, 0.f, 0.f) | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType          clutter_vertex_get_type (void) G_GNUC_CONST; | ||||
| CLUTTER_EXPORT | ||||
| ClutterVertex *clutter_vertex_new      (gfloat               x, | ||||
|                                         gfloat               y, | ||||
|                                         gfloat               z); | ||||
| CLUTTER_EXPORT | ||||
| ClutterVertex *clutter_vertex_alloc    (void); | ||||
| CLUTTER_EXPORT | ||||
| ClutterVertex *clutter_vertex_init     (ClutterVertex       *vertex, | ||||
|                                         gfloat               x, | ||||
|                                         gfloat               y, | ||||
|                                         gfloat               z); | ||||
| CLUTTER_EXPORT | ||||
| ClutterVertex *clutter_vertex_copy     (const ClutterVertex *vertex); | ||||
| CLUTTER_EXPORT | ||||
| void           clutter_vertex_free     (ClutterVertex       *vertex); | ||||
| CLUTTER_EXPORT | ||||
| gboolean       clutter_vertex_equal    (const ClutterVertex *vertex_a, | ||||
|                                         const ClutterVertex *vertex_b); | ||||
|  | ||||
| /** | ||||
|  * ClutterActorBox: | ||||
|  * @x1: X coordinate of the top left corner | ||||
| @@ -544,8 +229,8 @@ gboolean         clutter_actor_box_contains      (const ClutterActorBox *box, | ||||
|                                                   gfloat                 x, | ||||
|                                                   gfloat                 y); | ||||
| CLUTTER_EXPORT | ||||
| void             clutter_actor_box_from_vertices (ClutterActorBox       *box, | ||||
|                                                   const ClutterVertex    verts[]); | ||||
| void             clutter_actor_box_from_vertices (ClutterActorBox          *box, | ||||
|                                                   const graphene_point3d_t  verts[]); | ||||
| CLUTTER_EXPORT | ||||
| void             clutter_actor_box_interpolate   (const ClutterActorBox *initial, | ||||
|                                                   const ClutterActorBox *final, | ||||
| @@ -571,41 +256,6 @@ CLUTTER_EXPORT | ||||
| void             clutter_actor_box_scale          (ClutterActorBox       *box, | ||||
|                                                    gfloat                 scale); | ||||
|  | ||||
| /** | ||||
|  * ClutterGeometry: | ||||
|  * @x: X coordinate of the top left corner of an actor | ||||
|  * @y: Y coordinate of the top left corner of an actor | ||||
|  * @width: width of an actor | ||||
|  * @height: height of an actor | ||||
|  * | ||||
|  * The rectangle containing an actor's bounding box, measured in pixels. | ||||
|  * | ||||
|  * You should not use #ClutterGeometry, or operate on its fields | ||||
|  * directly; you should use #cairo_rectangle_int_t or #ClutterRect if you | ||||
|  * need a rectangle type, depending on the precision required. | ||||
|  * | ||||
|  * Deprecated: 1.16 | ||||
|  */ | ||||
| struct _ClutterGeometry | ||||
| { | ||||
|   /*< public >*/ | ||||
|   gint   x; | ||||
|   gint   y; | ||||
|   guint  width; | ||||
|   guint  height; | ||||
| }; | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| GType clutter_geometry_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| CLUTTER_DEPRECATED | ||||
| void      clutter_geometry_union      (const ClutterGeometry *geometry_a, | ||||
|                                        const ClutterGeometry *geometry_b, | ||||
|                                        ClutterGeometry       *result); | ||||
| CLUTTER_DEPRECATED | ||||
| gboolean  clutter_geometry_intersects (const ClutterGeometry *geometry0, | ||||
|                                        const ClutterGeometry *geometry1); | ||||
|  | ||||
| /** | ||||
|  * ClutterKnot: | ||||
|  * @x: X coordinate of the knot | ||||
| @@ -677,10 +327,10 @@ void                clutter_paint_volume_free                (ClutterPaintVolume | ||||
|  | ||||
| CLUTTER_EXPORT | ||||
| void                clutter_paint_volume_set_origin          (ClutterPaintVolume       *pv, | ||||
|                                                               const ClutterVertex      *origin); | ||||
|                                                               const graphene_point3d_t *origin); | ||||
| CLUTTER_EXPORT | ||||
| void                clutter_paint_volume_get_origin          (const ClutterPaintVolume *pv, | ||||
|                                                               ClutterVertex            *vertex); | ||||
|                                                               graphene_point3d_t       *vertex); | ||||
| CLUTTER_EXPORT | ||||
| void                clutter_paint_volume_set_width           (ClutterPaintVolume       *pv, | ||||
|                                                               gfloat                    width); | ||||
|   | ||||
| @@ -51,8 +51,8 @@ void | ||||
| _clutter_util_fully_transform_vertices (const CoglMatrix *modelview, | ||||
|                                         const CoglMatrix *projection, | ||||
|                                         const float *viewport, | ||||
|                                         const ClutterVertex *vertices_in, | ||||
|                                         ClutterVertex *vertices_out, | ||||
|                                         const graphene_point3d_t *vertices_in, | ||||
|                                         graphene_point3d_t *vertices_out, | ||||
|                                         int n_vertices) | ||||
| { | ||||
|   CoglMatrix modelview_projection; | ||||
| @@ -69,7 +69,7 @@ _clutter_util_fully_transform_vertices (const CoglMatrix *modelview, | ||||
|                             modelview); | ||||
|       cogl_matrix_project_points (&modelview_projection, | ||||
|                                   3, | ||||
|                                   sizeof (ClutterVertex), | ||||
|                                   sizeof (graphene_point3d_t), | ||||
|                                   vertices_in, | ||||
|                                   sizeof (ClutterVertex4), | ||||
|                                   vertices_tmp, | ||||
| @@ -79,7 +79,7 @@ _clutter_util_fully_transform_vertices (const CoglMatrix *modelview, | ||||
|     { | ||||
|       cogl_matrix_transform_points (modelview, | ||||
|                                     3, | ||||
|                                     sizeof (ClutterVertex), | ||||
|                                     sizeof (graphene_point3d_t), | ||||
|                                     vertices_in, | ||||
|                                     sizeof (ClutterVertex4), | ||||
|                                     vertices_tmp, | ||||
| @@ -97,7 +97,7 @@ _clutter_util_fully_transform_vertices (const CoglMatrix *modelview, | ||||
|   for (i = 0; i < n_vertices; i++) | ||||
|     { | ||||
|       ClutterVertex4 vertex_tmp = vertices_tmp[i]; | ||||
|       ClutterVertex *vertex_out = &vertices_out[i]; | ||||
|       graphene_point3d_t *vertex_out = &vertices_out[i]; | ||||
|       /* Finally translate from OpenGL coords to window coords */ | ||||
|       vertex_out->x = MTX_GL_SCALE_X (vertex_tmp.x, vertex_tmp.w, | ||||
|                                       viewport[2], viewport[0]); | ||||
| @@ -108,9 +108,9 @@ _clutter_util_fully_transform_vertices (const CoglMatrix *modelview, | ||||
|  | ||||
| void | ||||
| _clutter_util_rect_from_rectangle (const cairo_rectangle_int_t *src, | ||||
|                                    ClutterRect                 *dest) | ||||
|                                    graphene_rect_t             *dest) | ||||
| { | ||||
|   *dest = (ClutterRect) { | ||||
|   *dest = (graphene_rect_t) { | ||||
|     .origin = { | ||||
|       .x = src->x, | ||||
|       .y = src->y | ||||
| @@ -123,12 +123,12 @@ _clutter_util_rect_from_rectangle (const cairo_rectangle_int_t *src, | ||||
| } | ||||
|  | ||||
| void | ||||
| _clutter_util_rectangle_int_extents (const  ClutterRect    *src, | ||||
| _clutter_util_rectangle_int_extents (const graphene_rect_t *src, | ||||
|                                      cairo_rectangle_int_t *dest) | ||||
| { | ||||
|   ClutterRect tmp = *src; | ||||
|   graphene_rect_t tmp = *src; | ||||
|  | ||||
|   clutter_rect_clamp_to_pixel (&tmp); | ||||
|   graphene_rect_round_extents (&tmp, &tmp); | ||||
|  | ||||
|   *dest = (cairo_rectangle_int_t) { | ||||
|     .x = tmp.origin.x, | ||||
| @@ -299,48 +299,12 @@ _clutter_util_matrix_skew_yz (ClutterMatrix *matrix, | ||||
|   matrix->zw += matrix->yw * factor; | ||||
| } | ||||
|  | ||||
| static float | ||||
| _clutter_util_vertex_length (const ClutterVertex *vertex) | ||||
| { | ||||
|   return sqrtf (vertex->x * vertex->x + vertex->y * vertex->y + vertex->z * vertex->z); | ||||
| } | ||||
|  | ||||
| static void | ||||
| _clutter_util_vertex_normalize (ClutterVertex *vertex) | ||||
| { | ||||
|   float factor = _clutter_util_vertex_length (vertex); | ||||
|  | ||||
|   if (factor == 0.f) | ||||
|     return; | ||||
|  | ||||
|   vertex->x /= factor; | ||||
|   vertex->y /= factor; | ||||
|   vertex->z /= factor; | ||||
| } | ||||
|  | ||||
| static float | ||||
| _clutter_util_vertex_dot (const ClutterVertex *v1, | ||||
|                           const ClutterVertex *v2) | ||||
| { | ||||
|   return v1->x * v2->x + v1->y * v2->y + v1->z * v2->z; | ||||
| } | ||||
|  | ||||
| static void | ||||
| _clutter_util_vertex_cross (const ClutterVertex *v1, | ||||
|                             const ClutterVertex *v2, | ||||
|                             ClutterVertex       *res) | ||||
| { | ||||
|   res->x = v1->y * v2->z - v2->y * v1->z; | ||||
|   res->y = v1->z * v2->x - v2->z * v1->x; | ||||
|   res->z = v1->x * v2->y - v2->x * v1->y; | ||||
| } | ||||
|  | ||||
| static void | ||||
| _clutter_util_vertex_combine (const ClutterVertex *a, | ||||
|                               const ClutterVertex *b, | ||||
|                               double               ascl, | ||||
|                               double               bscl, | ||||
|                               ClutterVertex       *res) | ||||
| _clutter_util_vertex_combine (const graphene_point3d_t *a, | ||||
|                               const graphene_point3d_t *b, | ||||
|                               double                    ascl, | ||||
|                               double                    bscl, | ||||
|                               graphene_point3d_t       *res) | ||||
| { | ||||
|   res->x = (ascl * a->x) + (bscl * b->x); | ||||
|   res->y = (ascl * a->y) + (bscl * b->y); | ||||
| @@ -388,16 +352,16 @@ _clutter_util_vertex4_interpolate (const ClutterVertex4 *a, | ||||
|  */ | ||||
| gboolean | ||||
| _clutter_util_matrix_decompose (const ClutterMatrix *src, | ||||
|                                 ClutterVertex       *scale_p, | ||||
|                                 graphene_point3d_t  *scale_p, | ||||
|                                 float                shear_p[3], | ||||
|                                 ClutterVertex       *rotate_p, | ||||
|                                 ClutterVertex       *translate_p, | ||||
|                                 graphene_point3d_t  *rotate_p, | ||||
|                                 graphene_point3d_t  *translate_p, | ||||
|                                 ClutterVertex4      *perspective_p) | ||||
| { | ||||
|   CoglMatrix matrix = *src; | ||||
|   CoglMatrix perspective; | ||||
|   ClutterVertex4 vertex_tmp; | ||||
|   ClutterVertex row[3], pdum; | ||||
|   graphene_point3d_t row[3], pdum; | ||||
|   int i, j; | ||||
|  | ||||
| #define XY_SHEAR        0 | ||||
| @@ -485,34 +449,34 @@ _clutter_util_matrix_decompose (const ClutterMatrix *src, | ||||
|     } | ||||
|  | ||||
|   /* compute scale.x and normalize the first row */ | ||||
|   scale_p->x = _clutter_util_vertex_length (&row[0]); | ||||
|   _clutter_util_vertex_normalize (&row[0]); | ||||
|   scale_p->x = graphene_point3d_length (&row[0]); | ||||
|   graphene_point3d_normalize (&row[0], &row[0]); | ||||
|  | ||||
|   /* compute XY shear and make the second row orthogonal to the first */ | ||||
|   shear_p[XY_SHEAR] = _clutter_util_vertex_dot (&row[0], &row[1]); | ||||
|   shear_p[XY_SHEAR] = graphene_point3d_dot (&row[0], &row[1]); | ||||
|   _clutter_util_vertex_combine (&row[1], &row[0], | ||||
|                                 1.0, -shear_p[XY_SHEAR], | ||||
|                                 &row[1]); | ||||
|  | ||||
|   /* compute the Y scale and normalize the second row */ | ||||
|   scale_p->y = _clutter_util_vertex_length (&row[1]); | ||||
|   _clutter_util_vertex_normalize (&row[1]); | ||||
|   scale_p->y = graphene_point3d_length (&row[1]); | ||||
|   graphene_point3d_normalize (&row[1], &row[1]); | ||||
|   shear_p[XY_SHEAR] /= scale_p->y; | ||||
|  | ||||
|   /* compute XZ and YZ shears, orthogonalize the third row */ | ||||
|   shear_p[XZ_SHEAR] = _clutter_util_vertex_dot (&row[0], &row[2]); | ||||
|   shear_p[XZ_SHEAR] = graphene_point3d_dot (&row[0], &row[2]); | ||||
|   _clutter_util_vertex_combine (&row[2], &row[0], | ||||
|                                 1.0, -shear_p[XZ_SHEAR], | ||||
|                                 &row[2]); | ||||
|  | ||||
|   shear_p[YZ_SHEAR] = _clutter_util_vertex_dot (&row[1], &row[2]); | ||||
|   shear_p[YZ_SHEAR] = graphene_point3d_dot (&row[1], &row[2]); | ||||
|   _clutter_util_vertex_combine (&row[2], &row[1], | ||||
|                                 1.0, -shear_p[YZ_SHEAR], | ||||
|                                 &row[2]); | ||||
|  | ||||
|   /* get the Z scale and normalize the third row*/ | ||||
|   scale_p->z = _clutter_util_vertex_length (&row[2]); | ||||
|   _clutter_util_vertex_normalize (&row[2]); | ||||
|   scale_p->z = graphene_point3d_length (&row[2]); | ||||
|   graphene_point3d_normalize (&row[2], &row[2]); | ||||
|   shear_p[XZ_SHEAR] /= scale_p->z; | ||||
|   shear_p[YZ_SHEAR] /= scale_p->z; | ||||
|  | ||||
| @@ -520,8 +484,8 @@ _clutter_util_matrix_decompose (const ClutterMatrix *src, | ||||
|    * check for a coordinate system flip; if the determinant | ||||
|    * is -1, then negate the matrix and scaling factors | ||||
|    */ | ||||
|   _clutter_util_vertex_cross (&row[1], &row[2], &pdum); | ||||
|   if (_clutter_util_vertex_dot (&row[0], &pdum) < 0.f) | ||||
|   graphene_point3d_cross (&row[1], &row[2], &pdum); | ||||
|   if (graphene_point3d_dot (&row[0], &pdum) < 0.f) | ||||
|     { | ||||
|       scale_p->x *= -1.f; | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user