File: point_list_from_matrices.cpp

package info (click to toggle)
sight 25.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 43,252 kB
  • sloc: cpp: 310,629; xml: 17,622; ansic: 9,960; python: 1,379; sh: 144; makefile: 33
file content (110 lines) | stat: -rw-r--r-- 3,179 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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/************************************************************************
 *
 * Copyright (C) 2018-2024 IRCAD France
 * Copyright (C) 2018-2021 IHU Strasbourg
 *
 * This file is part of Sight.
 *
 * Sight is free software: you can redistribute it and/or modify it under
 * the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Sight is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with Sight. If not, see <https://www.gnu.org/licenses/>.
 *
 ***********************************************************************/

#include "point_list_from_matrices.hpp"

#include <core/com/signal.hxx>

#include <data/string.hpp>

#include <service/macros.hpp>

namespace sight::module::geometry
{

//-----------------------------------------------------------------------------

point_list_from_matrices::point_list_from_matrices() :
    filter(m_signals)
{
}

//-----------------------------------------------------------------------------

point_list_from_matrices::~point_list_from_matrices()
= default;

//-----------------------------------------------------------------------------

void point_list_from_matrices::configuring()
{
    const config_t config_tree = this->get_config();
    const config_t config      = config_tree.get_child("config.<xmlattr>");
    if(!config.empty())
    {
        m_append = config.get<bool>("append", m_append);
    }
}

//-----------------------------------------------------------------------------

void point_list_from_matrices::starting()
{
}

//-----------------------------------------------------------------------------

void point_list_from_matrices::stopping()
{
}

//-----------------------------------------------------------------------------

void point_list_from_matrices::updating()
{
    const std::size_t num_matrices = m_matrices.size();
    SIGHT_ASSERT("no matrices found", num_matrices != 0);

    auto point_list = m_point_list.lock();
    if(!m_append)
    {
        point_list->get_points().clear();
    }

    for(std::size_t j = 0 ; j < num_matrices ; ++j)
    {
        const auto mat = m_matrices[j].lock();

        // extract translation
        data::point::sptr p = std::make_shared<data::point>((*mat)[3], (*mat)[7], (*mat)[11]);

        std::string label;
        if(m_append)
        {
            label = std::to_string(point_list->get_points().size());
        }
        else
        {
            label = std::to_string(j);
        }

        p->set_label(label);
        point_list->push_back(p);
    }

    point_list->signal<data::point_list::modified_signal_t>(data::point_list::MODIFIED_SIG)->async_emit();
    this->signal<signals::computed_t>(signals::COMPUTED)->async_emit();
}

//-----------------------------------------------------------------------------

} // namespace sight::module::geometry