More conservative resource use in Table

This commit is contained in:
Jack Andersen 2016-01-07 14:06:21 -10:00
parent 329be27c7d
commit 24917f2367
18 changed files with 403 additions and 385 deletions

View File

@ -23,9 +23,7 @@ private:
std::unique_ptr<TextView> m_text; std::unique_ptr<TextView> m_text;
SolidShaderVert m_verts[28]; SolidShaderVert m_verts[28];
boo::IGraphicsBufferD* m_bVertsBuf = nullptr; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_bVtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_bShaderBinding = nullptr;
RectangleConstraint m_constraint; RectangleConstraint m_constraint;
int m_nomWidth, m_nomHeight; int m_nomWidth, m_nomHeight;

View File

@ -46,9 +46,7 @@ class ModalWindow : public View
void setFillVerts(int width, int height, float pf); void setFillVerts(int width, int height, float pf);
void setFillColors(float t); void setFillColors(float t);
boo::IGraphicsBufferD* m_vertsBuf; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_vertsVtxFmt; /* OpenGL only */
boo::IShaderDataBinding* m_vertsShaderBinding;
boo::GraphicsDataToken m_windowGfxData; boo::GraphicsDataToken m_windowGfxData;

View File

@ -32,9 +32,7 @@ private:
bool m_drawSideButtons = false; bool m_drawSideButtons = false;
SolidShaderVert m_verts[4]; SolidShaderVert m_verts[4];
boo::IGraphicsBufferD* m_vertsBuf = nullptr; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_vtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_shaderBinding = nullptr;
enum class SideButtonState enum class SideButtonState
{ {

View File

@ -60,9 +60,8 @@ private:
m_splitVerts[3].m_uv.assign(1, 0); m_splitVerts[3].m_uv.assign(1, 0);
} }
boo::IGraphicsBufferD* m_splitVertsBuf; VertexBufferBinding m_splitVertsBinding;
boo::IVertexFormat* m_splitVtxFmt; /* OpenGL only */
boo::IShaderDataBinding* m_splitShaderBinding;
public: public:
SplitView(ViewResources& res, View& parentView, Axis axis, int clearanceA=-1, int clearanceB=-1); SplitView(ViewResources& res, View& parentView, Axis axis, int clearanceA=-1, int clearanceB=-1);
View* setContentView(int slot, View* view); View* setContentView(int slot, View* view);

View File

@ -4,6 +4,7 @@
#include "View.hpp" #include "View.hpp"
#include "ScrollView.hpp" #include "ScrollView.hpp"
#include "TextView.hpp" #include "TextView.hpp"
#include <array>
namespace Specter namespace Specter
{ {
@ -53,11 +54,15 @@ class Table : public View
std::unique_ptr<TextView> m_text; std::unique_ptr<TextView> m_text;
size_t m_c, m_r; size_t m_c, m_r;
boo::SWindowRect m_scissorRect; boo::SWindowRect m_scissorRect;
CellView(Table& t, ViewResources& res, size_t c, size_t r); uint64_t m_textHash = 0;
CellView(Table& t, ViewResources& res);
bool m_selected = false; bool m_selected = false;
void select(); void select();
void deselect(); void deselect();
void reset();
bool reset(size_t c);
bool reset(size_t c, size_t r);
void mouseDown(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey); void mouseDown(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey);
void mouseUp(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey); void mouseUp(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey);
@ -68,16 +73,18 @@ class Table : public View
void draw(boo::IGraphicsCommandQueue* gfxQ); void draw(boo::IGraphicsCommandQueue* gfxQ);
}; };
std::vector<ViewChild<std::unique_ptr<CellView>>> m_headerViews; std::vector<ViewChild<std::unique_ptr<CellView>>> m_headerViews;
std::vector<std::vector<ViewChild<std::unique_ptr<CellView>>>> m_cellViews; using ColumnPool = std::array<std::array<ViewChild<std::unique_ptr<CellView>>, SPECTER_TABLE_MAX_ROWS>, 2>;
std::vector<ColumnPool> m_cellPools;
size_t m_ensuredRows = 0;
std::vector<ColumnPool>& ensureCellPools(size_t rows, size_t cols, ViewResources& res);
size_t m_activePool = -1;
bool m_header = false; bool m_header = false;
std::vector<boo::SWindowRect> m_hCellRects; std::vector<boo::SWindowRect> m_hCellRects;
size_t m_hDraggingIdx = 0; size_t m_hDraggingIdx = 0;
std::unique_ptr<SolidShaderVert[]> m_hVerts; std::unique_ptr<SolidShaderVert[]> m_hVerts;
boo::IGraphicsBufferD* m_hVertsBuf = nullptr; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_hVtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_hShaderBinding = nullptr;
void _setHeaderVerts(const boo::SWindowRect& rect); void _setHeaderVerts(const boo::SWindowRect& rect);
std::vector<boo::SWindowRect> getCellRects(const boo::SWindowRect& tableRect) const; std::vector<boo::SWindowRect> getCellRects(const boo::SWindowRect& tableRect) const;
@ -89,9 +96,7 @@ class Table : public View
Table& m_t; Table& m_t;
std::unique_ptr<SolidShaderVert[]> m_verts; std::unique_ptr<SolidShaderVert[]> m_verts;
boo::IGraphicsBufferD* m_vertsBuf = nullptr; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_vtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_shaderBinding = nullptr;
size_t m_visibleStart = 0; size_t m_visibleStart = 0;
size_t m_visibleRows = 0; size_t m_visibleRows = 0;
boo::SWindowRect m_scissorRect; boo::SWindowRect m_scissorRect;
@ -111,6 +116,8 @@ class Table : public View
bool m_headerNeedsUpdate = false; bool m_headerNeedsUpdate = false;
bool m_inSelectRow = false; bool m_inSelectRow = false;
void _updateData();
public: public:
Table(ViewResources& res, View& parentView, ITableDataBinding* data, Table(ViewResources& res, View& parentView, ITableDataBinding* data,

View File

@ -19,9 +19,7 @@ class TextField : public ITextInputView
std::unique_ptr<TextView> m_errText; std::unique_ptr<TextView> m_errText;
SolidShaderVert m_verts[41]; SolidShaderVert m_verts[41];
boo::IGraphicsBufferD* m_bVertsBuf = nullptr; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_bVtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_bShaderBinding = nullptr;
int m_nomWidth = 0; int m_nomWidth = 0;
int m_nomHeight = 0; int m_nomHeight = 0;

View File

@ -84,9 +84,8 @@ private:
m_tbVerts[9].m_uv.assign(1, 0); m_tbVerts[9].m_uv.assign(1, 0);
} }
boo::IGraphicsBufferD* m_tbVertsBuf; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_tbVtxFmt; /* OpenGL only */
boo::IShaderDataBinding* m_tbShaderBinding;
public: public:
Toolbar(ViewResources& res, View& parentView, Position toolbarPos); Toolbar(ViewResources& res, View& parentView, Position toolbarPos);
void mouseDown(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey); void mouseDown(const boo::SWindowCoord&, boo::EMouseButton, boo::EModifierKey);

View File

@ -17,9 +17,7 @@ class Tooltip : public View
void setVerts(int width, int height, float pf); void setVerts(int width, int height, float pf);
boo::IGraphicsBufferD* m_ttVertsBuf; VertexBufferBinding m_vertsBinding;
boo::IVertexFormat* m_ttVtxFmt; /* OpenGL only */
boo::IShaderDataBinding* m_ttShaderBinding;
std::string m_titleStr; std::string m_titleStr;
std::unique_ptr<TextView> m_title; std::unique_ptr<TextView> m_title;

View File

@ -90,13 +90,24 @@ public:
Zeus::CVector3f m_pos; Zeus::CVector3f m_pos;
Zeus::CVector2f m_uv; Zeus::CVector2f m_uv;
}; };
struct VertexBufferBinding
{
boo::IGraphicsBufferD* m_vertsBuf = nullptr;
boo::IVertexFormat* m_vtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_shaderBinding = nullptr;
void initSolid(ViewResources& res, size_t count, boo::IGraphicsBuffer* viewBlockBuf);
void initTex(ViewResources& res, size_t count, boo::IGraphicsBuffer* viewBlockBuf, boo::ITexture* texture);
void load(const void* data, size_t sz) {m_vertsBuf->load(data, sz);}
operator boo::IShaderDataBinding*() {return m_shaderBinding;}
};
private: private:
RootView& m_rootView; RootView& m_rootView;
View& m_parentView; View& m_parentView;
boo::SWindowRect m_subRect; boo::SWindowRect m_subRect;
boo::IGraphicsBufferD* m_bgVertBuf; VertexBufferBinding m_bgVertsBinding;
boo::IVertexFormat* m_bgVtxFmt = nullptr; /* OpenGL only */
boo::IShaderDataBinding* m_bgShaderBinding;
SolidShaderVert m_bgRect[4]; SolidShaderVert m_bgRect[4];
boo::GraphicsDataToken m_gfxData; boo::GraphicsDataToken m_gfxData;
@ -176,7 +187,7 @@ public:
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_bgRect[i].m_color = color; m_bgRect[i].m_color = color;
m_bgVertBuf->load(&m_bgRect, sizeof(SolidShaderVert) * 4); m_bgVertsBinding.load(m_bgRect, sizeof(m_bgRect));
} }
virtual void setMultiplyColor(const Zeus::CColor& color) virtual void setMultiplyColor(const Zeus::CColor& color)

View File

@ -23,29 +23,7 @@ Button::Button(ViewResources& res, View& parentView,
: Control(res, parentView, controlBinding), : Control(res, parentView, controlBinding),
m_style(style), m_textColor(textColor), m_textStr(text), m_constraint(constraint) m_style(style), m_textColor(textColor), m_textStr(text), m_constraint(constraint)
{ {
m_bVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), 28); m_vertsBinding.initSolid(res, 28, m_viewVertBlockBuf);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_bVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_bVertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_bVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_bShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_bVtxFmt, m_bVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_bShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_texVtxFmt,
m_bVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
commitResources(res); commitResources(res);
if (style == Style::Block) if (style == Style::Block)
@ -57,13 +35,13 @@ Button::Button(ViewResources& res, View& parentView,
m_verts[4].m_color = res.themeData().button2Inactive(); m_verts[4].m_color = res.themeData().button2Inactive();
for (int i=5 ; i<28 ; ++i) for (int i=5 ; i<28 ; ++i)
m_verts[i].m_color = res.themeData().button2Inactive(); m_verts[i].m_color = res.themeData().button2Inactive();
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = Zeus::CColor::skClear; m_verts[i].m_color = Zeus::CColor::skClear;
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
} }
m_text.reset(new TextView(res, *this, res.m_mainFont, TextView::Alignment::Center)); m_text.reset(new TextView(res, *this, res.m_mainFont, TextView::Alignment::Center));
@ -122,7 +100,7 @@ void Button::setText(const std::string& text, const Zeus::CColor& textColor)
m_verts[26].m_pos.assign(width+1, 1, 0); m_verts[26].m_pos.assign(width+1, 1, 0);
m_verts[27].m_pos.assign(width+1, 0, 0); m_verts[27].m_pos.assign(width+1, 0, 0);
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
@ -133,7 +111,7 @@ void Button::setText(const std::string& text, const Zeus::CColor& textColor)
m_verts[2].m_pos.assign(width, -1*pf, 0); m_verts[2].m_pos.assign(width, -1*pf, 0);
m_verts[3].m_pos.assign(width, -2*pf, 0); m_verts[3].m_pos.assign(width, -2*pf, 0);
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
} }
m_nomWidth = width; m_nomWidth = width;
@ -155,13 +133,13 @@ void Button::setInactive()
m_verts[2].m_color = rootView().themeData().button1Inactive(); m_verts[2].m_color = rootView().themeData().button1Inactive();
m_verts[3].m_color = rootView().themeData().button2Inactive(); m_verts[3].m_color = rootView().themeData().button2Inactive();
m_verts[4].m_color = rootView().themeData().button2Inactive(); m_verts[4].m_color = rootView().themeData().button2Inactive();
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = Zeus::CColor::skClear; m_verts[i].m_color = Zeus::CColor::skClear;
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
m_text->colorGlyphs(m_textColor); m_text->colorGlyphs(m_textColor);
} }
} }
@ -175,13 +153,13 @@ void Button::setHover()
m_verts[2].m_color = rootView().themeData().button1Hover(); m_verts[2].m_color = rootView().themeData().button1Hover();
m_verts[3].m_color = rootView().themeData().button2Hover(); m_verts[3].m_color = rootView().themeData().button2Hover();
m_verts[4].m_color = rootView().themeData().button2Hover(); m_verts[4].m_color = rootView().themeData().button2Hover();
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = m_textColor; m_verts[i].m_color = m_textColor;
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
m_text->colorGlyphs(m_textColor); m_text->colorGlyphs(m_textColor);
} }
} }
@ -195,13 +173,13 @@ void Button::setPressed()
m_verts[2].m_color = rootView().themeData().button1Press(); m_verts[2].m_color = rootView().themeData().button1Press();
m_verts[3].m_color = rootView().themeData().button2Press(); m_verts[3].m_color = rootView().themeData().button2Press();
m_verts[4].m_color = rootView().themeData().button2Press(); m_verts[4].m_color = rootView().themeData().button2Press();
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = m_textColor; m_verts[i].m_color = m_textColor;
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
m_text->colorGlyphs(m_textColor); m_text->colorGlyphs(m_textColor);
} }
} }
@ -215,13 +193,13 @@ void Button::setDisabled()
m_verts[2].m_color = rootView().themeData().button1Disabled(); m_verts[2].m_color = rootView().themeData().button1Disabled();
m_verts[3].m_color = rootView().themeData().button2Disabled(); m_verts[3].m_color = rootView().themeData().button2Disabled();
m_verts[4].m_color = rootView().themeData().button2Disabled(); m_verts[4].m_color = rootView().themeData().button2Disabled();
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 28); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 28);
} }
else else
{ {
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = Zeus::CColor::skClear; m_verts[i].m_color = Zeus::CColor::skClear;
m_bVertsBuf->load(m_verts, sizeof(SolidShaderVert) * 4); m_vertsBinding.load(m_verts, sizeof(SolidShaderVert) * 4);
Zeus::CColor dimText = m_textColor; Zeus::CColor dimText = m_textColor;
dimText[3] *= 0.5; dimText[3] *= 0.5;
m_text->colorGlyphs(dimText); m_text->colorGlyphs(dimText);
@ -291,7 +269,7 @@ void Button::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
void Button::draw(boo::IGraphicsCommandQueue* gfxQ) void Button::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
View::draw(gfxQ); View::draw(gfxQ);
gfxQ->setShaderDataBinding(m_bShaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
if (m_style == Style::Block) if (m_style == Style::Block)
gfxQ->draw(0, 28); gfxQ->draw(0, 28);

View File

@ -290,29 +290,9 @@ ModalWindow::ModalWindow(ViewResources& res, View& parentView, const RectangleCo
m_windowBgClear[3] = 0.0; m_windowBgClear[3] = 0.0;
m_line2Clear[3] = 0.0; m_line2Clear[3] = 0.0;
m_viewBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1); m_viewBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1);
m_vertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), 38);
m_vertsBinding.initSolid(res, 38, m_viewBlockBuf);
if (!res.m_viewRes.m_solidVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_vertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_vertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_vertsVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewBlockBuf};
m_vertsShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_vertsVtxFmt, m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewBlockBuf};
m_vertsShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_solidVtxFmt,
m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
m_windowGfxData = res.m_factory->commit(); m_windowGfxData = res.m_factory->commit();
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
@ -332,7 +312,7 @@ ModalWindow::ModalWindow(ViewResources& res, View& parentView, const RectangleCo
setLineColors(0.0); setLineColors(0.0);
setFillColors(0.0); setFillColors(0.0);
m_vertsBuf->load(&m_verts, sizeof(m_verts)); m_vertsBinding.load(&m_verts, sizeof(m_verts));
} }
static float CubicEase(float t) static float CubicEase(float t)
@ -387,7 +367,7 @@ void ModalWindow::think()
if (doneCount == 3) if (doneCount == 3)
m_phase = Phase::Showing; m_phase = Phase::Showing;
if (loadVerts) if (loadVerts)
m_vertsBuf->load(&m_verts, sizeof(m_verts)); m_vertsBinding.load(&m_verts, sizeof(m_verts));
++m_frame; ++m_frame;
break; break;
} }
@ -422,7 +402,7 @@ void ModalWindow::think()
tt = Zeus::Math::clamp(0.f, tt, 1.f); tt = Zeus::Math::clamp(0.f, tt, 1.f);
updateContentOpacity(tt); updateContentOpacity(tt);
} }
m_vertsBuf->load(&m_verts, sizeof(m_verts)); m_vertsBinding.load(&m_verts, sizeof(m_verts));
++m_frame; ++m_frame;
break; break;
} }
@ -442,7 +422,7 @@ bool ModalWindow::skipBuildInAnimation()
setLineVerts(m_width, m_height, pf, 1.0); setLineVerts(m_width, m_height, pf, 1.0);
setLineColors(2.0); setLineColors(2.0);
setFillColors(2.0); setFillColors(2.0);
m_vertsBuf->load(&m_verts, sizeof(m_verts)); m_vertsBinding.load(&m_verts, sizeof(m_verts));
m_phase = Phase::ResWait; m_phase = Phase::ResWait;
return true; return true;
} }
@ -472,7 +452,7 @@ void ModalWindow::resized(const boo::SWindowRect& root, const boo::SWindowRect&
setLineVerts(m_width, m_height, pf, m_lineTime); setLineVerts(m_width, m_height, pf, m_lineTime);
setFillVerts(m_width, m_height, pf); setFillVerts(m_width, m_height, pf);
m_vertsBuf->load(&m_verts, sizeof(m_verts)); m_vertsBinding.load(&m_verts, sizeof(m_verts));
boo::SWindowRect cornerRect = centerRect; boo::SWindowRect cornerRect = centerRect;
cornerRect.size[0] = cornerRect.size[1] = 8 * pf; cornerRect.size[0] = cornerRect.size[1] = 8 * pf;
@ -495,7 +475,7 @@ void ModalWindow::draw(boo::IGraphicsCommandQueue* gfxQ)
if (m_phase == Phase::Done) if (m_phase == Phase::Done)
return; return;
gfxQ->setShaderDataBinding(m_vertsShaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 22); gfxQ->draw(0, 22);
gfxQ->draw(22, 16); gfxQ->draw(22, 16);

View File

@ -9,29 +9,7 @@ namespace Specter
ScrollView::ScrollView(ViewResources& res, View& parentView, Style style) ScrollView::ScrollView(ViewResources& res, View& parentView, Style style)
: View(res, parentView), m_style(style), m_sideButtonBind(*this, rootView().viewManager()) : View(res, parentView), m_style(style), m_sideButtonBind(*this, rootView().viewManager())
{ {
m_vertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), 4); m_vertsBinding.initSolid(res, 4, m_viewVertBlockBuf);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_vertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_vertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_vtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_vtxFmt, m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_texVtxFmt,
m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
commitResources(res); commitResources(res);
if (style == Style::SideButtons) if (style == Style::SideButtons)
@ -271,7 +249,7 @@ void ScrollView::resized(const boo::SWindowRect& root, const boo::SWindowRect& s
const Zeus::CColor& color = rootView().themeData().scrollIndicator(); const Zeus::CColor& color = rootView().themeData().scrollIndicator();
for (int i=0 ; i<4 ; ++i) for (int i=0 ; i<4 ; ++i)
m_verts[i].m_color = color; m_verts[i].m_color = color;
m_vertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
} }
} }
else if (m_style == Style::SideButtons && m_drawSideButtons) else if (m_style == Style::SideButtons && m_drawSideButtons)
@ -297,7 +275,7 @@ void ScrollView::draw(boo::IGraphicsCommandQueue* gfxQ)
if (m_style == Style::ThinIndicator && m_drawInd) if (m_style == Style::ThinIndicator && m_drawInd)
{ {
gfxQ->setShaderDataBinding(m_shaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 4); gfxQ->draw(0, 4);
} }

View File

@ -22,32 +22,7 @@ SplitView::SplitView(ViewResources& res, View& parentView, Axis axis, int cleara
: View(res, parentView), m_axis(axis), m_clearanceA(clearanceA), m_clearanceB(clearanceB) : View(res, parentView), m_axis(axis), m_clearanceA(clearanceA), m_clearanceB(clearanceB)
{ {
m_splitBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1); m_splitBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1);
m_splitVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(TexShaderVert), 4); m_splitVertsBinding.initTex(res, 4, m_splitBlockBuf, res.m_splitRes.m_shadingTex);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_splitVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_splitVertsBuf, nullptr, boo::VertexSemantic::UV4}
};
m_splitVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_splitBlockBuf};
boo::ITexture* texs[] = {res.m_splitRes.m_shadingTex};
m_splitShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
m_splitVtxFmt, m_splitVertsBuf, nullptr,
nullptr, 1, bufs, 1, texs);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_splitBlockBuf};
boo::ITexture* texs[] = {res.m_splitRes.m_shadingTex};
m_splitShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
res.m_viewRes.m_texVtxFmt,
m_splitVertsBuf, nullptr,
nullptr, 1, bufs, 1, texs);
}
commitResources(res); commitResources(res);
} }
@ -210,7 +185,7 @@ void SplitView::resized(const boo::SWindowRect& root, const boo::SWindowRect& su
setVerticalVerts(ssub.size[1]); setVerticalVerts(ssub.size[1]);
} }
m_splitBlockBuf->load(&m_splitBlock, sizeof(ViewBlock)); m_splitBlockBuf->load(&m_splitBlock, sizeof(ViewBlock));
m_splitVertsBuf->load(m_splitVerts, sizeof(TexShaderVert) * 4); m_splitVertsBinding.load(m_splitVerts, sizeof(m_splitVerts));
} }
void SplitView::draw(boo::IGraphicsCommandQueue* gfxQ) void SplitView::draw(boo::IGraphicsCommandQueue* gfxQ)
@ -220,7 +195,7 @@ void SplitView::draw(boo::IGraphicsCommandQueue* gfxQ)
m_views[0].m_view->draw(gfxQ); m_views[0].m_view->draw(gfxQ);
if (m_views[1].m_view) if (m_views[1].m_view)
m_views[1].m_view->draw(gfxQ); m_views[1].m_view->draw(gfxQ);
gfxQ->setShaderDataBinding(m_splitShaderBinding); gfxQ->setShaderDataBinding(m_splitVertsBinding);
gfxQ->draw(0, 4); gfxQ->draw(0, 4);
} }

View File

@ -16,31 +16,7 @@ Table::Table(ViewResources& res, View& parentView, ITableDataBinding* data,
if (!maxColumns) if (!maxColumns)
Log.report(LogVisor::FatalError, "0-column tables not supported"); Log.report(LogVisor::FatalError, "0-column tables not supported");
m_hVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, m_vertsBinding.initSolid(res, maxColumns * 6, m_viewVertBlockBuf);
sizeof(SolidShaderVert),
maxColumns * 6);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_hVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_hVertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_hVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_hShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_hVtxFmt, m_hVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_hShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_texVtxFmt,
m_hVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
commitResources(res); commitResources(res);
m_scroll.m_view.reset(new ScrollView(res, *this, ScrollView::Style::ThinIndicator)); m_scroll.m_view.reset(new ScrollView(res, *this, ScrollView::Style::ThinIndicator));
@ -51,35 +27,12 @@ Table::Table(ViewResources& res, View& parentView, ITableDataBinding* data,
Table::RowsView::RowsView(Table& t, ViewResources& res) Table::RowsView::RowsView(Table& t, ViewResources& res)
: View(res, t), m_t(t), m_verts(new SolidShaderVert[SPECTER_TABLE_MAX_ROWS * t.m_maxColumns * 6]) : View(res, t), m_t(t), m_verts(new SolidShaderVert[SPECTER_TABLE_MAX_ROWS * t.m_maxColumns * 6])
{ {
m_vertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), m_vertsBinding.initSolid(res, SPECTER_TABLE_MAX_ROWS * t.m_maxColumns * 6, m_viewVertBlockBuf);
SPECTER_TABLE_MAX_ROWS * t.m_maxColumns * 6);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_vertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_vertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_vtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_vtxFmt, m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_texVtxFmt,
m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
commitResources(res); commitResources(res);
} }
Table::CellView::CellView(Table& t, ViewResources& res, size_t c, size_t r) Table::CellView::CellView(Table& t, ViewResources& res)
: View(res, t), m_t(t), m_text(new TextView(res, *this, res.m_mainFont)), m_c(c), m_r(r) {} : View(res, t), m_t(t), m_text(new TextView(res, *this, res.m_mainFont)), m_c(-1), m_r(-1) {}
void Table::_setHeaderVerts(const boo::SWindowRect& sub) void Table::_setHeaderVerts(const boo::SWindowRect& sub)
{; {;
@ -157,7 +110,7 @@ void Table::_setHeaderVerts(const boo::SWindowRect& sub)
} }
if (c) if (c)
m_hVertsBuf->load(m_hVerts.get(), sizeof(SolidShaderVert) * 6 * c); m_vertsBinding.load(m_hVerts.get(), sizeof(SolidShaderVert) * 6 * c);
m_headerNeedsUpdate = false; m_headerNeedsUpdate = false;
} }
@ -167,7 +120,7 @@ void Table::RowsView::_setRowVerts(const boo::SWindowRect& sub, const boo::SWind
SolidShaderVert* v = m_verts.get(); SolidShaderVert* v = m_verts.get();
const ThemeData& theme = rootView().themeData(); const ThemeData& theme = rootView().themeData();
if (m_t.m_cellViews.empty()) if (m_t.m_cellPools.empty())
return; return;
float pf = rootView().viewRes().pixelFactor(); float pf = rootView().viewRes().pixelFactor();
@ -182,8 +135,6 @@ void Table::RowsView::_setRowVerts(const boo::SWindowRect& sub, const boo::SWind
++idx; ++idx;
} }
int startIdx = int(m_t.m_rows) - idx; int startIdx = int(m_t.m_rows) - idx;
if (!m_t.m_header)
startIdx -= 1;
std::vector<boo::SWindowRect> cellRects = m_t.getCellRects(sub); std::vector<boo::SWindowRect> cellRects = m_t.getCellRects(sub);
@ -217,7 +168,7 @@ void Table::RowsView::_setRowVerts(const boo::SWindowRect& sub, const boo::SWind
m_visibleStart = std::max(0, startIdx); m_visibleStart = std::max(0, startIdx);
m_visibleRows = r; m_visibleRows = r;
if (r * c) if (r * c)
m_vertsBuf->load(m_verts.get(), sizeof(SolidShaderVert) * 6 * r * c); m_vertsBinding.load(m_verts.get(), sizeof(SolidShaderVert) * 6 * r * c);
} }
void Table::cycleSortColumn(size_t c) void Table::cycleSortColumn(size_t c)
@ -255,22 +206,61 @@ void Table::selectRow(size_t r)
} }
return; return;
} }
if (m_selectedRow != -1)
for (auto& col : m_cellViews) if (m_selectedRow != -1 && m_activePool != -1)
{
size_t poolIdx = m_selectedRow / SPECTER_TABLE_MAX_ROWS;
int pool0 = (poolIdx & 1) != 0;
int pool1 = (poolIdx & 1) == 0;
if (m_activePool == poolIdx)
{ {
ViewChild<std::unique_ptr<CellView>>& cv = col.at(m_selectedRow); for (auto& col : m_cellPools)
if (cv.m_view) {
cv.m_view->deselect(); ViewChild<std::unique_ptr<CellView>>& cv = col[pool0].at(m_selectedRow % SPECTER_TABLE_MAX_ROWS);
if (cv.m_view)
cv.m_view->deselect();
}
} }
else if (m_activePool+1 == poolIdx)
{
for (auto& col : m_cellPools)
{
ViewChild<std::unique_ptr<CellView>>& cv = col[pool1].at(m_selectedRow % SPECTER_TABLE_MAX_ROWS);
if (cv.m_view)
cv.m_view->deselect();
}
}
}
m_selectedRow = r; m_selectedRow = r;
if (m_selectedRow != -1)
for (auto& col : m_cellViews) if (m_selectedRow != -1 && m_activePool != -1)
{
size_t poolIdx = m_selectedRow / SPECTER_TABLE_MAX_ROWS;
int pool0 = (poolIdx & 1) != 0;
int pool1 = (poolIdx & 1) == 0;
if (m_activePool == poolIdx)
{ {
ViewChild<std::unique_ptr<CellView>>& cv = col.at(m_selectedRow); for (auto& col : m_cellPools)
if (cv.m_view) {
cv.m_view->select(); ViewChild<std::unique_ptr<CellView>>& cv = col[pool0].at(m_selectedRow % SPECTER_TABLE_MAX_ROWS);
if (cv.m_view)
cv.m_view->select();
}
} }
else if (m_activePool+1 == poolIdx)
{
for (auto& col : m_cellPools)
{
ViewChild<std::unique_ptr<CellView>>& cv = col[pool1].at(m_selectedRow % SPECTER_TABLE_MAX_ROWS);
if (cv.m_view)
cv.m_view->select();
}
}
}
updateSize(); updateSize();
if (m_state) if (m_state)
{ {
m_inSelectRow = true; m_inSelectRow = true;
@ -287,9 +277,12 @@ void Table::setMultiplyColor(const Zeus::CColor& color)
for (ViewChild<std::unique_ptr<CellView>>& hv : m_headerViews) for (ViewChild<std::unique_ptr<CellView>>& hv : m_headerViews)
if (hv.m_view) if (hv.m_view)
hv.m_view->m_text->setMultiplyColor(color); hv.m_view->m_text->setMultiplyColor(color);
for (auto& col : m_cellViews) for (auto& col : m_cellPools)
{ {
for (ViewChild<std::unique_ptr<CellView>>& cv : col) for (ViewChild<std::unique_ptr<CellView>>& cv : col[0])
if (cv.m_view)
cv.m_view->m_text->setMultiplyColor(color);
for (ViewChild<std::unique_ptr<CellView>>& cv : col[1])
if (cv.m_view) if (cv.m_view)
cv.m_view->m_text->setMultiplyColor(color); cv.m_view->m_text->setMultiplyColor(color);
} }
@ -349,9 +342,13 @@ void Table::RowsView::mouseDown(const boo::SWindowCoord& coord,
for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews) for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews)
if (hv.mouseDown(coord, button, mod)) if (hv.mouseDown(coord, button, mod))
return; /* Trap header event */ return; /* Trap header event */
for (std::vector<ViewChild<std::unique_ptr<CellView>>>& col : m_t.m_cellViews) for (auto& col : m_t.m_cellPools)
for (ViewChild<std::unique_ptr<CellView>>& cv : col) {
for (ViewChild<std::unique_ptr<CellView>>& cv : col[0])
cv.mouseDown(coord, button, mod); cv.mouseDown(coord, button, mod);
for (ViewChild<std::unique_ptr<CellView>>& cv : col[1])
cv.mouseDown(coord, button, mod);
}
} }
void Table::CellView::mouseDown(const boo::SWindowCoord& coord, void Table::CellView::mouseDown(const boo::SWindowCoord& coord,
@ -393,9 +390,13 @@ void Table::RowsView::mouseUp(const boo::SWindowCoord& coord,
hv.mouseUp(coord, button, mod); hv.mouseUp(coord, button, mod);
++idx; ++idx;
} }
for (std::vector<ViewChild<std::unique_ptr<CellView>>>& col : m_t.m_cellViews) for (auto& col : m_t.m_cellPools)
for (ViewChild<std::unique_ptr<CellView>>& cv : col) {
for (ViewChild<std::unique_ptr<CellView>>& cv : col[0])
cv.mouseUp(coord, button, mod); cv.mouseUp(coord, button, mod);
for (ViewChild<std::unique_ptr<CellView>>& cv : col[1])
cv.mouseUp(coord, button, mod);
}
} }
void Table::CellView::mouseUp(const boo::SWindowCoord& coord, void Table::CellView::mouseUp(const boo::SWindowCoord& coord,
@ -453,9 +454,13 @@ void Table::RowsView::mouseMove(const boo::SWindowCoord& coord)
{ {
for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews) for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews)
hv.mouseMove(coord); hv.mouseMove(coord);
for (std::vector<ViewChild<std::unique_ptr<CellView>>>& col : m_t.m_cellViews) for (auto& col : m_t.m_cellPools)
for (ViewChild<std::unique_ptr<CellView>>& cv : col) {
for (ViewChild<std::unique_ptr<CellView>>& cv : col[0])
cv.mouseMove(coord); cv.mouseMove(coord);
for (ViewChild<std::unique_ptr<CellView>>& cv : col[1])
cv.mouseMove(coord);
}
} }
void Table::mouseEnter(const boo::SWindowCoord& coord) void Table::mouseEnter(const boo::SWindowCoord& coord)
@ -482,9 +487,13 @@ void Table::RowsView::mouseLeave(const boo::SWindowCoord& coord)
{ {
for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews) for (ViewChild<std::unique_ptr<CellView>>& hv : m_t.m_headerViews)
hv.mouseLeave(coord); hv.mouseLeave(coord);
for (std::vector<ViewChild<std::unique_ptr<CellView>>>& col : m_t.m_cellViews) for (auto& col : m_t.m_cellPools)
for (ViewChild<std::unique_ptr<CellView>>& cv : col) {
for (ViewChild<std::unique_ptr<CellView>>& cv : col[0])
cv.mouseLeave(coord); cv.mouseLeave(coord);
for (ViewChild<std::unique_ptr<CellView>>& cv : col[1])
cv.mouseLeave(coord);
}
} }
void Table::CellView::mouseLeave(const boo::SWindowCoord& coord) void Table::CellView::mouseLeave(const boo::SWindowCoord& coord)
@ -504,12 +513,108 @@ void Table::think()
m_scroll.m_view->think(); m_scroll.m_view->think();
++m_clickFrames; ++m_clickFrames;
} }
void Table::CellView::reset()
{
m_c = -1;
m_r = -1;
if (m_textHash)
{
m_text->typesetGlyphs("");
m_textHash = 0;
}
}
bool Table::CellView::reset(size_t c)
{
m_c = c;
m_r = -1;
const std::string* headerText = m_t.m_data->header(c);
if (headerText)
{
uint64_t hash = XXH64(headerText->data(), headerText->size(), 0);
if (hash != m_textHash)
{
m_text->typesetGlyphs(*headerText, rootView().themeData().uiText());
m_textHash = hash;
}
return true;
}
else if (m_textHash)
{
m_text->typesetGlyphs("");
m_textHash = 0;
}
return false;
}
void Table::updateData() bool Table::CellView::reset(size_t c, size_t r)
{
m_c = c;
m_r = r;
const std::string* cellText = m_t.m_data->cell(c, r);
if (cellText)
{
uint64_t hash = XXH64(cellText->data(), cellText->size(), 0);
if (hash != m_textHash)
{
m_text->typesetGlyphs(*cellText, rootView().themeData().uiText());
m_textHash = hash;
}
return true;
}
else if (m_textHash)
{
m_text->typesetGlyphs("");
m_textHash = 0;
}
return false;
}
std::vector<Table::ColumnPool>& Table::ensureCellPools(size_t rows, size_t cols, ViewResources& res)
{
if (m_cellPools.size() < cols)
{
m_cellPools.reserve(cols);
for (size_t i=m_cellPools.size() ; i<cols ; ++i)
m_cellPools.emplace_back();
m_ensuredRows = 0;
}
if (m_ensuredRows < rows)
{
for (size_t i=0 ; i<cols ; ++i)
{
ColumnPool& cp = m_cellPools[i];
if (rows > SPECTER_TABLE_MAX_ROWS)
{
for (int p=0 ; p<2 ; ++p)
for (ViewChild<std::unique_ptr<CellView>>& cv : cp[p])
if (!cv.m_view)
cv.m_view.reset(new CellView(*this, res));
}
else
{
size_t r = 0;
for (ViewChild<std::unique_ptr<CellView>>& cv : cp[0])
{
if (!cv.m_view)
cv.m_view.reset(new CellView(*this, res));
++r;
if (r >= rows)
break;
}
}
}
m_ensuredRows = rows;
}
return m_cellPools;
}
void Table::_updateData()
{ {
m_header = false; m_header = false;
bool newViewChildren = false; bool newViewChildren = false;
if (m_columns != m_data->columnCount()) if (m_columns != m_data->columnCount() || m_rows > m_data->rowCount() + SPECTER_TABLE_MAX_ROWS)
newViewChildren = true; newViewChildren = true;
m_rows = m_data->rowCount(); m_rows = m_data->rowCount();
@ -517,52 +622,66 @@ void Table::updateData()
if (!m_columns) if (!m_columns)
return; return;
ViewResources& res = rootView().viewRes();
if (newViewChildren) if (newViewChildren)
{ {
m_headerViews.clear(); m_headerViews.clear();
m_cellViews.clear(); m_cellPools.clear();
m_headerViews.reserve(m_columns); m_headerViews.reserve(m_columns);
m_cellViews.reserve(m_columns);
for (size_t c=0 ; c<m_columns ; ++c) for (size_t c=0 ; c<m_columns ; ++c)
{
m_headerViews.emplace_back(); m_headerViews.emplace_back();
m_cellViews.emplace_back(); m_ensuredRows = 0;
}
} }
ensureCellPools(m_rows, m_columns, res);
ViewResources& res = rootView().viewRes();
const Zeus::CColor& textColor = rootView().themeData().uiText(); size_t poolIdx = m_rowsView.m_visibleStart / SPECTER_TABLE_MAX_ROWS;
size_t startRow = poolIdx * SPECTER_TABLE_MAX_ROWS;
int pool0 = (poolIdx & 1) != 0;
int pool1 = (poolIdx & 1) == 0;
for (size_t c=0 ; c<m_columns ; ++c) for (size_t c=0 ; c<m_columns ; ++c)
{ {
const std::string* headerText = m_data->header(c); std::unique_ptr<CellView>& cv = m_headerViews[c].m_view;
if (headerText) if (!cv)
{ cv.reset(new CellView(*this, res));
if (cv->reset(c))
m_header = true; m_header = true;
CellView* cv = new CellView(*this, res, c, -1);
m_headerViews[c].m_view.reset(cv);
cv->m_text->typesetGlyphs(*headerText, textColor);
}
else
m_headerViews[c].m_view.reset();
std::vector<ViewChild<std::unique_ptr<CellView>>>& col = m_cellViews[c]; ColumnPool& col = m_cellPools[c];
col.clear();
col.reserve(m_rows); if (poolIdx != m_activePool)
for (size_t r=0 ; r<m_rows ; ++r)
{ {
const std::string* cellText = m_data->cell(c, r); for (size_t r=startRow, i=0 ; i<SPECTER_TABLE_MAX_ROWS ; ++r, ++i)
if (cellText)
{ {
CellView* cv = new CellView(*this, res, c, r); ViewChild<std::unique_ptr<CellView>>& cv = col[pool0][i];
col.emplace_back(); if (cv.m_view)
col.back().m_view.reset(cv); {
cv->m_text->typesetGlyphs(*cellText, textColor); if (r < m_rows)
cv.m_view->reset(c, r);
else
cv.m_view->reset();
}
}
for (size_t r=startRow+SPECTER_TABLE_MAX_ROWS, i=0 ; i<SPECTER_TABLE_MAX_ROWS ; ++r, ++i)
{
ViewChild<std::unique_ptr<CellView>>& cv = col[pool1][i];
if (cv.m_view)
{
if (r < m_rows)
cv.m_view->reset(c, r);
else
cv.m_view->reset();
}
} }
else
col.emplace_back();
} }
} }
m_activePool = poolIdx;
}
void Table::updateData()
{
m_activePool = -1;
updateSize(); updateSize();
} }
@ -643,9 +762,7 @@ void Table::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
int Table::RowsView::nominalHeight() const int Table::RowsView::nominalHeight() const
{ {
float pf = rootView().viewRes().pixelFactor(); float pf = rootView().viewRes().pixelFactor();
int rows = m_t.m_rows; int rows = m_t.m_rows + 1;
if (m_t.m_header)
rows += 1;
return rows * (ROW_HEIGHT + CELL_MARGIN * 2) * pf; return rows * (ROW_HEIGHT + CELL_MARGIN * 2) * pf;
} }
@ -654,6 +771,7 @@ void Table::RowsView::resized(const boo::SWindowRect& root, const boo::SWindowRe
{ {
View::resized(root, sub); View::resized(root, sub);
_setRowVerts(sub, scissor); _setRowVerts(sub, scissor);
m_t._updateData();
if (!m_t.m_columns) if (!m_t.m_columns)
return; return;
@ -666,9 +784,20 @@ void Table::RowsView::resized(const boo::SWindowRect& root, const boo::SWindowRe
int spacing = (ROW_HEIGHT + CELL_MARGIN * 2) * pf; int spacing = (ROW_HEIGHT + CELL_MARGIN * 2) * pf;
std::vector<boo::SWindowRect> cellRects = m_t.getCellRects(rowRect); std::vector<boo::SWindowRect> cellRects = m_t.getCellRects(rowRect);
auto cellRectIt = cellRects.begin(); auto cellRectIt = cellRects.begin();
for (auto& col : m_t.m_cellViews) int poolIdx = m_visibleStart / SPECTER_TABLE_MAX_ROWS;
int pool0 = (poolIdx & 1) != 0;
int pool1 = (poolIdx & 1) == 0;
int locationStart = spacing * poolIdx * SPECTER_TABLE_MAX_ROWS;
for (auto& col : m_t.m_cellPools)
{ {
for (ViewChild<std::unique_ptr<CellView>>& cv : col) cellRectIt->location[1] -= locationStart;
for (ViewChild<std::unique_ptr<CellView>>& cv : col[pool0])
{
cellRectIt->location[1] -= spacing;
if (cv.m_view)
cv.m_view->resized(root, *cellRectIt, cellScissor);
}
for (ViewChild<std::unique_ptr<CellView>>& cv : col[pool1])
{ {
cellRectIt->location[1] -= spacing; cellRectIt->location[1] -= spacing;
if (cv.m_view) if (cv.m_view)
@ -701,15 +830,25 @@ void Table::draw(boo::IGraphicsCommandQueue* gfxQ)
void Table::RowsView::draw(boo::IGraphicsCommandQueue* gfxQ) void Table::RowsView::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
gfxQ->setShaderDataBinding(m_shaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->setScissor(m_scissorRect); gfxQ->setScissor(m_scissorRect);
gfxQ->draw(1, m_visibleRows * m_t.m_columns * 6 - 2); gfxQ->draw(1, m_visibleRows * m_t.m_columns * 6 - 2);
for (auto& col : m_t.m_cellViews)
int poolIdx = m_t.m_activePool;
int pool0 = (poolIdx & 1) != 0;
int pool1 = (poolIdx & 1) == 0;
for (auto& col : m_t.m_cellPools)
{ {
size_t idx = 0; size_t idx = poolIdx * SPECTER_TABLE_MAX_ROWS;
for (ViewChild<std::unique_ptr<CellView>>& cv : col) for (ViewChild<std::unique_ptr<CellView>>& cv : col[pool0])
{
if (cv.m_view && idx >= m_visibleStart && idx < m_visibleStart + m_visibleRows)
cv.m_view->draw(gfxQ);
++idx;
}
for (ViewChild<std::unique_ptr<CellView>>& cv : col[pool1])
{ {
if (cv.m_view && idx >= m_visibleStart && idx < m_visibleStart + m_visibleRows) if (cv.m_view && idx >= m_visibleStart && idx < m_visibleStart + m_visibleRows)
cv.m_view->draw(gfxQ); cv.m_view->draw(gfxQ);
@ -719,7 +858,7 @@ void Table::RowsView::draw(boo::IGraphicsCommandQueue* gfxQ)
if (m_t.m_header) if (m_t.m_header)
{ {
gfxQ->setShaderDataBinding(m_t.m_hShaderBinding); gfxQ->setShaderDataBinding(m_t.m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->setScissor(rootView().subRect()); gfxQ->setScissor(rootView().subRect());
gfxQ->draw(1, m_t.m_columns * 6 - 2); gfxQ->draw(1, m_t.m_columns * 6 - 2);

View File

@ -8,35 +8,13 @@ namespace Specter
TextField::TextField(ViewResources& res, View& parentView, IStringBinding* strBind) TextField::TextField(ViewResources& res, View& parentView, IStringBinding* strBind)
: ITextInputView(res, parentView, strBind) : ITextInputView(res, parentView, strBind)
{ {
m_bVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), 41); m_vertsBinding.initSolid(res, 41, m_viewVertBlockBuf);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_bVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_bVertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_bVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_bShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_bVtxFmt, m_bVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_viewVertBlockBuf};
m_bShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_texVtxFmt,
m_bVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
commitResources(res); commitResources(res);
for (int i=28 ; i<32 ; ++i) for (int i=28 ; i<32 ; ++i)
m_verts[i].m_color = res.themeData().textfieldSelection(); m_verts[i].m_color = res.themeData().textfieldSelection();
setInactive(); setInactive();
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_text.reset(new TextView(res, *this, res.m_mainFont, TextView::Alignment::Left, 1024)); m_text.reset(new TextView(res, *this, res.m_mainFont, TextView::Alignment::Left, 1024));
if (strBind) if (strBind)
@ -149,7 +127,7 @@ void TextField::setInactive()
for (int i=5 ; i<28 ; ++i) for (int i=5 ; i<28 ; ++i)
m_verts[i].m_color = theme.textfield2Inactive(); m_verts[i].m_color = theme.textfield2Inactive();
} }
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_bgState = BGState::Inactive; m_bgState = BGState::Inactive;
} }
@ -176,7 +154,7 @@ void TextField::setHover()
for (int i=5 ; i<28 ; ++i) for (int i=5 ; i<28 ; ++i)
m_verts[i].m_color = theme.textfield2Inactive(); m_verts[i].m_color = theme.textfield2Inactive();
} }
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_bgState = BGState::Hover; m_bgState = BGState::Hover;
} }
@ -203,7 +181,7 @@ void TextField::setDisabled()
for (int i=5 ; i<28 ; ++i) for (int i=5 ; i<28 ; ++i)
m_verts[i].m_color = theme.textfield2Disabled(); m_verts[i].m_color = theme.textfield2Disabled();
} }
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_bgState = BGState::Disabled; m_bgState = BGState::Disabled;
} }
@ -623,7 +601,7 @@ void TextField::think()
} }
for (size_t i=32 ; i<41 ; ++i) for (size_t i=32 ; i<41 ; ++i)
m_verts[i].m_color = errBg; m_verts[i].m_color = errBg;
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_errText->setMultiplyColor(errMult); m_errText->setMultiplyColor(errMult);
} }
@ -666,7 +644,7 @@ void TextField::_reallySetCursorPos(size_t pos)
m_verts[30].m_color = selColor; m_verts[30].m_color = selColor;
m_verts[31].m_pos.assign(offset2, 4 * pf, 0); m_verts[31].m_pos.assign(offset2, 4 * pf, 0);
m_verts[31].m_color = selColor; m_verts[31].m_color = selColor;
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]}; int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]};
rootView().window()->claimKeyboardFocus(focusRect); rootView().window()->claimKeyboardFocus(focusRect);
@ -747,7 +725,7 @@ void TextField::_reallySetSelectionRange(size_t start, size_t len)
m_verts[29].m_pos.assign(offset1, 4 * pf, 0); m_verts[29].m_pos.assign(offset1, 4 * pf, 0);
m_verts[30].m_pos.assign(offset2, 18 * pf, 0); m_verts[30].m_pos.assign(offset2, 18 * pf, 0);
m_verts[31].m_pos.assign(offset2, 4 * pf, 0); m_verts[31].m_pos.assign(offset2, 4 * pf, 0);
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]}; int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]};
rootView().window()->claimKeyboardFocus(focusRect); rootView().window()->claimKeyboardFocus(focusRect);
@ -772,7 +750,7 @@ void TextField::_reallySetMarkRange(size_t start, size_t len)
m_verts[30].m_color = selColor; m_verts[30].m_color = selColor;
m_verts[31].m_pos.assign(offset2, 4 * pf, 0); m_verts[31].m_pos.assign(offset2, 4 * pf, 0);
m_verts[31].m_color = selColor; m_verts[31].m_color = selColor;
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]}; int focusRect[2] = {subRect().location[0] + offset1, subRect().location[1]};
rootView().window()->claimKeyboardFocus(focusRect); rootView().window()->claimKeyboardFocus(focusRect);
@ -902,7 +880,7 @@ void TextField::resized(const boo::SWindowRect& root, const boo::SWindowRect& su
m_verts[i].m_color = Zeus::CColor::skClear; m_verts[i].m_color = Zeus::CColor::skClear;
} }
m_bVertsBuf->load(m_verts, sizeof(m_verts)); m_vertsBinding.load(m_verts, sizeof(m_verts));
m_nomWidth = width; m_nomWidth = width;
m_nomHeight = height; m_nomHeight = height;
@ -916,7 +894,7 @@ void TextField::resized(const boo::SWindowRect& root, const boo::SWindowRect& su
void TextField::draw(boo::IGraphicsCommandQueue* gfxQ) void TextField::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
View::draw(gfxQ); View::draw(gfxQ);
gfxQ->setShaderDataBinding(m_bShaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 28); gfxQ->draw(0, 28);
if (m_active) if (m_active)

View File

@ -27,34 +27,9 @@ Toolbar::Toolbar(ViewResources& res, View& parentView, Position tbPos)
m_padding(res.pixelFactor() * TOOLBAR_PADDING) m_padding(res.pixelFactor() * TOOLBAR_PADDING)
{ {
m_tbBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1); m_tbBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1);
m_tbVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(TexShaderVert), 10); m_vertsBinding.initTex(res, 10, m_tbBlockBuf, res.m_toolbarRes.m_shadingTex);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_tbVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_tbVertsBuf, nullptr, boo::VertexSemantic::UV4}
};
m_tbVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_tbBlockBuf};
boo::ITexture* texs[] = {res.m_toolbarRes.m_shadingTex};
m_tbShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
m_tbVtxFmt, m_tbVertsBuf, nullptr,
nullptr, 1, bufs, 1, texs);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_tbBlockBuf};
boo::ITexture* texs[] = {res.m_toolbarRes.m_shadingTex};
m_tbShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
res.m_viewRes.m_texVtxFmt,
m_tbVertsBuf, nullptr,
nullptr, 1, bufs, 1, texs);
}
setBackground(res.themeData().toolbarBackground());
commitResources(res); commitResources(res);
setBackground(res.themeData().toolbarBackground());
} }
void Toolbar::mouseDown(const boo::SWindowCoord& coord, boo::EMouseButton button, boo::EModifierKey mod) void Toolbar::mouseDown(const boo::SWindowCoord& coord, boo::EMouseButton button, boo::EModifierKey mod)
@ -91,7 +66,7 @@ void Toolbar::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
{ {
View::resized(root, sub); View::resized(root, sub);
setHorizontalVerts(sub.size[0]); setHorizontalVerts(sub.size[0]);
m_tbVertsBuf->load(&m_tbVerts, sizeof(TexShaderVert) * 10); m_vertsBinding.load(m_tbVerts, sizeof(m_tbVerts));
m_tbBlock.setViewRect(root, sub); m_tbBlock.setViewRect(root, sub);
m_tbBlockBuf->load(&m_tbBlock, sizeof(ViewBlock)); m_tbBlockBuf->load(&m_tbBlock, sizeof(ViewBlock));
@ -110,7 +85,7 @@ void Toolbar::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
void Toolbar::draw(boo::IGraphicsCommandQueue* gfxQ) void Toolbar::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
View::draw(gfxQ); View::draw(gfxQ);
gfxQ->setShaderDataBinding(m_tbShaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 10); gfxQ->draw(0, 10);

View File

@ -13,29 +13,7 @@ Tooltip::Tooltip(ViewResources& res, View& parentView, const std::string& title,
: View(res, parentView), m_titleStr(title), m_messageStr(message) : View(res, parentView), m_titleStr(title), m_messageStr(message)
{ {
m_ttBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1); m_ttBlockBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, sizeof(ViewBlock), 1);
m_ttVertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), 16); m_vertsBinding.initSolid(res, 16, m_ttBlockBuf);
if (!res.m_viewRes.m_solidVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_ttVertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_ttVertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_ttVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {m_ttBlockBuf};
m_ttShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_ttVtxFmt, m_ttVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {m_ttBlockBuf};
m_ttShaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_solidVtxFmt,
m_ttVertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
for (int i=0 ; i<16 ; ++i) for (int i=0 ; i<16 ; ++i)
m_ttVerts[i].m_color = res.themeData().tooltipBackground(); m_ttVerts[i].m_color = res.themeData().tooltipBackground();
@ -94,7 +72,7 @@ void Tooltip::setVerts(int width, int height, float pf)
m_ttVerts[14].m_pos.assign(width-margin.first, margin.second, 0); m_ttVerts[14].m_pos.assign(width-margin.first, margin.second, 0);
m_ttVerts[15].m_pos.assign(width-margin.first, 0, 0); m_ttVerts[15].m_pos.assign(width-margin.first, 0, 0);
m_ttVertsBuf->load(m_ttVerts, sizeof(SolidShaderVert) * 16); m_vertsBinding.load(m_ttVerts, sizeof(m_ttVerts));
} }
void Tooltip::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub) void Tooltip::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
@ -132,7 +110,7 @@ void Tooltip::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
void Tooltip::draw(boo::IGraphicsCommandQueue* gfxQ) void Tooltip::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
gfxQ->setShaderDataBinding(m_ttShaderBinding); gfxQ->setShaderDataBinding(m_vertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 16); gfxQ->draw(0, 16);

View File

@ -286,36 +286,10 @@ void View::Resources::init(boo::MetalDataFactory* factory, const ThemeData& them
void View::buildResources(ViewResources& res) void View::buildResources(ViewResources& res)
{ {
m_bgVertBuf =
res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex,
sizeof(SolidShaderVert), 4);
m_viewVertBlockBuf = m_viewVertBlockBuf =
res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform, res.m_factory->newDynamicBuffer(boo::BufferUse::Uniform,
sizeof(ViewBlock), 1); sizeof(ViewBlock), 1);
m_bgVertsBinding.initSolid(res, 4, m_viewVertBlockBuf);
if (!res.m_viewRes.m_solidVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_bgVertBuf, nullptr, boo::VertexSemantic::Position4},
{m_bgVertBuf, nullptr, boo::VertexSemantic::Color}
};
m_bgVtxFmt = res.m_factory->newVertexFormat(2, vdescs);
m_bgShaderBinding =
res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader, m_bgVtxFmt,
m_bgVertBuf, nullptr, nullptr, 1,
(boo::IGraphicsBuffer**)&m_viewVertBlockBuf,
0, nullptr);
}
else
{
m_bgShaderBinding =
res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader, res.m_viewRes.m_solidVtxFmt,
m_bgVertBuf, nullptr, nullptr, 1,
(boo::IGraphicsBuffer**)&m_viewVertBlockBuf,
0, nullptr);
}
} }
View::View(ViewResources& res) View::View(ViewResources& res)
@ -346,12 +320,12 @@ void View::resized(const boo::SWindowRect& root, const boo::SWindowRect& sub)
m_bgRect[2].m_pos.assign(sub.size[0], sub.size[1], 0.f); m_bgRect[2].m_pos.assign(sub.size[0], sub.size[1], 0.f);
m_bgRect[3].m_pos.assign(sub.size[0], 0.f, 0.f); m_bgRect[3].m_pos.assign(sub.size[0], 0.f, 0.f);
m_viewVertBlockBuf->load(&m_viewVertBlock, sizeof(ViewBlock)); m_viewVertBlockBuf->load(&m_viewVertBlock, sizeof(ViewBlock));
m_bgVertBuf->load(m_bgRect, sizeof(SolidShaderVert) * 4); m_bgVertsBinding.load(m_bgRect, sizeof(m_bgRect));
} }
void View::draw(boo::IGraphicsCommandQueue* gfxQ) void View::draw(boo::IGraphicsCommandQueue* gfxQ)
{ {
gfxQ->setShaderDataBinding(m_bgShaderBinding); gfxQ->setShaderDataBinding(m_bgVertsBinding);
gfxQ->setDrawPrimitive(boo::Primitive::TriStrips); gfxQ->setDrawPrimitive(boo::Primitive::TriStrips);
gfxQ->draw(0, 4); gfxQ->draw(0, 4);
} }
@ -362,5 +336,62 @@ void View::commitResources(ViewResources& res)
Log.report(LogVisor::FatalError, "multiple resource commits not allowed"); Log.report(LogVisor::FatalError, "multiple resource commits not allowed");
m_gfxData = res.m_factory->commit(); m_gfxData = res.m_factory->commit();
} }
void View::VertexBufferBinding::initSolid(ViewResources& res, size_t count, boo::IGraphicsBuffer* viewBlockBuf)
{
m_vertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(SolidShaderVert), count);
if (!res.m_viewRes.m_solidVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_vertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_vertsBuf, nullptr, boo::VertexSemantic::Color}
};
m_vtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {viewBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
m_vtxFmt, m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
else
{
boo::IGraphicsBuffer* bufs[] = {viewBlockBuf};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_solidShader,
res.m_viewRes.m_solidVtxFmt,
m_vertsBuf, nullptr,
nullptr, 1, bufs, 0, nullptr);
}
}
void View::VertexBufferBinding::initTex(ViewResources& res, size_t count, boo::IGraphicsBuffer* viewBlockBuf, boo::ITexture* texture)
{
m_vertsBuf = res.m_factory->newDynamicBuffer(boo::BufferUse::Vertex, sizeof(TexShaderVert), count);
if (!res.m_viewRes.m_texVtxFmt)
{
boo::VertexElementDescriptor vdescs[] =
{
{m_vertsBuf, nullptr, boo::VertexSemantic::Position4},
{m_vertsBuf, nullptr, boo::VertexSemantic::UV4}
};
m_vtxFmt = res.m_factory->newVertexFormat(2, vdescs);
boo::IGraphicsBuffer* bufs[] = {viewBlockBuf};
boo::ITexture* tex[] = {texture};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
m_vtxFmt, m_vertsBuf, nullptr,
nullptr, 1, bufs, 1, tex);
}
else
{
boo::IGraphicsBuffer* bufs[] = {viewBlockBuf};
boo::ITexture* tex[] = {texture};
m_shaderBinding = res.m_factory->newShaderDataBinding(res.m_viewRes.m_texShader,
res.m_viewRes.m_texVtxFmt,
m_vertsBuf, nullptr,
nullptr, 1, bufs, 1, tex);
}
}
} }