Panel Manager ported to Gdlmm-1.0
This commit is contained in:
parent
56eaf80c4b
commit
eb4cdcd975
4 changed files with 27 additions and 45 deletions
|
|
@ -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());
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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.
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue