| // ---------------------------------------------------------------------------- | |
| // - Open3D: www.open3d.org - | |
| // ---------------------------------------------------------------------------- | |
| // The MIT License (MIT) | |
| // | |
| // Copyright (c) 2018 www.open3d.org | |
| // | |
| // Permission is hereby granted, free of charge, to any person obtaining a copy | |
| // of this software and associated documentation files (the "Software"), to deal | |
| // in the Software without restriction, including without limitation the rights | |
| // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | |
| // copies of the Software, and to permit persons to whom the Software is | |
| // furnished to do so, subject to the following conditions: | |
| // | |
| // The above copyright notice and this permission notice shall be included in | |
| // all copies or substantial portions of the Software. | |
| // | |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
| // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
| // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | |
| // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | |
| // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | |
| // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | |
| // IN THE SOFTWARE. | |
| // ---------------------------------------------------------------------------- | |
| // A simplified version of examples/cpp/Visualizer.cpp to demonstrate linking | |
| // an external project to Open3D. | |
| int main(int argc, char *argv[]) { | |
| using namespace open3d; | |
| utility::SetVerbosityLevel(utility::VerbosityLevel::Debug); | |
| if (argc < 3) { | |
| utility::LogInfo("Open3D {}\n", OPEN3D_VERSION); | |
| utility::LogInfo("\n"); | |
| utility::LogInfo("Usage:\n"); | |
| utility::LogInfo(" > TestVisualizer [mesh|pointcloud] [filename]\n"); | |
| // CI will execute this file without input files, return 0 to pass | |
| return 0; | |
| } | |
| std::string option(argv[1]); | |
| if (option == "mesh") { | |
| auto mesh_ptr = std::make_shared<geometry::TriangleMesh>(); | |
| if (io::ReadTriangleMesh(argv[2], *mesh_ptr)) { | |
| utility::LogInfo("Successfully read {}\n", argv[2]); | |
| } else { | |
| utility::LogWarning("Failed to read {}\n\n", argv[2]); | |
| return 1; | |
| } | |
| mesh_ptr->ComputeVertexNormals(); | |
| visualization::DrawGeometries({mesh_ptr}, "Mesh", 1600, 900); | |
| } else if (option == "pointcloud") { | |
| auto cloud_ptr = std::make_shared<geometry::PointCloud>(); | |
| if (io::ReadPointCloud(argv[2], *cloud_ptr)) { | |
| utility::LogInfo("Successfully read {}\n", argv[2]); | |
| } else { | |
| utility::LogWarning("Failed to read {}\n\n", argv[2]); | |
| return 1; | |
| } | |
| cloud_ptr->NormalizeNormals(); | |
| visualization::DrawGeometries({cloud_ptr}, "PointCloud", 1600, 900); | |
| } else { | |
| utility::LogWarning("Unrecognized option: {}\n", option); | |
| return 1; | |
| } | |
| utility::LogInfo("End of the test.\n"); | |
| return 0; | |
| } | |