mirror of https://github.com/opencv/opencv.git
parent
319dbd2eb7
commit
2848f43acc
2 changed files with 84 additions and 0 deletions
@ -0,0 +1,41 @@ |
||||
#ifndef CSVREADER_H |
||||
#define CSVREADER_H |
||||
|
||||
#include <iostream> |
||||
#include <fstream> |
||||
|
||||
#include <opencv2/core/core.hpp> |
||||
#include "Mesh.h" |
||||
|
||||
using namespace std; |
||||
using namespace cv; |
||||
|
||||
class CsvReader { |
||||
public: |
||||
/**
|
||||
* The default constructor of the CSV reader Class. |
||||
* The default separator is ' ' (empty space) |
||||
* |
||||
* @param path - The path of the file to read |
||||
* @param separator - The separator character between words per line |
||||
* @return |
||||
*/ |
||||
CsvReader(const std::string &path, const char &separator = ' '); |
||||
|
||||
/**
|
||||
* Read a plane text file with .ply format |
||||
* |
||||
* @param list_vertex - The container of the vertices list of the mesh |
||||
* @param list_triangle - The container of the triangles list of the mesh |
||||
* @return |
||||
*/ |
||||
void readPLY(std::vector<cv::Point3f> &list_vertex, std::vector<std::vector<int> > &list_triangles); |
||||
|
||||
private: |
||||
/** The current stream file for the reader */ |
||||
ifstream _file; |
||||
/** The separator character between words for each line */ |
||||
char _separator; |
||||
}; |
||||
|
||||
#endif |
@ -0,0 +1,43 @@ |
||||
/*
|
||||
* ModelRegistration.h |
||||
* |
||||
* Created on: Apr 18, 2014 |
||||
* Author: edgar |
||||
*/ |
||||
|
||||
#ifndef MODELREGISTRATION_H_ |
||||
#define MODELREGISTRATION_H_ |
||||
|
||||
#include <iostream> |
||||
#include <opencv2/core/core.hpp> |
||||
|
||||
class ModelRegistration |
||||
{ |
||||
public: |
||||
|
||||
ModelRegistration(); |
||||
virtual ~ModelRegistration(); |
||||
|
||||
void setNumMax(int n) { max_registrations_ = n; } |
||||
|
||||
std::vector<cv::Point2f> get_points2d() const { return list_points2d_; } |
||||
std::vector<cv::Point3f> get_points3d() const { return list_points3d_; } |
||||
int getNumMax() const { return max_registrations_; } |
||||
int getNumRegist() const { return n_registrations_; } |
||||
|
||||
bool is_registrable() const { return (n_registrations_ < max_registrations_); } |
||||
void registerPoint(const cv::Point2f &point2d, const cv::Point3f &point3d); |
||||
void reset(); |
||||
|
||||
private: |
||||
/** The current number of registered points */ |
||||
int n_registrations_; |
||||
/** The total number of points to register */ |
||||
int max_registrations_; |
||||
/** The list of 2D points to register the model */ |
||||
std::vector<cv::Point2f> list_points2d_; |
||||
/** The list of 3D points to register the model */ |
||||
std::vector<cv::Point3f> list_points3d_; |
||||
}; |
||||
|
||||
#endif /* MODELREGISTRATION_H_ */ |
Loading…
Reference in new issue