blob: 4728c0ac25c359d95df05c9915011a3b4bc98509 (
plain)
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
|
// Copyright (C) 2017 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "channelmapper_p.h"
#include <Qt3DAnimation/qchannelmapper.h>
#include <Qt3DAnimation/qchannelmapping.h>
#include <Qt3DAnimation/private/qchannelmapper_p.h>
#include <Qt3DAnimation/private/animationlogging_p.h>
#include <Qt3DAnimation/private/managers_p.h>
#include <algorithm>
QT_BEGIN_NAMESPACE
namespace Qt3DAnimation {
namespace Animation {
ChannelMapper::ChannelMapper()
: BackendNode(ReadOnly)
, m_mappingIds()
, m_isDirty(true)
{
}
void ChannelMapper::cleanup()
{
setEnabled(false);
m_mappingIds.clear();
m_mappings.clear();
m_isDirty = true;
}
void ChannelMapper::syncFromFrontEnd(const Qt3DCore::QNode *frontEnd, bool firstTime)
{
BackendNode::syncFromFrontEnd(frontEnd, firstTime);
const QChannelMapper *node = qobject_cast<const QChannelMapper *>(frontEnd);
if (!node)
return;
auto ids = Qt3DCore::qIdsForNodes(node->mappings());
std::sort(std::begin(ids), std::end(ids));
m_isDirty = firstTime;
if (m_mappingIds != ids) {
m_mappingIds = ids;
setDirty(Handler::ChannelMappingsDirty);
m_isDirty = true;
}
}
void ChannelMapper::updateMappings() const
{
m_mappings.clear();
m_mappings.reserve(m_mappingIds.size());
const auto mappingManager = m_handler->channelMappingManager();
for (const auto &mappingId : m_mappingIds) {
const auto mapping = mappingManager->lookupResource(mappingId);
Q_ASSERT(mapping);
m_mappings.push_back(mapping);
}
m_isDirty = false;
}
} // namespace Animation
} // namespace Qt3DAnimation
QT_END_NAMESPACE
|