Added lots of model synchronization mechanisms
This commit is contained in:
148
devicesmodel.cpp
148
devicesmodel.cpp
@ -19,7 +19,41 @@ void DevicesModel::setController(DmxController *controller)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
beginResetModel();
|
beginResetModel();
|
||||||
|
|
||||||
|
if (m_controller)
|
||||||
|
{
|
||||||
|
disconnect(m_controller, &DmxController::deviceInserted,
|
||||||
|
this, &DevicesModel::otherDeviceInserted);
|
||||||
|
disconnect(m_controller, &DmxController::deviceRemoved,
|
||||||
|
this, &DevicesModel::otherDeviceRemoved);
|
||||||
|
disconnect(m_controller, &DmxController::deviceNameChanged,
|
||||||
|
this, &DevicesModel::otherDeviceNameChanged);
|
||||||
|
disconnect(m_controller, &DmxController::deviceDeviceTypeIdChanged,
|
||||||
|
this, &DevicesModel::otherDeviceDeviceTypeIdChanged);
|
||||||
|
disconnect(m_controller, &DmxController::deviceAddressChanged,
|
||||||
|
this, &DevicesModel::otherDeviceAddressChanged);
|
||||||
|
disconnect(m_controller, &DmxController::devicePositionChanged,
|
||||||
|
this, &DevicesModel::otherDevicePositionChanged);
|
||||||
|
}
|
||||||
|
|
||||||
m_controller = controller;
|
m_controller = controller;
|
||||||
|
|
||||||
|
if (m_controller)
|
||||||
|
{
|
||||||
|
connect(m_controller, &DmxController::deviceInserted,
|
||||||
|
this, &DevicesModel::otherDeviceInserted);
|
||||||
|
connect(m_controller, &DmxController::deviceRemoved,
|
||||||
|
this, &DevicesModel::otherDeviceRemoved);
|
||||||
|
connect(m_controller, &DmxController::deviceNameChanged,
|
||||||
|
this, &DevicesModel::otherDeviceNameChanged);
|
||||||
|
connect(m_controller, &DmxController::deviceDeviceTypeIdChanged,
|
||||||
|
this, &DevicesModel::otherDeviceDeviceTypeIdChanged);
|
||||||
|
connect(m_controller, &DmxController::deviceAddressChanged,
|
||||||
|
this, &DevicesModel::otherDeviceAddressChanged);
|
||||||
|
connect(m_controller, &DmxController::devicePositionChanged,
|
||||||
|
this, &DevicesModel::otherDevicePositionChanged);
|
||||||
|
}
|
||||||
|
|
||||||
endResetModel();
|
endResetModel();
|
||||||
emit controllerChanged(m_controller);
|
emit controllerChanged(m_controller);
|
||||||
}
|
}
|
||||||
@ -168,6 +202,13 @@ bool DevicesModel::setData(const QModelIndex &index, const QVariant &value, int
|
|||||||
}
|
}
|
||||||
device.name = value.toString();
|
device.name = value.toString();
|
||||||
emit dataChanged(index, index, { Qt::DisplayRole, Qt::EditRole });
|
emit dataChanged(index, index, { Qt::DisplayRole, Qt::EditRole });
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceNameChanged,
|
||||||
|
this, &DevicesModel::otherDeviceNameChanged);
|
||||||
|
emit m_controller->deviceNameChanged(index.row(), device.name);
|
||||||
|
connect(m_controller, &DmxController::deviceNameChanged,
|
||||||
|
this, &DevicesModel::otherDeviceNameChanged);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
case IdRole:
|
case IdRole:
|
||||||
if (value.userType() != QMetaType::Int)
|
if (value.userType() != QMetaType::Int)
|
||||||
@ -186,6 +227,13 @@ bool DevicesModel::setData(const QModelIndex &index, const QVariant &value, int
|
|||||||
}
|
}
|
||||||
device.deviceTypeId = value.toInt();
|
device.deviceTypeId = value.toInt();
|
||||||
emit dataChanged(index, index, { DeviceTypeIdRole });
|
emit dataChanged(index, index, { DeviceTypeIdRole });
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceDeviceTypeIdChanged,
|
||||||
|
this, &DevicesModel::otherDeviceDeviceTypeIdChanged);
|
||||||
|
emit m_controller->deviceDeviceTypeIdChanged(index.row(), device.deviceTypeId);
|
||||||
|
connect(m_controller, &DmxController::deviceDeviceTypeIdChanged,
|
||||||
|
this, &DevicesModel::otherDeviceDeviceTypeIdChanged);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
case AddressRole:
|
case AddressRole:
|
||||||
if (value.userType() != QMetaType::Int)
|
if (value.userType() != QMetaType::Int)
|
||||||
@ -195,6 +243,13 @@ bool DevicesModel::setData(const QModelIndex &index, const QVariant &value, int
|
|||||||
}
|
}
|
||||||
device.address = value.toInt();
|
device.address = value.toInt();
|
||||||
emit dataChanged(index, index, { AddressRole });
|
emit dataChanged(index, index, { AddressRole });
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceAddressChanged,
|
||||||
|
this, &DevicesModel::otherDeviceAddressChanged);
|
||||||
|
emit m_controller->deviceAddressChanged(index.row(), device.address);
|
||||||
|
connect(m_controller, &DmxController::deviceAddressChanged,
|
||||||
|
this, &DevicesModel::otherDeviceAddressChanged);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
case PositionRole:
|
case PositionRole:
|
||||||
if (value.userType() != QMetaType::QVector3D)
|
if (value.userType() != QMetaType::QVector3D)
|
||||||
@ -204,6 +259,13 @@ bool DevicesModel::setData(const QModelIndex &index, const QVariant &value, int
|
|||||||
}
|
}
|
||||||
device.position = value.value<QVector3D>();
|
device.position = value.value<QVector3D>();
|
||||||
emit dataChanged(index, index, { PositionRole });
|
emit dataChanged(index, index, { PositionRole });
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::devicePositionChanged,
|
||||||
|
this, &DevicesModel::otherDevicePositionChanged);
|
||||||
|
emit m_controller->devicePositionChanged(index.row(), device.position);
|
||||||
|
connect(m_controller, &DmxController::devicePositionChanged,
|
||||||
|
this, &DevicesModel::otherDevicePositionChanged);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
qWarning() << "hilfe" << __LINE__;
|
qWarning() << "hilfe" << __LINE__;
|
||||||
@ -244,10 +306,16 @@ bool DevicesModel::insertRows(int row, int count, const QModelIndex &parent)
|
|||||||
|
|
||||||
beginInsertRows({}, row, row+count-1);
|
beginInsertRows({}, row, row+count-1);
|
||||||
auto iter = std::begin(devices) + row;
|
auto iter = std::begin(devices) + row;
|
||||||
for (; count > 0; count--)
|
for (auto i = 0; i < count; i++)
|
||||||
iter = devices.insert(iter, LightConfig{ .id=id++, .name="<neu>", .deviceTypeId=0, .address=0, .position={} }) + 1;
|
iter = devices.insert(iter, LightConfig{ .id=id++, .name="<neu>", .deviceTypeId=0, .address=0, .position={} }) + 1;
|
||||||
endInsertRows();
|
endInsertRows();
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceInserted,
|
||||||
|
this, &DevicesModel::otherDeviceInserted);
|
||||||
|
emit m_controller->deviceInserted(row, row+count-1);
|
||||||
|
connect(m_controller, &DmxController::deviceInserted,
|
||||||
|
this, &DevicesModel::otherDeviceInserted);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -291,9 +359,87 @@ bool DevicesModel::removeRows(int row, int count, const QModelIndex &parent)
|
|||||||
devices.erase(begin, end);
|
devices.erase(begin, end);
|
||||||
endRemoveRows();
|
endRemoveRows();
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceRemoved,
|
||||||
|
this, &DevicesModel::otherDeviceRemoved);
|
||||||
|
emit m_controller->deviceRemoved(row, row+count-1);
|
||||||
|
connect(m_controller, &DmxController::deviceRemoved,
|
||||||
|
this, &DevicesModel::otherDeviceRemoved);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDeviceInserted(int first, int last)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
beginInsertRows({}, first, last);
|
||||||
|
endInsertRows();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDeviceRemoved(int first, int last)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
beginRemoveRows({}, first, last);
|
||||||
|
endRemoveRows();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDeviceNameChanged(int row, const QString &name)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto index = this->index(row);
|
||||||
|
emit dataChanged(index, index, { Qt::DisplayRole, Qt::EditRole });
|
||||||
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDeviceDeviceTypeIdChanged(int row, int deviceTypeId)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto index = this->index(row);
|
||||||
|
emit dataChanged(index, index, { DeviceTypeIdRole });
|
||||||
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDeviceAddressChanged(int row, int address)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto index = this->index(row);
|
||||||
|
emit dataChanged(index, index, { AddressRole });
|
||||||
|
}
|
||||||
|
|
||||||
|
void DevicesModel::otherDevicePositionChanged(int row, const QVector3D &position)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto index = this->index(row);
|
||||||
|
emit dataChanged(index, index, { PositionRole });
|
||||||
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
void registrierDenShit()
|
void registrierDenShit()
|
||||||
{
|
{
|
||||||
|
@ -28,6 +28,14 @@ public:
|
|||||||
signals:
|
signals:
|
||||||
void controllerChanged(DmxController *controller);
|
void controllerChanged(DmxController *controller);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void otherDeviceInserted(int first, int last);
|
||||||
|
void otherDeviceRemoved(int first, int last);
|
||||||
|
void otherDeviceNameChanged(int row, const QString &name);
|
||||||
|
void otherDeviceDeviceTypeIdChanged(int row, int deviceTypeId);
|
||||||
|
void otherDeviceAddressChanged(int row, int address);
|
||||||
|
void otherDevicePositionChanged(int row, const QVector3D &position);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DmxController *m_controller{};
|
DmxController *m_controller{};
|
||||||
};
|
};
|
||||||
|
@ -24,6 +24,8 @@ void DeviceTypesModel::setController(DmxController *controller)
|
|||||||
this, &DeviceTypesModel::otherDeviceTypeRemoved);
|
this, &DeviceTypesModel::otherDeviceTypeRemoved);
|
||||||
disconnect(m_controller, &DmxController::deviceTypeNameChanged,
|
disconnect(m_controller, &DmxController::deviceTypeNameChanged,
|
||||||
this, &DeviceTypesModel::otherDeviceTypeNameChanged);
|
this, &DeviceTypesModel::otherDeviceTypeNameChanged);
|
||||||
|
disconnect(m_controller, &DmxController::deviceTypeIconNameChanged,
|
||||||
|
this, &DeviceTypesModel::otherDeviceTypeIconNameChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_controller = controller;
|
m_controller = controller;
|
||||||
@ -36,6 +38,8 @@ void DeviceTypesModel::setController(DmxController *controller)
|
|||||||
this, &DeviceTypesModel::otherDeviceTypeRemoved);
|
this, &DeviceTypesModel::otherDeviceTypeRemoved);
|
||||||
connect(m_controller, &DmxController::deviceTypeNameChanged,
|
connect(m_controller, &DmxController::deviceTypeNameChanged,
|
||||||
this, &DeviceTypesModel::otherDeviceTypeNameChanged);
|
this, &DeviceTypesModel::otherDeviceTypeNameChanged);
|
||||||
|
connect(m_controller, &DmxController::deviceTypeIconNameChanged,
|
||||||
|
this, &DeviceTypesModel::otherDeviceTypeIconNameChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
endResetModel();
|
endResetModel();
|
||||||
@ -208,6 +212,13 @@ bool DeviceTypesModel::setData(const QModelIndex &index, const QVariant &value,
|
|||||||
}
|
}
|
||||||
deviceType.iconName = value.toString();
|
deviceType.iconName = value.toString();
|
||||||
emit dataChanged(index, index, { IconNameRole });
|
emit dataChanged(index, index, { IconNameRole });
|
||||||
|
|
||||||
|
disconnect(m_controller, &DmxController::deviceTypeIconNameChanged,
|
||||||
|
this, &DeviceTypesModel::otherDeviceTypeIconNameChanged);
|
||||||
|
emit m_controller->deviceTypeIconNameChanged(index.row(), deviceType.iconName);
|
||||||
|
connect(m_controller, &DmxController::deviceTypeIconNameChanged,
|
||||||
|
this, &DeviceTypesModel::otherDeviceTypeIconNameChanged);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
qWarning() << "hilfe" << __LINE__;
|
qWarning() << "hilfe" << __LINE__;
|
||||||
@ -248,7 +259,7 @@ bool DeviceTypesModel::insertRows(int row, int count, const QModelIndex &parent)
|
|||||||
|
|
||||||
beginInsertRows({}, row, row+count-1);
|
beginInsertRows({}, row, row+count-1);
|
||||||
auto iter = std::begin(deviceTypes) + row;
|
auto iter = std::begin(deviceTypes) + row;
|
||||||
for (; count > 0; count--)
|
for (auto i = 0; i < count; i++)
|
||||||
iter = deviceTypes.insert(iter, DeviceTypeConfig{ .id=id++, .name="<neu>" }) + 1;
|
iter = deviceTypes.insert(iter, DeviceTypeConfig{ .id=id++, .name="<neu>" }) + 1;
|
||||||
endInsertRows();
|
endInsertRows();
|
||||||
|
|
||||||
@ -346,6 +357,18 @@ void DeviceTypesModel::otherDeviceTypeNameChanged(int row, const QString &name)
|
|||||||
emit dataChanged(index, index, { Qt::DisplayRole, Qt::EditRole });
|
emit dataChanged(index, index, { Qt::DisplayRole, Qt::EditRole });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DeviceTypesModel::otherDeviceTypeIconNameChanged(int row, const QString &name)
|
||||||
|
{
|
||||||
|
if (!m_controller)
|
||||||
|
{
|
||||||
|
qWarning() << "hilfe" << __LINE__;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto index = this->index(row);
|
||||||
|
emit dataChanged(index, index, { IconNameRole });
|
||||||
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
void registrierDenShit()
|
void registrierDenShit()
|
||||||
{
|
{
|
||||||
|
@ -32,6 +32,7 @@ private slots:
|
|||||||
void otherDeviceTypeInserted(int first, int last);
|
void otherDeviceTypeInserted(int first, int last);
|
||||||
void otherDeviceTypeRemoved(int first, int last);
|
void otherDeviceTypeRemoved(int first, int last);
|
||||||
void otherDeviceTypeNameChanged(int row, const QString &name);
|
void otherDeviceTypeNameChanged(int row, const QString &name);
|
||||||
|
void otherDeviceTypeIconNameChanged(int row, const QString &name);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DmxController *m_controller{};
|
DmxController *m_controller{};
|
||||||
|
@ -39,6 +39,13 @@ signals:
|
|||||||
void deviceTypeRegisterRemoved(const DeviceTypeConfig &deviceType, int first, int last);
|
void deviceTypeRegisterRemoved(const DeviceTypeConfig &deviceType, int first, int last);
|
||||||
void deviceTypeRegisterTypeChanged(const DeviceTypeConfig &deviceType, int index, DeviceTypeRegisterType type);
|
void deviceTypeRegisterTypeChanged(const DeviceTypeConfig &deviceType, int index, DeviceTypeRegisterType type);
|
||||||
|
|
||||||
|
void deviceInserted(int first, int last);
|
||||||
|
void deviceRemoved(int first, int last);
|
||||||
|
void deviceNameChanged(int index, const QString &name);
|
||||||
|
void deviceDeviceTypeIdChanged(int index, int deviceTypeId);
|
||||||
|
void deviceAddressChanged(int index, int address);
|
||||||
|
void devicePositionChanged(int index, const QVector3D &position);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
friend class DmxControllerThread;
|
friend class DmxControllerThread;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user