52 #ifndef OPENMESH_SUBDIVIDER_ADAPTIVE_COMPOSITET_HH
53 #define OPENMESH_SUBDIVIDER_ADAPTIVE_COMPOSITET_HH
58 #include <OpenMesh/Core/System/config.hh>
69 namespace Subdivider {
76 template <
typename R>
struct RuleHandleT;
77 template <
typename M>
class RuleInterfaceT;
137 typedef std::vector<Rule*> RuleSequence;
139 typedef typename M::VertexHandle VH;
140 typedef typename M::FaceHandle FH;
141 typedef typename M::EdgeHandle EH;
142 typedef typename M::HalfedgeHandle HH;
149 subdiv_rule_(NULL), mesh_(_mesh)
164 std::for_each(rule_sequence_.begin(),
165 rule_sequence_.end(), DeleteRule() );
166 rule_sequence_.clear();
171 bool initialize(
void);
175 void refine(
typename M::FaceHandle& _fh);
179 void refine(
typename M::VertexHandle& _vh);
187 const Rule& subdiv_rule()
const {
return *subdiv_rule_; }
198 template <
typename R >
201 size_t idx = rule_sequence_.size();
202 rule_sequence_.push_back(
new R( mesh_ ) );
203 return RuleHandleT<R>( (idx < rule_sequence_.size()) ? idx : -1 );
210 template <
typename R >
213 return _rh = add< R >();
221 template <
typename R >
224 typedef typename RuleHandleT<R>::Rule rule_t;
226 return *
dynamic_cast<rule_t*
>(rule_sequence_[ _rh.
idx() ]);
238 return *rule_sequence_[ _idx ];
242 size_t n_rules()
const {
return rule_sequence_.size(); }
245 std::string rules_as_string(
const std::string& _sep=
" * ")
const;
252 const RuleSequence&
rules()
const {
return rule_sequence_; }
258 state_t generation( VH _vh ) {
return generation(mesh_.data(_vh).state()); }
259 state_t generation( EH _eh ) {
return generation(mesh_.data(_eh).state()); }
260 state_t generation( FH _fh ) {
return generation(mesh_.data(_fh).state()); }
265 Rule* t_rule() {
return subdiv_rule_; }
266 Rule* f_rule() {
return rule_sequence_.front(); }
267 Rule* l_rule() {
return rule_sequence_.back(); }
272 RuleSequence rule_sequence_;
286 #ifndef DOXY_IGNORE_THIS
287 struct DeleteRule {
void operator()( Rule* _r ) {
delete _r; } };
303 #if defined(OM_INCLUDE_TEMPLATES) && !defined(OPENMESH_SUBDIVIDER_ADAPTIVE_COMPOSITET_CC)
304 # define OPENMESH_SUBDIVIDER_TEMPLATES
305 # include "CompositeT.cc"
308 #endif // OPENMESH_SUBDIVIDER_ADAPTIVE_COMPOSITET_HH defined