29 #include "WSelectorBranch.h"
33 m_size( fibers->size() ),
37 m_bitField = std::shared_ptr< std::vector<bool> >(
new std::vector<bool>(
m_size,
false ) );
40 std::shared_ptr< boost::function< void() > >(
new boost::function< void() >( boost::bind( &
WSelectorBranch::setDirty,
this ) ) );
44 std::shared_ptr< boost::function< void() > >(
new boost::function< void() >( boost::bind( &
WSelectorBranch::setDirty,
this ) ) );
52 for( std::list< std::shared_ptr< WSelectorRoi > >::iterator roiIter =
m_rois.begin(); roiIter !=
m_rois.end(); ++roiIter )
76 for( std::list< std::shared_ptr< WSelectorRoi > >::iterator iter =
m_rois.begin(); iter !=
m_rois.end(); ++iter )
78 if( ( *iter )->getRoi() == roi )
89 bool atLeastOneActive =
false;
91 for( std::list< std::shared_ptr< WSelectorRoi > >::iterator iter =
m_rois.begin(); iter !=
m_rois.end(); ++iter )
93 if( ( *iter )->getRoi()->active() )
95 atLeastOneActive =
true;
99 if( atLeastOneActive )
103 for( std::list< std::shared_ptr< WSelectorRoi > >::iterator iter =
m_rois.begin(); iter !=
m_rois.end(); ++iter )
105 if( ( *iter )->getRoi()->active() )
107 std::shared_ptr< std::vector<bool> > bf = ( *iter )->getBitField();
108 bool isnot = ( *iter )->getRoi()->isNot();
111 for(
size_t i = 0 ; i <
m_size ; ++i )
113 ( *m_workerBitfield )[i] = ( *m_workerBitfield )[i] & ( *bf )[i];
118 for(
size_t i = 0 ; i <
m_size ; ++i )
120 ( *m_workerBitfield )[i] = ( *m_workerBitfield )[i] & !( *bf )[i];
128 for(
size_t i = 0 ; i <
m_size ; ++i )
130 ( *m_workerBitfield )[i] = !( *m_workerBitfield )[i];
144 return m_branch->colorProperty()->toPropColor()->get(
true );
void setDirty()
Sets the dirty flag.
WColor getBranchColor() const
Return the current branch color.
WSelectorBranch(std::shared_ptr< const WDataSetFibers > fibers, std::shared_ptr< WRMBranch > branch)
constructor
std::shared_ptr< boost::function< void() > > m_changeRoiSignal
Signal that can be used to update the selector branch.
std::shared_ptr< boost::function< void() > > m_changeSignal
Signal that can be used to update the selector branch.
std::shared_ptr< WRMBranch > m_branch
pointer to the branch object in the roi manager
~WSelectorBranch()
destructor
std::shared_ptr< std::vector< bool > > m_workerBitfield
the bitfield we work on
size_t m_size
size of the fiber dataset, stored for convinience
void removeRoi(osg::ref_ptr< WROI > roi)
Removes a roi fromt he branch.
std::list< std::shared_ptr< WSelectorRoi > > m_rois
list of rois in this branch
void addRoi(std::shared_ptr< WSelectorRoi > roi)
adds a roi to the branch
std::shared_ptr< std::vector< bool > > m_bitField
the bitfield given to the outside world
void recalculate()
updates the output bitfield with the information from all rois in this branch
std::list< std::shared_ptr< WSelectorRoi > > getROIs()
Queries the ROIs.