CGI/exercise4/include/LineSegment.h

51 lines
1.7 KiB
C
Raw Normal View History

2019-01-24 14:38:18 +00:00
// This source code is property of the Computer Graphics and Visualization
// chair of the TU Dresden. Do not distribute!
2018-09-06 12:35:43 +00:00
// Copyright (C) CGV TU Dresden - All Rights Reserved
#pragma once
#include "Box.h"
#include "GridUtils.h"
#include <util/OpenMeshUtils.h>
/*
a 3d line segment primitive which can be used with the AABBTree and the HashGrid data structure
*/
class LineSegment
{
//internal storage of start point of line segment
Eigen::Vector3f v0;
//internal storage of end point of line segment
Eigen::Vector3f v1;
//internal storage for an edge handle
//this edge handle can be used to optionally identify the edge in a halfedge mesh data structure instance
OpenMesh::EdgeHandle h;
2019-01-24 14:38:18 +00:00
public:
2018-09-06 12:35:43 +00:00
//default constructor
LineSegment();
//constructs a line segment by the two end points v0, v1 without using the edge handle
2019-01-24 14:38:18 +00:00
LineSegment(const Eigen::Vector3f &v0, const Eigen::Vector3f &v1);
2018-09-06 12:35:43 +00:00
//construct a line segment from the edge e of the halfedge mesh m
2019-01-24 14:38:18 +00:00
LineSegment(const HEMesh &m, const OpenMesh::EdgeHandle &e);
2018-09-06 12:35:43 +00:00
//returns an axis aligned bounding box of the line segment
Box ComputeBounds() const;
2019-01-24 14:38:18 +00:00
2018-09-06 12:35:43 +00:00
//returns true if the line segment overlaps the given box b
2019-01-24 14:38:18 +00:00
bool Overlaps(const Box &b) const;
2018-09-06 12:35:43 +00:00
//returns the point with smallest distance topoint p which lies on the line segment
2019-01-24 14:38:18 +00:00
Eigen::Vector3f ClosestPoint(const Eigen::Vector3f &p) const;
2018-09-06 12:35:43 +00:00
//returns the squared distance between point p and the line segment
2019-01-24 14:38:18 +00:00
float SqrDistance(const Eigen::Vector3f &p) const;
2018-09-06 12:35:43 +00:00
//returns the euclidean distance between point p and the line segment
2019-01-24 14:38:18 +00:00
float Distance(const Eigen::Vector3f &p) const;
2018-09-06 12:35:43 +00:00
//returns a reference point which is on the line segment and is used to sort the primitive in the AABB tree construction
Eigen::Vector3f ReferencePoint() const;
};