Panel Manager ported to Gdlmm-1.0

This commit is contained in:
Michael R. Fisher 2011-10-16 01:43:03 -05:00 committed by Ichthyostega
parent 56eaf80c4b
commit eb4cdcd975
4 changed files with 27 additions and 45 deletions

View file

@ -88,7 +88,7 @@ void
GtkLumiera::main (int argc, char *argv[]) GtkLumiera::main (int argc, char *argv[])
{ {
Glib::thread_init(); Glib::thread_init();
Gdl::init();
Main kit(argc, argv); Main kit(argc, argv);
Glib::set_application_name (getAppTitle()); Glib::set_application_name (getAppTitle());

View file

@ -31,6 +31,7 @@
#include "gui/gtk-lumiera.hpp" #include "gui/gtk-lumiera.hpp"
#include "gui/widgets/panel-bar.hpp" #include "gui/widgets/panel-bar.hpp"
#include <gdlmm.h>
#include <gdl/gdl-dock-item.h> #include <gdl/gdl-dock-item.h>
namespace gui { namespace gui {

View file

@ -46,23 +46,16 @@ unsigned short PanelManager::panelID = 0;
PanelManager::PanelManager(WorkspaceWindow &workspace_window) : PanelManager::PanelManager(WorkspaceWindow &workspace_window) :
workspaceWindow(workspace_window), workspaceWindow(workspace_window),
dock(NULL), dock(),
dockBar(NULL), dockBar(dock),
dockLayout(NULL) dockLayout()
{ {
dockLayout = Gdl::DockLayout::create(dock);
memset(&dockPlaceholders, 0, sizeof(dockPlaceholders)); memset(&dockPlaceholders, 0, sizeof(dockPlaceholders));
} }
PanelManager::~PanelManager() PanelManager::~PanelManager()
{ {
if(dock)
g_object_unref(dock);
if(dockBar)
g_object_unref(dockBar);
if(dockLayout)
g_object_unref(dockLayout);
for(int i = 0; i < 4; i++) for(int i = 0; i < 4; i++)
if(dockPlaceholders[i]) if(dockPlaceholders[i])
@ -74,28 +67,17 @@ PanelManager::~PanelManager()
void void
PanelManager::setup_dock() PanelManager::setup_dock()
{ {
REQUIRE(dock == NULL);
dock = GDL_DOCK(gdl_dock_new());
ENSURE(dock);
REQUIRE(dockBar == NULL);
dockBar = GDL_DOCK_BAR(gdl_dock_bar_new(dock));
ENSURE(dockBar);
REQUIRE(dockLayout == NULL);
dockLayout = GDL_DOCK_LAYOUT(gdl_dock_layout_new(dock));
ENSURE(dockLayout);
REQUIRE(dockPlaceholders[0] == NULL && dockPlaceholders[1] == NULL && REQUIRE(dockPlaceholders[0] == NULL && dockPlaceholders[1] == NULL &&
dockPlaceholders[2] == NULL && dockPlaceholders[3] == NULL); dockPlaceholders[2] == NULL && dockPlaceholders[3] == NULL);
dockPlaceholders[0] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new( dockPlaceholders[0] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new(
"ph1", GDL_DOCK_OBJECT(dock), GDL_DOCK_TOP, FALSE)); "ph1", GDL_DOCK_OBJECT(dock.gobj()), GDL_DOCK_TOP, FALSE));
dockPlaceholders[1] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new( dockPlaceholders[1] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new(
"ph2", GDL_DOCK_OBJECT(dock), GDL_DOCK_BOTTOM, FALSE)); "ph2", GDL_DOCK_OBJECT(dock.gobj()), GDL_DOCK_BOTTOM, FALSE));
dockPlaceholders[2] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new( dockPlaceholders[2] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new(
"ph3", GDL_DOCK_OBJECT(dock), GDL_DOCK_LEFT, FALSE)); "ph3", GDL_DOCK_OBJECT(dock.gobj()), GDL_DOCK_LEFT, FALSE));
dockPlaceholders[3] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new( dockPlaceholders[3] = GDL_DOCK_PLACEHOLDER(gdl_dock_placeholder_new(
"ph4", GDL_DOCK_OBJECT(dock), GDL_DOCK_RIGHT, FALSE)); "ph4", GDL_DOCK_OBJECT(dock.gobj()), GDL_DOCK_RIGHT, FALSE));
ENSURE(dockPlaceholders[0] && dockPlaceholders[1] && ENSURE(dockPlaceholders[0] && dockPlaceholders[1] &&
dockPlaceholders[2] && dockPlaceholders[3]); dockPlaceholders[2] && dockPlaceholders[3]);
@ -103,17 +85,15 @@ PanelManager::setup_dock()
} }
GdlDock* GdlDock*
PanelManager::get_dock() const PanelManager::get_dock()
{ {
ENSURE(dock); return dock.gobj();
return dock;
} }
GdlDockBar* GdlDockBar*
PanelManager::get_dock_bar() const PanelManager::get_dock_bar()
{ {
ENSURE(dockBar); return dockBar.gobj();
return dockBar;
} }
WorkspaceWindow& WorkspaceWindow&
@ -146,7 +126,8 @@ PanelManager::show_panel(const int description_index)
panels::Panel *new_panel = create_panel_by_index(description_index); panels::Panel *new_panel = create_panel_by_index(description_index);
// Dock the item // Dock the item
gdl_dock_add_item(dock, new_panel->get_dock_item(), TODO("Port to Gdlmm.");
gdl_dock_add_item(dock.gobj(), new_panel->get_dock_item(),
GDL_DOCK_FLOATING); GDL_DOCK_FLOATING);
} }
@ -226,11 +207,11 @@ PanelManager::create_panels()
panels::Panel* timelinePanel = panels::Panel* timelinePanel =
create_panel_by_name("TimelinePanel"); create_panel_by_name("TimelinePanel");
gdl_dock_add_item(dock, gdl_dock_add_item(dock.gobj(),
assetsPanel->get_dock_item(), GDL_DOCK_LEFT); assetsPanel->get_dock_item(), GDL_DOCK_LEFT);
gdl_dock_add_item(dock, gdl_dock_add_item(dock.gobj(),
timelinePanel->get_dock_item(), GDL_DOCK_BOTTOM); timelinePanel->get_dock_item(), GDL_DOCK_BOTTOM);
gdl_dock_add_item(dock, gdl_dock_add_item(dock.gobj(),
viewerPanel->get_dock_item(), GDL_DOCK_RIGHT); viewerPanel->get_dock_item(), GDL_DOCK_RIGHT);
} }

View file

@ -30,7 +30,7 @@
#include "gui/panels/panel.hpp" #include "gui/panels/panel.hpp"
#include <gdl/gdl.h> #include <gdlmm.h>
#include <typeinfo> #include <typeinfo>
@ -70,13 +70,13 @@ public:
* Gets a pointer to the dock object. * Gets a pointer to the dock object.
* @remarks Note that this must not be called before setup_dock. * @remarks Note that this must not be called before setup_dock.
*/ */
GdlDock* get_dock() const; GdlDock* get_dock();
/** /**
* Gets a pointer to the dock bar. * Gets a pointer to the dock bar.
* @remarks Note that this must not be called before setup_dock. * @remarks Note that this must not be called before setup_dock.
*/ */
GdlDockBar* get_dock_bar() const; GdlDockBar* get_dock_bar();
/** /**
* Returns a reference to the owner workspace window. * Returns a reference to the owner workspace window.
@ -204,19 +204,19 @@ private:
* The pointer to GDL dock widget. * The pointer to GDL dock widget.
* @remarks This value is NULL until setup_dock has been called. * @remarks This value is NULL until setup_dock has been called.
*/ */
GdlDock *dock; Gdl::Dock dock;
/** /**
* The pointer to GDL dock bar widget. * The pointer to GDL dock bar widget.
* @remarks This value is NULL until setup_dock has been called. * @remarks This value is NULL until setup_dock has been called.
*/ */
GdlDockBar *dockBar; Gdl::DockBar dockBar;
/** /**
* The pointer to GDL dock layout object. * The pointer to GDL dock layout object.
* @remarks This value is NULL until setup_dock has been called. * @remarks This value is NULL until setup_dock has been called.
*/ */
GdlDockLayout *dockLayout; Glib::RefPtr<Gdl::DockLayout> dockLayout;
/** /**
* Pointers to the 4 root place holders. * Pointers to the 4 root place holders.