File: DebugUtil.h

package info (click to toggle)
open3d 0.19.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 83,496 kB
  • sloc: cpp: 206,543; python: 27,254; ansic: 8,356; javascript: 1,883; sh: 1,527; makefile: 259; xml: 69
file content (40 lines) | stat: -rw-r--r-- 1,521 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
// ----------------------------------------------------------------------------
// -                        Open3D: www.open3d.org                            -
// ----------------------------------------------------------------------------
// Copyright (c) 2018-2024 www.open3d.org
// SPDX-License-Identifier: MIT
// ----------------------------------------------------------------------------

#pragma once

#include "open3d/Open3D.h"

namespace open3d {
namespace apps {
namespace offline_reconstruction {

static const Eigen::Matrix4d flip_transformation = Eigen::Matrix4d({
        {1, 0, 0, 0},
        {0, -1, 0, 0},
        {0, 0, -1, 0},
        {0, 0, 0, 1},
});

void DrawRegistrationResult(const geometry::PointCloud& src,
                            const geometry::PointCloud& dst,
                            const Eigen::Matrix4d& transformation,
                            bool keep_color = false) {
    auto transformed_src = std::make_shared<geometry::PointCloud>(src);
    auto transformed_dst = std::make_shared<geometry::PointCloud>(dst);
    if (!keep_color) {
        transformed_src->PaintUniformColor(Eigen::Vector3d(1, 0.706, 0));
        transformed_dst->PaintUniformColor(Eigen::Vector3d(0, 0.651, 0.929));
    }
    transformed_src->Transform(flip_transformation * transformation);
    transformed_dst->Transform(flip_transformation);
    visualization::DrawGeometries({transformed_src, transformed_dst});
}

}  // namespace offline_reconstruction
}  // namespace apps
}  // namespace open3d