Files
@ 3be63f78737a
Branch filter:
Location: tempo-plotter/src/channelinfomodel.cpp
3be63f78737a
5.3 KiB
text/x-c++hdr
somewhat integrated new channelinfomodel
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 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 | /*
Copyright © 2017 Hasan Yavuz Özderya
This file is part of serialplot.
serialplot is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
serialplot 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with serialplot. If not, see <http://www.gnu.org/licenses/>.
*/
#include "channelinfomodel.h"
const QColor colors[8] =
{
QColor(237,97,68),
QColor(92,200,96),
QColor(225,98,207),
QColor(163,195,58),
QColor(148,123,239),
QColor(212,182,52),
QColor(238,82,133),
QColor(219,136,44)
};
ChannelInfoModel::ChannelInfoModel(unsigned numberOfChannels, QObject* parent) :
QAbstractTableModel(parent)
{
_numOfChannels = 0;
setNumOfChannels(numberOfChannels);
}
int ChannelInfoModel::rowCount(const QModelIndex &parent) const
{
return _numOfChannels;
}
int ChannelInfoModel::columnCount(const QModelIndex & parent) const
{
return COLUMN_COUNT;
}
Qt::ItemFlags ChannelInfoModel::flags(const QModelIndex &index) const
{
if (index.column() == COLUMN_NAME)
{
return Qt::ItemIsEditable | Qt::ItemIsEnabled | Qt::ItemNeverHasChildren | Qt::ItemIsSelectable;
}
else if (index.column() == COLUMN_VISIBILITY)
{
return Qt::ItemIsUserCheckable | Qt::ItemIsEnabled | Qt::ItemNeverHasChildren | Qt::ItemIsSelectable;
}
return Qt::NoItemFlags;
}
QVariant ChannelInfoModel::data(const QModelIndex &index, int role) const
{
// check index
if (index.row() >= (int) _numOfChannels)
{
return QVariant();
}
// get color
if (role == Qt::ForegroundRole)
{
return infos[index.row()].color;
}
// get name
if (index.column() == COLUMN_NAME)
{
if (role == Qt::DisplayRole || role == Qt::EditRole)
{
return QVariant(infos[index.row()].name);
}
} // get visibility
else if (index.column() == COLUMN_VISIBILITY)
{
if (role == Qt::CheckStateRole)
{
bool visible = infos[index.row()].visibility;
return visible ? Qt::Checked : Qt::Unchecked;
}
}
return QVariant();
}
QVariant ChannelInfoModel::headerData(int section, Qt::Orientation orientation, int role) const
{
if (orientation == Qt::Horizontal)
{
if (role == Qt::DisplayRole)
{
if (section == COLUMN_NAME)
{
return tr("Channel");
}
else if (section == COLUMN_VISIBILITY)
{
return tr("Visible");
}
}
}
else // vertical
{
if (section < (int) _numOfChannels && role == Qt::DisplayRole)
{
return QString::number(section + 1);
}
}
return QVariant();
}
bool ChannelInfoModel::setData(const QModelIndex &index, const QVariant &value, int role)
{
// check index
if (index.row() >= (int) _numOfChannels)
{
return false;
}
// set color
if (role == Qt::ForegroundRole)
{
infos[index.row()].color = value.value<QColor>();
emit dataChanged(index, index, QVector<int>({Qt::ForegroundRole}));
return true;
}
// set name
if (index.column() == COLUMN_NAME)
{
if (role == Qt::DisplayRole || role == Qt::EditRole)
{
infos[index.row()].name = value.toString();
emit dataChanged(index, index, QVector<int>({role}));
return true;
}
} // set visibility
else if (index.column() == COLUMN_VISIBILITY)
{
if (role == Qt::CheckStateRole)
{
bool checked = value.toInt() == Qt::Checked;
infos[index.row()].visibility = checked;
emit dataChanged(index, index, QVector<int>({role}));
return true;
}
}
// invalid index/role
return false;
}
void ChannelInfoModel::setNumOfChannels(unsigned number)
{
if (number == _numOfChannels) return;
bool isInserting = number > _numOfChannels;
if (isInserting)
{
beginInsertRows(QModelIndex(), _numOfChannels, number-1);
}
else
{
beginRemoveRows(QModelIndex(), number, _numOfChannels-1);
}
// we create channel info but never remove channel info to
// remember user entered info
if ((int) number > infos.length())
{
for (unsigned ci = _numOfChannels; ci < number; ci++)
{
infos.append({QString("Channel %1").arg(ci+1), true, colors[ci % 8]});
}
}
// make sure newly available channels are visible, we don't
// remember visibility option intentionally so that user doesn't
// get confused
if (number > _numOfChannels)
{
for (unsigned ci = _numOfChannels; ci < number; ci++)
{
infos[ci].visibility = true;
}
}
_numOfChannels = number;
if (isInserting)
{
endInsertRows();
}
else
{
endRemoveRows();
}
}
|