- added a "only on selection" option to VertexUniform and AllVertex sampling functions

- added a "isD" check to VertexUniform sampling function

to be tested
This commit is contained in:
Marco Callieri 2015-10-29 13:44:25 +00:00
parent e814e3a9f5
commit 6715e4f658
1 changed files with 35 additions and 18 deletions

View File

@ -504,15 +504,19 @@ static int Poisson(double lambda)
static void AllVertex(MeshType & m, VertexSampler &ps) static void AllVertex(MeshType & m, VertexSampler &ps)
{
AllVertex(m, ps, false);
}
static void AllVertex(MeshType & m, VertexSampler &ps, bool onlySelected)
{ {
VertexIterator vi; VertexIterator vi;
for(vi=m.vert.begin();vi!=m.vert.end();++vi) for(vi=m.vert.begin();vi!=m.vert.end();++vi)
{
if(!(*vi).IsD()) if(!(*vi).IsD())
if ((!onlySelected) || ((*vi).IsS()))
{ {
ps.AddVert(*vi); ps.AddVert(*vi);
} }
}
} }
/// Sample the vertices in a weighted way. Each vertex has a probability of being chosen /// Sample the vertices in a weighted way. Each vertex has a probability of being chosen
@ -603,18 +607,31 @@ static void FillAndShuffleVertexPointerVector(MeshType & m, std::vector<VertexPo
} }
/// Sample the vertices in a uniform way. Each vertex has the same probabiltiy of being chosen. /// Sample the vertices in a uniform way. Each vertex has the same probabiltiy of being chosen.
static void VertexUniform(MeshType & m, VertexSampler &ps, int sampleNum) static void VertexUniform(MeshType & m, VertexSampler &ps, int sampleNum, bool onlySelected)
{ {
if(sampleNum>=m.vn) { if (sampleNum >= m.vn) {
AllVertex(m,ps); AllVertex(m, ps, onlySelected);
return; return;
} }
std::vector<VertexPointer> vertVec; std::vector<VertexPointer> vertVec;
FillAndShuffleVertexPointerVector(m,vertVec); FillAndShuffleVertexPointerVector(m, vertVec);
for(int i =0; i< sampleNum; ++i) int added = 0;
for (int i = 0; ((i < m.vn) && (added < sampleNum)); ++i)
if (!(*vertVec[i]).IsD())
if ((!onlySelected) || (*vertVec[i]).IsS())
{
ps.AddVert(*vertVec[i]); ps.AddVert(*vertVec[i]);
added++;
}
}
static void VertexUniform(MeshType & m, VertexSampler &ps, int sampleNum)
{
VertexUniform(m, ps, sampleNum, false);
} }