From 196d5579a88c3ee6e1a7f881ac2e41b3b3f0f517 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pedro=20Cort=C3=A9s?= <36660222+pedrocortesark@users.noreply.github.com> Date: Tue, 22 Oct 2024 11:46:05 +0200 Subject: [PATCH] #642 Adding support for point normals and colors --- src/bindings/bnd_pointcloud.cpp | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/src/bindings/bnd_pointcloud.cpp b/src/bindings/bnd_pointcloud.cpp index 838b61d5..89e35b7b 100644 --- a/src/bindings/bnd_pointcloud.cpp +++ b/src/bindings/bnd_pointcloud.cpp @@ -72,6 +72,7 @@ ON_3dVector BND_PointCloudItem::GetNormal() const return m_pointcloud->m_N[m_index]; return ON_3dVector::UnsetVector; } + void BND_PointCloudItem::SetNormal(const ON_3dVector& v) { if((m_index >= 0) && (m_index < m_pointcloud->m_P.Count())) @@ -808,13 +809,20 @@ BND_PointCloud* BND_PointCloud::CreateFromThreejsJSON(BND_DICT json) return nullptr; emscripten::val attributes = json["data"]["attributes"]; - // Adding data validation - if (emscripten::val::undefined() == attributes["position"] || - emscripten::val::undefined() == attributes["position"]["array"]) - return nullptr; - std::vector position_array = emscripten::vecFromJSArray(attributes["position"]["array"]); + std::vector normal_array; + if (emscripten::val::undefined() != attributes["normal"]) + { + normal_array = emscripten::vecFromJSArray(attributes["normal"]["array"]); + } + + std::vector color_array; + if (emscripten::val::undefined() != attributes["color"]) + { + color_array = emscripten::vecFromJSArray(attributes["normal"]["array"]); + } + ON_PointCloud* pc = new ON_PointCloud(); const int vertex_count = position_array.size() / 3; @@ -822,6 +830,16 @@ BND_PointCloud* BND_PointCloud::CreateFromThreejsJSON(BND_DICT json) pc->m_P.SetCount(vertex_count); memcpy(pc->m_P.Array(), position_array.data(), sizeof(double) * position_array.size()); + const int normal_count = normal_array.size() / 3; + pc->m_N.SetCapacity(normal_count); + pc->m_N.SetCount(normal_count); + memcpy(mesh->m_N.Array(), normal_array.data(), sizeof(double) * normal_array.size()); + + const int color_count = color_array.size() / 3; + pc->m_C.SetCapacity(color_count); + pc->m_C.SetCount(color_count); + memcpy(pc->m_C.Array(), color_array.data(), sizeof(double) * color_array.size()); + ON_Xform rotation(1); rotation.RotationZYX(0.0, 0.0, ON_PI / 2.0); pc->Transform(rotation);