本文整理汇总了C++中TriangleList::size方法的典型用法代码示例。如果您正苦于以下问题:C++ TriangleList::size方法的具体用法?C++ TriangleList::size怎么用?C++ TriangleList::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TriangleList
的用法示例。
在下文中一共展示了TriangleList::size方法的14个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: generateEventList
void KDTree::generateEventList( TriangleList& triList, AABB& parentBox )
{
//Start with an empty event list
eventList.clear();
//Go through all the triangles passed in.
for(unsigned i = 0; i < triList.size(); ++i)
{
//Clip the triangle to the parent box
Triangle tri = triList[i];
clipTriToParentBox(tri, parentBox);
//And the box be the AABB of this event
AABB* pBox = &parentBox;
//Grab the minimum and maximum points of the triangle as per this split axis
float pMin = GeometryLibrary::minPos(tri, curAxis);
float pMax = GeometryLibrary::maxPos(tri, curAxis);
//If the maximum and minimum points are the same, we have a coplanar event
if(pMax == pMin)
eventList.push_back(KDEvent(Coplanar, &tri, pMin, pBox));
//Otherwise start at the minimum and end at the maximum on this axis
else
{
eventList.push_back(KDEvent(Starting, &tri, pMin, pBox));
eventList.push_back(KDEvent(Ending, &tri, pMax, pBox));
}
}
//Sort according to the operator < provided so that the events are in ascending order
std::sort(eventList.begin(), eventList.end());
}
示例2: FindNeighbors
void MeshMender::FindNeighbors(Triangle* tri,
TriangleList&possibleNeighbors,
Triangle** neighbor1,
Triangle** neighbor2,
std::vector< Vertex >& theVerts)
{
*neighbor1 = NULL;
*neighbor2 = NULL;
std::vector<Triangle*> theNeighbors;
for(unsigned int n = 0; n < possibleNeighbors.size(); ++n)
{
TriID tID = possibleNeighbors[n];
Triangle* possible =&(m_Triangles[ tID]);
if(possible != tri ) //check for myself
{
if( SharesEdge(tri, possible, theVerts) )
{
theNeighbors.push_back(possible);
}
}
}
if(theNeighbors.size()>0)
*neighbor1 = theNeighbors[0];
if(theNeighbors.size()>1)
*neighbor2 = theNeighbors[1];
}
示例3: lambda
Deform::Deform(const float *P_data, int P_Num, const AdjList &adj_list, const TriangleList &triangle_list)
:at(ORIGIN_HARD),
P_data(P_data),
P_Num(P_Num),
max_iter(10),
min_tol(1e-3),
lambda(5),
adj_list(adj_list)
{
for (size_t i = 0, i_end = triangle_list.size(); i < i_end; ++ i)
{
std::vector<int> face = triangle_list[i];
std::sort(face.begin(), face.end());
assert(face.size() == 3);
face_list.push_back(Eigen::Vector3i(face[0], face[1], face[2]));
}
P.resize(3, P_Num);
for (int i = 0; i != P_Num; ++i) {P.col(i) << P_data[3*i], P_data[3*i+1], P_data[3*i+2];}
P_Prime = P;
R = vector<Matrix3f>(P_Num, Matrix3f::Identity());
// Weight
build_weight_matrix();
}
示例4: reset
void TriangleDensityWidget::reset()
{
TriangleList triangles = triangleScene->triangles();
// make more sliders if necessary
while (sliders.size() < triangles.size())
{
GroupedSlider* s
= new GroupedSlider(Qt::Horizontal, this, sliders.size());
QLabel* name = new QLabel(QString::number(sliders.size() + 1));
QHBoxLayout* hl = new QHBoxLayout();
hl->addWidget(name);
hl->addWidget(s);
dynamic_cast<QVBoxLayout*>
(m_scrollAreaWidgetContents->layout())->insertLayout(-1,hl,0);
s->setRange(0, 1000);
s->setVisible(false);
sliders.append(s);
slider_names.append(name);
connect(s, SIGNAL(valueChanged(int)), this, SLOT(groupedSliderChangedSlot(int)));
connect(s, SIGNAL(sliderPressed()), this, SLOT(groupedSliderPressedSlot()));
connect(s, SIGNAL(undoStateSignal()), this, SIGNAL(undoStateSignal()));
}
// hide non-used sliders
for (int n = triangles.size() ; n < sliders.size() ; n++)
{
sliders.at(n)->setVisible(false);
slider_names.at(n)->setVisible(false);
}
resetSliders(getNorm());
QStringList items;
items << tr("None");
for (int n = 1 ; n <= genome->size() ; n++)
items << QString::number(n);
int n = m_crossComboBox->currentIndex();
m_crossComboBox->blockSignals(true);
m_crossComboBox->clear();
m_crossComboBox->addItems(items);
m_crossComboBox->setCurrentIndex(n);
m_crossComboBox->blockSignals(false);
}
示例5: phiFunction
double phiFunction(QPointF *points, quint32 size, quint32 layers,
QPointF point, quint32 vertexNumber, QPointF *centerPtr) {
Vertex vertex = getVertex(size, vertexNumber);
TriangleList triangles = getSurroundingTriangles(points, size,
layers, vertex, centerPtr);
for (int i = 0; i < triangles.size(); ++i) {
if (pointInTriangle(point, triangles.at(i)))
return phiFunction(point, triangles.at(i),
getPoint(points, size, layers, vertex, centerPtr));
}
return 0;
}
示例6: findMinPlane
void KDTree::findMinPlane(TriangleList& triList, AABB& parentBox)
{
unsigned Nl, Nr, Nc, Vs, Ve, Vc;
Vs = Ve = Vc = 0;
//Set minimum cost to infinite
minCost = FLT_MAX;
//For every possible axis,
for(unsigned i = 0; i < NumAxes; ++i)
{
//Generate the event list for this axis
curAxis = (SplitAxis)i;
generateEventList(triList, parentBox);
//All of the triangles are to our right.
//These will remain through iterations on positions
Nl = 0;
Nr = triList.size();
Nc = 0;
//For every position
for(unsigned j = 0; j < eventList.size(); )
{
float curPos = eventList[j].eventPos;
Vs = Ve = Vc = 0;
//Count the triangles starting, ending, and coplanar with this position
//This will advance j to the next event position
countTrisOfEvent(Vs, Ve, Vc, j, curPos);
Nc = Vc;
Nr -= Ve + Vc;
//The last index is the positions we care about.
calcCostOfPlane(Nl, Nr, Nc, parentBox, curPos);
Nl += Vs + Vc;
//Update the lowest possible plane
if(curCost < minCost)
{
minCost = curCost;
//Save what axis and position we're going to cut at so far...
splitPos = curPos;
splitAxis = curAxis;
}
}
}
}
示例7: numSurfaceIntersections
inline unsigned numSurfaceIntersections(const V3 &voxelPos, const V3 &dir)
{
unsigned numHits = 0;
/********* ASSIGNMENT *********/
/* Check and return the number of times a ray cast in direction dir,
* from voxel center voxelPos intersects the surface */
CompFab::Ray r;
for (int i = 0; i < triangleList.size(); i++) {
r = CompFab::Ray(voxelPos, dir);
if (rayTriangleIntersection(r, triangleList[i])) {
numHits += 1;
}
}
return numHits;
}
示例8: UpdateIndices
void MeshMender::UpdateIndices(const size_t oldIndex , const size_t newIndex , TriangleList& curGroup)
{
//make any triangle that used the oldIndex use the newIndex instead
for( size_t t = 0; t < curGroup.size(); ++t )
{
TriID tID = curGroup[ t ];
for(size_t indx = 0 ; indx < 3 ; ++indx)
{
if(m_Triangles[tID].indices[indx] == oldIndex)
{
m_Triangles[tID].indices[indx] = newIndex;
}
}
}
}
示例9: splitTriList
void KDTree::splitTriList( TriangleList& l, TriangleList& r, TriangleList& p, float pos )
{
curAxis = splitAxis;
unsigned left, right, coplanar, side;
//Go through every triangle in the triangle list
for(unsigned i = 0; i < p.size(); ++i)
{
Triangle& tri = p[i];
left = right = coplanar = 0;
CountVertPositions(tri, left, right, coplanar, splitAxis, pos);
side = max(left, max(right, coplanar));
if(side == left)
l.push_back(tri);
else if(side == right)
r.push_back(tri);
else if(side == coplanar)
l.push_back(tri);
}
}
示例10: ProcessBinormals
void MeshMender::ProcessBinormals(TriangleList& possibleNeighbors,
std::vector< Vertex >& theVerts,
std::vector< unsigned int >& mappingNewToOldVert,
D3DXVECTOR3 workingPosition)
{
NeighborGroupList neighborGroups;//a fresh group for each pass
//reset each triangle to prepare for smoothing group building
unsigned int i;
for(i =0; i < possibleNeighbors.size(); ++i )
{
m_Triangles[ possibleNeighbors[i] ].Reset();
}
//now start building groups
CanSmoothBinormalsChecker canSmoothBinormalsChecker;
for(i =0; i < possibleNeighbors.size(); ++i )
{
Triangle* currTri = &(m_Triangles[ possibleNeighbors[i] ]);
assert(currTri);
if(!currTri->handled)
{
BuildGroups(currTri,possibleNeighbors,
neighborGroups, theVerts,
&canSmoothBinormalsChecker ,MinBinormalsCreaseCosAngle );
}
}
std::vector<D3DXVECTOR3> groupBinormalVectors;
for(i=0; i<neighborGroups.size(); ++i)
{
D3DXVECTOR3 gbinormal(0,0,0);
for(unsigned int t = 0; t < neighborGroups[i].size(); ++t)//for each triangle in the group,
{
TriID tID = neighborGroups[i][t];
gbinormal+= m_Triangles[tID].binormal;
}
gbinormal = glm::normalize(gbinormal.GLMvec());//D3DXVec3Normalize( &gbinormal, &gbinormal );
groupBinormalVectors.push_back(gbinormal);
}
//next step, ensure that triangles in different groups are not
//sharing vertices. and give the shared vertex their new group vector
std::set<size_t> otherGroupsIndices;
for( i = 0; i < neighborGroups.size(); ++i )
{
TriangleList& curGroup = neighborGroups[ i ];
std::set<size_t> thisGroupIndices;
for( size_t t = 0; t < curGroup.size(); ++t ) //for each tri
{
TriID tID = curGroup[ t ];
for(size_t indx = 0; indx < 3 ; ++indx)//for each vert in that tri
{
//if it is at the positions in question
if( theVerts[ m_Triangles[tID].indices[indx] ].pos == workingPosition)
{
//see if another group is already using this vert
if(otherGroupsIndices.find( m_Triangles[tID].indices[indx] ) != otherGroupsIndices.end() )
{
//then we need to make a new vertex
Vertex ov;
ov = theVerts[ m_Triangles[tID].indices[indx] ];
ov.binormal = groupBinormalVectors[i];
size_t oldIndex = m_Triangles[tID].indices[indx];
size_t newIndex = theVerts.size();
theVerts.push_back(ov);
AppendToMapping( oldIndex , m_originalNumVerts , mappingNewToOldVert);
UpdateIndices(oldIndex,newIndex,curGroup);
}
else
{
//otherwise, just update it with the new vector
theVerts[ m_Triangles[tID].indices[indx] ].binormal = groupBinormalVectors[i];
}
//store that we have used this index, so other groups can check
thisGroupIndices.insert(m_Triangles[tID].indices[indx]);
}
}
}
for(std::set<size_t>::iterator it = thisGroupIndices.begin(); it!= thisGroupIndices.end() ; ++it)
{
otherGroupsIndices.insert(*it);
}
}
}
示例11: DeallocateGeometry
//.........这里部分代码省略.........
// Get rid of the mesh
pSubsetIB->Release();
d3dxMesh->UnlockVertexBuffer();
d3dxMesh->Release();
// Free our device
pd3dDevice->Release();
// Error!
return false;
}
// This table pairs an index from the .X file to an index in the buffer that
// holds the vertices for this subset
XIndicesTable xIndicesTable;
// For each of the indices in the strip, puts its vertex ID into the indices
// table. Use the counter to determine which vertex this is.
{
GeometryIndex vertexCounter = 0;
for (DWORD e = 0; e < numStripIndices; ++e)
{
// Insert the entry [x-mesh index, subset index] into the table
XIndicesTableInsertResult result = xIndicesTable.insert(XIndicesEntry(pXIndices[e], vertexCounter));
// If the result was successful (this isn't a duplicated X-mesh index) increment the vertex counter
if (result.second)
vertexCounter++;
}
}
// Grab the number of vertices this geometry uses
DWORD numVertices = (DWORD)xIndicesTable.size();
// This buffer holds all of the triangles in this subset
TriangleList triangles;
// This list keeps track of locations in the strip where the winding order changes. This is necessary
// because this next part will remove degenerate triangles from the list.
std::set<size_t> windingChanges;
// Generate the list of triangles from the strip provided
for (DWORD t = 0; t < numStripIndices - 2; ++t)
{
// Build the triangle that will be added to the buffer
// CHANGED July 25, 2008: the winding order is wrong here
//Triangle tri = { pXIndices[t + 0], pXIndices[t + 1], pXIndices[t + 2] };
Triangle tri = { pXIndices[t + 0], pXIndices[t + 2], pXIndices[t + 1] };
// Convert the triangle into subset-indices by using the lookup table
// we generated before.
tri.index[0] = xIndicesTable.find(tri.index[0])->second;
tri.index[1] = xIndicesTable.find(tri.index[1])->second;
tri.index[2] = xIndicesTable.find(tri.index[2])->second;
// Check to make sure this triangle isn't degenerate. If it is, we can just skip
// this triangle entirely to simplify the geometry.
if (tri.index[0] == tri.index[1] || tri.index[1] == tri.index[2] || tri.index[0] == tri.index[2])
{
// Try to find the winding in the list
std::set<size_t>::iterator currentWinding = windingChanges.find(triangles.size());
// Add this to the winding change list, or remove the change if it's already there
示例12: Render
void Renderer::Render( void )
{
for (unsigned i = 0; i < m_renderUnitList.size(); i++)
{
RenderUnit* renderUnit = m_renderUnitList[i];
unsigned nVerts = renderUnit->m_vb->Size();
unsigned nTriangles = renderUnit->m_ib->Size() / 3;
VsOutList vsOuts(nVerts);
TriangleList triangles;
// 对每个顶点执行VS
for (unsigned j = 0; j < nVerts; j++)
{
vsOuts[j] = renderUnit->m_vs->Main((*renderUnit->m_vb)[j]);
}
// triangle setup (trivial-rejection, clipping)
for (unsigned j = 0; j < nTriangles; j++)
{
Triangle tri;
tri.iV0 = (*renderUnit->m_ib)[3 * j + 0];
tri.iV1 = (*renderUnit->m_ib)[3 * j + 1];
tri.iV2 = (*renderUnit->m_ib)[3 * j + 2];
if (TrivialReject(tri, vsOuts))
{
continue;
}
else if (RemoveBackface(tri, vsOuts, CULL_MODE_CCW))
{
continue;
}
else if (TrivialAccept(tri, vsOuts))
{
triangles.push_back(tri);
}
else
{
// TODO: do clipping here
triangles.push_back(tri);
}
}
int halfRtWidth = m_renderTarget->GetWidth() >> 1;
int halfRtHeight = m_renderTarget->GetHeight() >> 1;
for (unsigned j = 0; j < vsOuts.size(); j++)
{
Vector4& position = vsOuts[j].position;
// perspective-divide
position.x /= position.w;
position.y /= position.w;
position.z /= position.w;
// 转化到屏幕坐标
position.x = ( position.x + 1.0f) * halfRtWidth;
position.y = (-position.y + 1.0f) * halfRtHeight;
}
// 光栅化每个三角形
for (unsigned j = 0; j < triangles.size(); j++)
{
VertexShaderOutput& v0 = vsOuts[triangles[j].iV0];
VertexShaderOutput& v1 = vsOuts[triangles[j].iV1];
VertexShaderOutput& v2 = vsOuts[triangles[j].iV2];
if (renderUnit->m_wireFrame) // fill mode: wireframe
{
int x0 = int(v0.position.x);
int y0 = int(v0.position.y);
int x1 = int(v1.position.x);
int y1 = int(v1.position.y);
int x2 = int(v2.position.x);
int y2 = int(v2.position.y);
DrawLine(x0, y0, x1, y1, 0xFFFFFFFF);
DrawLine(x0, y0, x2, y2, 0xFFFFFFFF);
DrawLine(x1, y1, x2, y2, 0xFFFFFFFF);
}
else // fill mode: solid
{
VertexShaderOutput* sv;
VertexShaderOutput* mv;
VertexShaderOutput* ev;
// 按Y值给三个顶点排序
if (v0.position.y < v1.position.y)
{
sv = &v0;
ev = &v1;
}
else
{
sv = &v1;
ev = &v0;
}
//.........这里部分代码省略.........
示例13: initGeometry
void GeometryEngine::initGeometry(TriangleList triangles, QVector<QVector3D> lines, QVector<QVector3D> points)
{
isTransparent = false;
initializeOpenGLFunctions();
glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
// Generate 2 VBOs
arrayBuf.create();
indexBuf.create();
arrayBufLines.create();
arrayBufPoints.create();
std::vector<VertexData> vertices;
std::vector<GLuint> indices;
std::vector<GLuint> tmp(3);
// iterate over all triangles
for (uint i = 0; i < triangles.size(); i++) {
// iterate over all vertices in triangle
for (int j = 0; j < 3; j++) {
// create vertex with texture coords
VertexData vertex = {
QVector3D(triangles[i][j][0], triangles[i][j][1], triangles[i][j][2]),
QVector2D(abs(((j+1)%2)-1), abs(((j+1)%3)-1)) // tex coords (0,0),(1,1),(0,1)
};
// is vertex already in indices?
GLuint idx = indexOf(vertices, vertex);
if (idx >= vertices.size()) {
// no, add it to the end of the list
//idx = vertices.size();
vertices.push_back(vertex);
}
// prime the index of current vertex for insertion
tmp[j] = idx;
}
// insert vertex indices of current triangle
indices.insert(indices.end(), tmp.begin(), tmp.end());
// render both sides of triangles, for now as a #define option
#if TWO_SIDED
std::reverse(tmp.begin(), tmp.end());
indices.insert(indices.end(), tmp.begin(), tmp.end());
#endif
}
#if DEBUG
std::cout << "Vertices:" << std::endl << vertices.size() << std::endl;
for (auto i = vertices.begin(); i != vertices.end(); ++i)
std::cout << "(" << (*i).position[0] <<"," << (*i).position[1] <<"," << (*i).position[2] <<")" << ' ';
std::cout << std::endl;
std::cout << "Indices:" << std::endl << indices.size() << std::endl;
for (auto i = indices.begin(); i != indices.end(); ++i)
std::cout << *i << ' ';
std::cout << std::endl;
#endif
arrayBuf.bind();
arrayBuf.allocate(&vertices[0], vertices.size() * sizeof(VertexData));
indexBuf.bind();
indexBuf.allocate(&indices[0], indices.size() * sizeof(GLuint));
idxLen = indices.size();
if (!lines.empty())
{
arrayBufLines.bind();
arrayBufLines.allocate(&lines[0], lines.size() * sizeof(QVector3D));
}
if (!points.empty())
{
arrayBufPoints.bind();
arrayBufPoints.allocate(&points[0], points.size() * sizeof(QVector3D));
}
}
示例14: triangulate
void Triangulator::triangulate(const Contour &contour, TriangleList &triangles, int index_offset) {
Path path;
build_path(contour, path, index_offset);
triangles.reserve(triangles.size() + 3*(path.size() - 2));
split_path(&path.front(), triangles);
}