X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2Fview.h;h=9e3017cc4033d159801923de87f04a375238a3f9;hp=4457e1d9bd25009bf01f39f6fd387a7685686586;hb=396b22d11e8041a00b33ca874a5be3853c09d6c0;hpb=070e5e119baa62352418dbc2dd1b0670b4da8dca diff --git a/src/view.h b/src/view.h index 4457e1d..9e3017c 100644 --- a/src/view.h +++ b/src/view.h @@ -13,7 +13,7 @@ namespace IPDF { public: View(Document & document, const Rect & bounds = Rect(0,0,1,1), const Colour & colour = Colour(0.f,0.f,0.f,1.f)) - : m_use_gpu_transform(false), m_bounds_dirty(true), m_buffer_dirty(true), m_document(document), m_bounds(bounds), m_colour(colour) + : m_use_gpu_transform(false), m_bounds_dirty(true), m_buffer_dirty(true), m_render_inited(false), m_document(document), m_bounds(bounds), m_colour(colour) { Debug("View Created - Bounds => {%s}", m_bounds.Str().c_str()); } @@ -32,21 +32,31 @@ namespace IPDF void ToggleGPUTransform() { m_use_gpu_transform = (!m_use_gpu_transform); m_bounds_dirty = true; m_buffer_dirty = true; } private: - void ReRender(); + void PrepareRender(); + void UpdateObjBoundsVBO(); void DrawGrid(); bool m_use_gpu_transform; bool m_bounds_dirty; bool m_buffer_dirty; - ShaderProgram m_rect_shader; + bool m_render_inited; + ShaderProgram m_rect_outline_shader; + ShaderProgram m_rect_filled_shader; + ShaderProgram m_circle_filled_shader; + // Stores the view bounds. GraphicsBuffer m_bounds_ubo; - GraphicsBuffer m_vertex_buffer; - GraphicsBuffer m_index_buffer; + // Stores the bounds for _all_ objects. + GraphicsBuffer m_objbounds_vbo; + // Stores indices into the objbounds vbo for each type of object. + GraphicsBuffer m_outline_ibo; // Rectangle outline + GraphicsBuffer m_filled_ibo; // Filled rectangle + GraphicsBuffer m_circle_ibo; // Filled circle FrameBuffer m_cached_display; Document & m_document; Rect m_bounds; Colour m_colour; uint32_t m_rendered_filled; uint32_t m_rendered_outline; + uint32_t m_rendered_circle; }; }