cgal/Stream_support/test/Stream_support/test_LAS.cpp

64 lines
2.1 KiB
C++

#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/property_map.h>
#include <CGAL/IO/read_las_points.h>
#include <utility>
#include <vector>
#include <fstream>
// types
typedef CGAL::Exact_predicates_inexact_constructions_kernel Kernel;
typedef Kernel::FT FT;
typedef Kernel::Point_3 Point;
typedef std::array<unsigned short, 4> Color;
typedef std::pair<Point, Color> PointWithColor;
int main(int argc, char* argv[])
{
std::ifstream is("data/colored_points.las");
// Reads a .las point set file with normal vectors and colors
std::vector<PointWithColor> points; // store points
if (!CGAL::IO::read_LAS_with_properties(is, std::back_inserter(points),
CGAL::IO::make_las_point_reader(CGAL::First_of_pair_property_map<PointWithColor>()),
std::make_tuple(CGAL::Second_of_pair_property_map<PointWithColor>(),
CGAL::Construct_array(),
CGAL::IO::LAS_property::R(),
CGAL::IO::LAS_property::G(),
CGAL::IO::LAS_property::B(),
CGAL::IO::LAS_property::I())))
{
std::cerr << "Error: cannot read file data/colored_points.las" << std::endl;
return EXIT_FAILURE;
}
CGAL_assertion(points.size() == 5);
CGAL_assertion(points[0].second[0] == 65535);
CGAL_assertion(points[0].second[1] == 0);
CGAL_assertion(points[0].second[2] == 0);
CGAL_assertion(points[0].second[3] == 0);
CGAL_assertion(points[1].second[0] == 0);
CGAL_assertion(points[1].second[1] == 65535);
CGAL_assertion(points[1].second[2] == 0);
CGAL_assertion(points[1].second[3] == 0);
CGAL_assertion(points[2].second[0] == 0);
CGAL_assertion(points[2].second[1] == 0);
CGAL_assertion(points[2].second[2] == 65535);
CGAL_assertion(points[2].second[3] == 0);
CGAL_assertion(points[3].second[0] == 0);
CGAL_assertion(points[3].second[1] == 65535);
CGAL_assertion(points[3].second[2] == 65535);
CGAL_assertion(points[3].second[3] == 0);
CGAL_assertion(points[4].second[0] == 65535);
CGAL_assertion(points[4].second[1] == 65535);
CGAL_assertion(points[4].second[2] == 0);
CGAL_assertion(points[4].second[3] == 0);
return EXIT_SUCCESS;
}