#ifndef NXS_NEXUS_MT_H #define NXS_NEXUS_MT_H #include "nexus.h" #include #include #include #include namespace nxs { typedef std::vector Frag; struct Node { std::vector in; std::vector out; std::vector frags; float error; bool visited; bool pushed; }; struct TNode { float error; Node *node; TNode(Node *n, float e): node(n), error(e) {} bool operator<(const TNode &n) { return error < n.error; } }; class Metric { public: vector *index; float GetError(Node *node); float GetError(Frag &frag); virtual float GetError(unsigned int cell) = 0; virtual void GetView() {} }; class FlatMetric: public Metric { public: void GetView() {} float GetError(unsigned int cell); }; class DeltaMetric: public Metric { public: vcg::Point3f delta; void GetView() {} float GetError(unsigned int cell); }; class FrustumMetric: public Metric { public: vcg::Frustumf frustum; void GetView() { frustum.GetView(); } float GetError(unsigned int cell); }; class Policy { public: float error; int ram_used; int ram_size; vector *entries; void Init(); bool Expand(TNode &node); void NodeVisited(Node *node); }; class Prefetch: public pt::thread { public: Prefetch(); ~Prefetch(); void execute(); void cleanup() {} bool Running() { return get_running(); } std::vector cells; pt::mutex cells_mx; pt::mutex patch_mx; Nexus *nexus; }; class NexusMt: public Nexus { private: std::vector nodes; Prefetch prefetch; public: //Vertex buffer object mode enum Vbo { VBO_AUTO, //autodetect best size VBO_OFF, //no vertex buffer object VBO_FIXED }; //user supplied size enum MetricKind { FRUSTUM, //screen error extraction GEOMETRY, //geometry error extraction DELTA }; //delta error enum Mode { POINTS, SMOOTH, XRAY, HIDDEN_LINE, FLAT_WIRE, FLAT, DEBUG }; enum Component { COLOR = 0x1, NORMAL = 0x2, TEXTURE = 0x4, DATA = 0x8}; Vbo vbo_mode; Metric *metric; Policy policy; Mode mode; bool prefetching; unsigned int components; bool use_normals; bool use_colors; bool use_textures; bool use_data; //statistics: unsigned int tri_rendered; unsigned int tri_total; NexusMt(); ~NexusMt(); bool Load(const std::string &filename, bool readonly = true); bool InitGL(Vbo mode = VBO_AUTO, unsigned int vbo_size = 0); void Render(); void SetMetric(MetricKind kind); void SetError(float error); void SetRamExtractionSize(unsigned int ram_size); void SetVboSize(unsigned int vbo_size); void SetPrefetching(bool on); bool SetMode(Mode mode); bool SetComponent(Component c, bool on); bool SetComponents(unsigned int mask); void Draw(std::vector &selected); void Extract(std::vector &selected); protected: void LoadHistory(); void ClearHistory(); void VisitNode(Node *node, std::vector &heap); void Select(std::vector &selected); Patch &LoadPatch(unsigned int p); }; } #endif