// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_UI_GTK_GTK_FLOATING_CONTAINER_H_ #define CHROME_BROWSER_UI_GTK_GTK_FLOATING_CONTAINER_H_ #pragma once #include #include // A specialized container, which is a cross between a GtkBin and a // GtkFixed. This container dervies from GtkBin and the implementation of // gtk_container_add() is the same: only one GtkWidget can be added through // that interface. The GtkBin portion contains normal content and is given the // same allocation that this container has. // // In addition, any number of widgets can be added through the // gtk_floating_container_add_floating() method, which provides functionality // similar to a GtkFixed. Unlike a GtkFixed, coordinates are not set when you // gtk_fixed_put(). The location of the floating widgets is determined while // running the "set-floating-position" signal, which is emitted during this // container's "size-allocate" handler. // // The "set-floating-position" signal is (semi-)mandatory if you want widgets // placed anywhere other than the origin and should have the following // signature: // // void (*set_floating_position)(GtkFloatingContainer* container, // GtkAllocation* allocation, // gpointer userdata); // // Your handler should, for each floating widget, set the "x" and "y" child // properties. G_BEGIN_DECLS #define GTK_TYPE_FLOATING_CONTAINER \ (gtk_floating_container_get_type()) #define GTK_FLOATING_CONTAINER(obj) \ (G_TYPE_CHECK_INSTANCE_CAST((obj), GTK_TYPE_FLOATING_CONTAINER, \ GtkFloatingContainer)) #define GTK_FLOATING_CONTAINER_CLASS(klass) \ (G_TYPE_CHECK_CLASS_CAST((klass), GTK_TYPE_FLOATING_CONTAINER, \ GtkFloatingContainerClass)) #define GTK_IS_FLOATING_CONTAINER(obj) \ (G_TYPE_CHECK_INSTANCE_TYPE((obj), GTK_TYPE_FLOATING_CONTAINER)) #define GTK_IS_FLOATING_CONTAINER_CLASS(klass) \ (G_TYPE_CHECK_CLASS_TYPE((klass), GTK_TYPE_FLOATING_CONTAINER)) #define GTK_FLOATING_CONTAINER_GET_CLASS(obj) \ (G_TYPE_INSTANCE_GET_CLASS((obj), GTK_TYPE_FLOATING_CONTAINER, \ GtkFloatingContainerClass)) typedef struct _GtkFloatingContainer GtkFloatingContainer; typedef struct _GtkFloatingContainerClass GtkFloatingContainerClass; typedef struct _GtkFloatingContainerChild GtkFloatingContainerChild; struct _GtkFloatingContainer { // Parent class. GtkBin bin; // A GList of all our floating children, in GtkFloatingContainerChild // structs. Owned by the GtkFloatingContainer. GList* floating_children; }; struct _GtkFloatingContainerClass { GtkBinClass parent_class; }; // Internal structure used to associate a widget and its x/y child properties. struct _GtkFloatingContainerChild { GtkWidget* widget; gint x; gint y; }; GType gtk_floating_container_get_type() G_GNUC_CONST; GtkWidget* gtk_floating_container_new(); void gtk_floating_container_add_floating(GtkFloatingContainer* container, GtkWidget* widget); // Use gtk_container_remove to remove all widgets; both widgets added with // gtk_container_add() and gtk_floating_container_add_floating(). G_END_DECLS #endif // CHROME_BROWSER_UI_GTK_GTK_FLOATING_CONTAINER_H_