Recreated test layout in new space architecture

This commit is contained in:
Jack Andersen 2015-12-11 14:37:32 -10:00
parent d3af294056
commit 0dad45e894
6 changed files with 115 additions and 69 deletions

View File

@ -1,6 +1,8 @@
include_directories(${CMAKE_CURRENT_SOURCE_DIR})
add_subdirectory(locale)
atdna(atdna_Space.cpp Space.hpp)
set(SPACE_HEADERS
ResourceOutliner/ResourceOutliner.hpp)
@ -9,7 +11,7 @@ set(SPACE_SOURCES
add_executable(rude WIN32
main.cpp
Space.hpp Space.cpp
Space.hpp Space.cpp atdna_Space.cpp
${SPACE_HEADERS} ${SPACE_SOURCES}
ViewManager.hpp ViewManager.cpp)

View File

@ -6,15 +6,13 @@
namespace RUDE
{
struct ResourceOutlinerState : SpaceState
{
DECL_YAML
};
class ResourceOutliner : public Space
{
ResourceOutlinerState m_state;
SpaceState& spaceState() {return m_state;}
struct State : SpaceState
{
DECL_YAML
} m_state;
SpaceState* spaceState() {return &m_state;}
};
}

View File

@ -1,7 +1,19 @@
#include "Space.hpp"
#include "ViewManager.hpp"
namespace RUDE
{
Specter::Space* Space::buildSpace(Specter::ViewResources& res)
{
m_space.reset(new Specter::Space(res, m_vm.rootView(), Specter::Toolbar::Position::Bottom));
return m_space.get();
}
Specter::View* SplitSpace::buildContent(Specter::ViewResources& res)
{
m_splitView.reset(new Specter::SplitView(res, m_vm.rootView(), Specter::SplitView::Axis::Horizontal));
return m_splitView.get();
}
}

View File

@ -2,7 +2,7 @@
#define RUDE_SPACE_HPP
#include <Athena/DNAYaml.hpp>
#include <Specter/Space.hpp>
#include <Specter/Specter.hpp>
namespace Specter
{
@ -15,44 +15,92 @@ namespace RUDE
{
class ViewManager;
struct SpaceState : Athena::io::DNAYaml<Athena::BigEndian> {};
struct SpaceState : Athena::io::DNAYaml<Athena::BigEndian> {Delete _d;};
class Space
{
std::unique_ptr<Specter::Space> m_space;
public:
enum class Class
{
None,
Split,
SplitSpace,
TestSpace,
ResourceOutliner,
};
protected:
friend class ViewManager;
ViewManager& m_vm;
Class m_class = Class::None;
std::unique_ptr<Specter::Space> m_space;
Space(ViewManager& vm, Class cls) : m_vm(vm), m_class(cls) {}
Space(ViewManager& vm, Class cls, Athena::io::IStreamReader& r) : m_vm(vm), m_class(cls) {}
Space(ViewManager& vm, Class cls, Athena::io::IStreamReader& r) : m_vm(vm), m_class(cls)
{if (spaceState()) spaceState()->read(r);}
void writeState(Athena::io::IStreamWriter& w) const;
/* Allows common Space code to access DNA-encoded state */
virtual SpaceState& spaceState()=0;
virtual SpaceState* spaceState() {return nullptr;}
/* Structural control */
virtual bool usesToolbar() const {return false;}
virtual void buildToolbar(Specter::ViewResources& res, Specter::Toolbar& tb) {}
virtual Specter::View* buildContent(Specter::ViewResources& res)=0;
public:
Specter::Space* buildSpace(Specter::ViewResources& res);
};
class Split : public Space
class SplitSpace : public Space
{
std::unique_ptr<Specter::SplitView> m_split;
friend class ViewManager;
std::unique_ptr<Specter::SplitView> m_splitView;
struct State : SpaceState
{
DECL_YAML
Value<float> m_split;
} m_state;
SpaceState& spaceState() {return m_state;}
SpaceState* spaceState() {return &m_state;}
public:
SplitSpace(ViewManager& vm)
: Space(vm, Class::SplitSpace) {}
Specter::View* buildContent(Specter::ViewResources& res);
};
class TestSpace : public Space
{
std::unique_ptr<Specter::Button> m_button;
std::unique_ptr<Specter::MultiLineTextView> m_textView;
std::string m_contentStr;
std::string m_buttonStr;
Specter::IButtonBinding* m_binding;
public:
TestSpace(ViewManager& vm, const std::string& content, const std::string& button,
Specter::IButtonBinding* binding)
: Space(vm, Class::TestSpace), m_contentStr(content), m_buttonStr(button), m_binding(binding)
{}
struct State : SpaceState
{
DECL_YAML
} m_state;
SpaceState* spaceState() {return &m_state;}
bool usesToolbar() const {return true;}
void buildToolbar(Specter::ViewResources& res, Specter::Toolbar& tb)
{
m_button.reset(new Specter::Button(res, tb, m_binding, m_buttonStr));
tb.push_back(m_button.get());
}
Specter::View* buildContent(Specter::ViewResources& res)
{
m_textView.reset(new Specter::MultiLineTextView(res, *m_space, res.m_heading14));
m_textView->setBackground(res.themeData().viewportBackground());
m_textView->typesetGlyphs(m_contentStr, res.themeData().uiText());
return m_textView.get();
}
};
}

View File

@ -1,44 +1,29 @@
#include "ViewManager.hpp"
#include "Specter/Control.hpp"
#include "Specter/Space.hpp"
using YAMLNode = Athena::io::YAMLNode;
namespace RUDE
{
Specter::View* ViewManager::BuildSpaceViews(RUDE::Space* space)
{
Specter::Space* sspace = space->buildSpace(m_viewResources);
Specter::View* sview = space->buildContent(m_viewResources);
sspace->setContentView(sview);
if (space->usesToolbar())
space->buildToolbar(m_viewResources, sspace->toolbar());
return sspace;
}
void ViewManager::SetupRootView()
{
m_rootView.reset(new Specter::RootView(*this, m_viewResources, m_mainWindow.get()));
m_splitView.reset(new Specter::SplitView(m_viewResources, *m_rootView, Specter::SplitView::Axis::Horizontal));
m_rootView->setContentView(m_splitView.get());
m_space1.reset(new Specter::Space(m_viewResources, *m_splitView, Specter::Toolbar::Position::Top));
m_butt1.reset(new Specter::Button(m_viewResources, m_space1->toolbar(),
&m_setTo1, "Hello Button"));
m_space1->toolbar().push_back(m_butt1.get());
m_space2.reset(new Specter::Space(m_viewResources, *m_splitView, Specter::Toolbar::Position::Bottom));
m_butt2.reset(new Specter::Button(m_viewResources, m_space2->toolbar(),
&m_setTo2, "こんにちはボタン"));
m_space2->toolbar().push_back(m_butt2.get());
m_splitView->setContentView(0, m_space1.get());
m_splitView->setContentView(1, m_space2.get());
m_rootView->setBackground(Zeus::CColor::skGrey);
m_textView1.reset(new Specter::MultiLineTextView(m_viewResources, *m_space1, m_viewResources.m_heading18));
m_space1->setContentView(m_textView1.get());
m_textView2.reset(new Specter::MultiLineTextView(m_viewResources, *m_space2, m_viewResources.m_heading18));
m_space2->setContentView(m_textView2.get());
m_textView1->typesetGlyphs("Hello, World!\n\n", m_viewResources.themeData().uiText());
m_textView2->typesetGlyphs("こんにちは世界!\n\n", m_viewResources.themeData().uiText());
m_textView1->setBackground(m_viewResources.themeData().viewportBackground());
m_textView2->setBackground(m_viewResources.themeData().viewportBackground());
m_rootView->setContentView(m_split.buildContent(m_viewResources));
m_split.m_splitView->setContentView(0, BuildSpaceViews(&m_space1));
m_split.m_splitView->setContentView(1, BuildSpaceViews(&m_space2));
m_rootView->updateSize();
}

View File

@ -1,7 +1,6 @@
#ifndef RUDE_VIEW_MANAGER_HPP
#define RUDE_VIEW_MANAGER_HPP
#include <Specter/Specter.hpp>
#include <HECL/CVarManager.hpp>
#include "Space.hpp"
@ -15,36 +14,15 @@ class ViewManager : Specter::IViewManager
Specter::ViewResources m_viewResources;
std::unique_ptr<boo::IWindow> m_mainWindow;
std::unique_ptr<Specter::RootView> m_rootView;
std::unique_ptr<Specter::SplitView> m_splitView;
std::unique_ptr<Specter::Space> m_space1;
std::unique_ptr<Specter::Button> m_butt1;
std::unique_ptr<Specter::MultiLineTextView> m_textView1;
std::unique_ptr<Specter::Space> m_space2;
std::unique_ptr<Specter::Button> m_butt2;
std::unique_ptr<Specter::MultiLineTextView> m_textView2;
HECL::CVar* m_cvPixelFactor;
bool m_updatePf = false;
float m_reqPf;
Specter::View* BuildSpaceViews(RUDE::Space* space);
void SetupRootView();
public:
ViewManager(HECL::Runtime::FileStoreManager& fileMgr, HECL::CVarManager& cvarMgr)
: m_cvarManager(cvarMgr), m_fontCache(fileMgr), m_setTo1(*this), m_setTo2(*this) {}
Specter::RootView& rootView() const {return *m_rootView;}
void RequestPixelFactor(float pf)
{
m_reqPf = pf;
m_updatePf = true;
}
void init(boo::IApplication* app);
bool proc();
void stop();
struct SetTo1 : Specter::IButtonBinding
{
ViewManager& m_vm;
@ -76,6 +54,29 @@ public:
}
};
SetTo2 m_setTo2;
SplitSpace m_split;
TestSpace m_space1;
TestSpace m_space2;
ViewManager(HECL::Runtime::FileStoreManager& fileMgr, HECL::CVarManager& cvarMgr)
: m_cvarManager(cvarMgr), m_fontCache(fileMgr),
m_setTo1(*this), m_setTo2(*this),
m_split(*this),
m_space1(*this, "Hello, World!\n\n", "Hello Button", &m_setTo1),
m_space2(*this, "こんにちは世界!\n\n", "こんにちはボタン", &m_setTo2)
{}
Specter::RootView& rootView() const {return *m_rootView;}
void RequestPixelFactor(float pf)
{
m_reqPf = pf;
m_updatePf = true;
}
void init(boo::IApplication* app);
bool proc();
void stop();
};
}