app: Keep GimpDocks in GtkPaneds in GimpDockColumns
Use the new GimpPanedBox to make the space for GimpDocks in GimpDockColumns manually distributable by the use of GtkPaneds.
This commit is contained in:
@ -160,7 +160,7 @@ gimp_ui_configurer_move_docks_to_columns (GimpUIConfigurer *ui_configurer,
|
|||||||
*/
|
*/
|
||||||
g_object_ref (dock);
|
g_object_ref (dock);
|
||||||
gtk_container_remove (GTK_CONTAINER (dock_window), GTK_WIDGET (dock));
|
gtk_container_remove (GTK_CONTAINER (dock_window), GTK_WIDGET (dock));
|
||||||
gimp_dock_columns_add_dock (dock_columns, dock);
|
gimp_dock_columns_add_dock (dock_columns, dock, -1);
|
||||||
g_object_unref (dock);
|
g_object_unref (dock);
|
||||||
|
|
||||||
/* Queue for removal from the dialog factory. (We can't remove
|
/* Queue for removal from the dialog factory. (We can't remove
|
||||||
|
@ -26,14 +26,22 @@
|
|||||||
|
|
||||||
#include "gimpdock.h"
|
#include "gimpdock.h"
|
||||||
#include "gimpdockcolumns.h"
|
#include "gimpdockcolumns.h"
|
||||||
|
#include "gimppanedbox.h"
|
||||||
|
|
||||||
|
|
||||||
struct _GimpDockColumnsPrivate
|
struct _GimpDockColumnsPrivate
|
||||||
{
|
{
|
||||||
int dummy;
|
GList *docks;
|
||||||
|
|
||||||
|
GtkWidget *paned_hbox;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
static gboolean gimp_dock_columns_dropped_cb (GimpDockSeparator *separator,
|
||||||
|
GtkWidget *source,
|
||||||
|
gpointer data);
|
||||||
|
|
||||||
|
|
||||||
G_DEFINE_TYPE (GimpDockColumns, gimp_dock_columns, GTK_TYPE_HBOX)
|
G_DEFINE_TYPE (GimpDockColumns, gimp_dock_columns, GTK_TYPE_HBOX)
|
||||||
|
|
||||||
#define parent_class gimp_dock_columns_parent_class
|
#define parent_class gimp_dock_columns_parent_class
|
||||||
@ -51,15 +59,64 @@ gimp_dock_columns_init (GimpDockColumns *dock_columns)
|
|||||||
dock_columns->p = G_TYPE_INSTANCE_GET_PRIVATE (dock_columns,
|
dock_columns->p = G_TYPE_INSTANCE_GET_PRIVATE (dock_columns,
|
||||||
GIMP_TYPE_DOCK_COLUMNS,
|
GIMP_TYPE_DOCK_COLUMNS,
|
||||||
GimpDockColumnsPrivate);
|
GimpDockColumnsPrivate);
|
||||||
|
|
||||||
|
dock_columns->p->paned_hbox = gimp_paned_box_new (FALSE, 0,
|
||||||
|
GTK_ORIENTATION_HORIZONTAL);
|
||||||
|
gimp_paned_box_set_dropped_cb (GIMP_PANED_BOX (dock_columns->p->paned_hbox),
|
||||||
|
gimp_dock_columns_dropped_cb,
|
||||||
|
dock_columns);
|
||||||
|
gtk_container_add (GTK_CONTAINER (dock_columns), dock_columns->p->paned_hbox);
|
||||||
|
gtk_widget_show (dock_columns->p->paned_hbox);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gimp_dock_columns_dropped_cb (GimpDockSeparator *separator,
|
||||||
|
GtkWidget *source,
|
||||||
|
gpointer data)
|
||||||
|
{
|
||||||
|
g_printerr ("%s: WiP: Will create a new column soon!\n", G_STRFUNC);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gimp_dock_columns_add_dock:
|
||||||
|
* @dock_columns:
|
||||||
|
* @dock:
|
||||||
|
*
|
||||||
|
* Add a dock, added to a horizontal GimpPanedBox.
|
||||||
|
**/
|
||||||
void
|
void
|
||||||
gimp_dock_columns_add_dock (GimpDockColumns *dock_columns,
|
gimp_dock_columns_add_dock (GimpDockColumns *dock_columns,
|
||||||
|
GimpDock *dock,
|
||||||
|
gint index)
|
||||||
|
{
|
||||||
|
g_return_if_fail (GIMP_IS_DOCK_COLUMNS (dock_columns));
|
||||||
|
g_return_if_fail (GIMP_IS_DOCK (dock));
|
||||||
|
|
||||||
|
dock_columns->p->docks = g_list_prepend (dock_columns->p->docks, dock);
|
||||||
|
|
||||||
|
gimp_paned_box_add_widget (GIMP_PANED_BOX (dock_columns->p->paned_hbox),
|
||||||
|
GTK_WIDGET (dock),
|
||||||
|
index);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
gimp_dock_columns_remove_dock (GimpDockColumns *dock_columns,
|
||||||
GimpDock *dock)
|
GimpDock *dock)
|
||||||
{
|
{
|
||||||
g_return_if_fail (GIMP_IS_DOCK_COLUMNS (dock_columns));
|
g_return_if_fail (GIMP_IS_DOCK_COLUMNS (dock_columns));
|
||||||
g_return_if_fail (GIMP_IS_DOCK (dock));
|
g_return_if_fail (GIMP_IS_DOCK (dock));
|
||||||
|
|
||||||
gtk_box_pack_start (GTK_BOX (dock_columns), GTK_WIDGET (dock),
|
dock_columns->p->docks = g_list_remove (dock_columns->p->docks, dock);
|
||||||
TRUE, TRUE, 0);
|
|
||||||
|
gimp_paned_box_remove_widget (GIMP_PANED_BOX (dock_columns->p->paned_hbox),
|
||||||
|
GTK_WIDGET (dock));
|
||||||
|
}
|
||||||
|
|
||||||
|
GList *
|
||||||
|
gimp_dock_columns_get_docks (GimpDockColumns *dock_columns)
|
||||||
|
{
|
||||||
|
return g_list_copy (dock_columns->p->docks);
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,11 @@ struct _GimpDockColumnsClass
|
|||||||
|
|
||||||
GType gimp_dock_columns_get_type (void) G_GNUC_CONST;
|
GType gimp_dock_columns_get_type (void) G_GNUC_CONST;
|
||||||
void gimp_dock_columns_add_dock (GimpDockColumns *dock_columns,
|
void gimp_dock_columns_add_dock (GimpDockColumns *dock_columns,
|
||||||
|
GimpDock *dock,
|
||||||
|
gint index);
|
||||||
|
void gimp_dock_columns_remove_dock (GimpDockColumns *dock_columns,
|
||||||
GimpDock *dock);
|
GimpDock *dock);
|
||||||
|
GList * gimp_dock_columns_get_docks (GimpDockColumns *dock_columns);
|
||||||
|
|
||||||
|
|
||||||
#endif /* __GIMP_DOCK_COLUMNS_H__ */
|
#endif /* __GIMP_DOCK_COLUMNS_H__ */
|
||||||
|
Reference in New Issue
Block a user