2D outline algorithm for projected 3D mesh

前端 未结 6 1550
执念已碎
执念已碎 2021-01-30 03:21

Given: A 3D mesh defined with a set of vertices and triangles building up the mesh with these points.

Problem: Find the 2d outline of the projected arbitrarily rotated m

6条回答
  •  失恋的感觉
    2021-01-30 04:02

    The 2D outline of the mesh projection is a subset of the projection of its edges.

    Using this observation, one can determine the 2D outline using the following method:

    • the projection of every edge belonging to only one face is part of the 2D outline,
    • for other edges, determine the normal vector of its adjacent faces
    • calculate the dot products of those normals with the normal of the plane of projection
    • the projection of this edge belongs to the 2D outline if all the signs of the dot products not the same (which means, one face is pointing towards the projection plane while at least one other doesn't, which identifies the edge as part of the outline).

    Note that this method will report all the edges that are orthogonal to the projection plane, even those which are not visible from the projection plane's point of view. For example, with a torus, it will find the interior and the exterior outlines, even when the torus is rotated in such a way that its interior hole isn't visible from the projection plane's point of view. To sort out which edges are visible, you will need some sort of visibility test. If the intended use is for user display, you can use a depth buffer computed with an orthogonal projection matrix to render the geometry from the projection plane's point-of-view and do some z-testing to determine which edges are visible from the plane. If you need precision, you will need to perform ray/triangle intersection to determine visibility.

提交回复
热议问题