forked from teamnwah/openmw-tes3coop
Merge branch 'region'
This commit is contained in:
commit
6a5ab34971
11 changed files with 714 additions and 3 deletions
|
@ -18,7 +18,7 @@ opencs_hdrs_noqt (model/doc
|
|||
|
||||
|
||||
opencs_units (model/world
|
||||
idtable idtableproxymodel
|
||||
idtable idtableproxymodel regionmap
|
||||
)
|
||||
|
||||
|
||||
|
@ -57,7 +57,7 @@ opencs_hdrs_noqt (view/doc
|
|||
|
||||
|
||||
opencs_units (view/world
|
||||
table tablesubview scriptsubview util
|
||||
table tablesubview scriptsubview util regionmapsubview
|
||||
)
|
||||
|
||||
opencs_units_noqt (view/world
|
||||
|
|
|
@ -11,6 +11,7 @@
|
|||
|
||||
#include "idtable.hpp"
|
||||
#include "columns.hpp"
|
||||
#include "regionmap.hpp"
|
||||
|
||||
void CSMWorld::Data::addModel (QAbstractItemModel *model, UniversalId::Type type1,
|
||||
UniversalId::Type type2)
|
||||
|
@ -304,7 +305,20 @@ QAbstractItemModel *CSMWorld::Data::getTableModel (const UniversalId& id)
|
|||
std::map<UniversalId::Type, QAbstractItemModel *>::iterator iter = mModelIndex.find (id.getType());
|
||||
|
||||
if (iter==mModelIndex.end())
|
||||
{
|
||||
// try creating missing (secondary) tables on the fly
|
||||
//
|
||||
// Note: We create these tables here so we don't have to deal with them during load/initial
|
||||
// construction of the ESX data where no update signals are available.
|
||||
if (id.getType()==UniversalId::Type_RegionMap)
|
||||
{
|
||||
RegionMap *table = 0;
|
||||
addModel (table = new RegionMap (*this), UniversalId::Type_RegionMap,
|
||||
UniversalId::Type_None);
|
||||
return table;
|
||||
}
|
||||
throw std::logic_error ("No table model available for " + id.toString());
|
||||
}
|
||||
|
||||
return iter->second;
|
||||
}
|
||||
|
|
513
apps/opencs/model/world/regionmap.cpp
Normal file
513
apps/opencs/model/world/regionmap.cpp
Normal file
|
@ -0,0 +1,513 @@
|
|||
|
||||
#include "regionmap.hpp"
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
#include <QBrush>
|
||||
|
||||
#include <components/misc/stringops.hpp>
|
||||
|
||||
#include "data.hpp"
|
||||
#include "universalid.hpp"
|
||||
|
||||
CSMWorld::RegionMap::CellDescription::CellDescription() : mDeleted (false) {}
|
||||
|
||||
CSMWorld::RegionMap::CellDescription::CellDescription (const Record<Cell>& cell)
|
||||
{
|
||||
const Cell& cell2 = cell.get();
|
||||
|
||||
if (!cell2.isExterior())
|
||||
throw std::logic_error ("Interior cell in region map");
|
||||
|
||||
mDeleted = cell.isDeleted();
|
||||
|
||||
mRegion = cell2.mRegion;
|
||||
mName = cell2.mName;
|
||||
}
|
||||
|
||||
CSMWorld::RegionMap::CellIndex CSMWorld::RegionMap::getIndex (const QModelIndex& index) const
|
||||
{
|
||||
return CellIndex (index.column()+mMin.first,
|
||||
(mMax.second-mMin.second - index.row()-1)+mMin.second);
|
||||
}
|
||||
|
||||
QModelIndex CSMWorld::RegionMap::getIndex (const CellIndex& index) const
|
||||
{
|
||||
// I hate you, Qt API naming scheme!
|
||||
return QAbstractTableModel::index (mMax.second-mMin.second - (index.second-mMin.second)-1,
|
||||
index.first-mMin.first);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::buildRegions()
|
||||
{
|
||||
const IdCollection<ESM::Region>& regions = mData.getRegions();
|
||||
|
||||
int size = regions.getSize();
|
||||
|
||||
for (int i=0; i<size; ++i)
|
||||
{
|
||||
const Record<ESM::Region>& region = regions.getRecord (i);
|
||||
|
||||
if (!region.isDeleted())
|
||||
mColours.insert (std::make_pair (Misc::StringUtils::lowerCase (region.get().mId),
|
||||
region.get().mMapColor));
|
||||
}
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::buildMap()
|
||||
{
|
||||
const IdCollection<Cell>& cells = mData.getCells();
|
||||
|
||||
int size = cells.getSize();
|
||||
|
||||
for (int i=0; i<size; ++i)
|
||||
{
|
||||
const Record<Cell>& cell = cells.getRecord (i);
|
||||
|
||||
const Cell& cell2 = cell.get();
|
||||
|
||||
if (cell2.isExterior())
|
||||
{
|
||||
CellDescription description (cell);
|
||||
|
||||
CellIndex index (cell2.mData.mX, cell2.mData.mY);
|
||||
|
||||
mMap.insert (std::make_pair (index, description));
|
||||
}
|
||||
}
|
||||
|
||||
std::pair<CellIndex, CellIndex> mapSize = getSize();
|
||||
|
||||
mMin = mapSize.first;
|
||||
mMax = mapSize.second;
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::addCell (const CellIndex& index, const CellDescription& description)
|
||||
{
|
||||
std::map<CellIndex, CellDescription>::iterator cell = mMap.find (index);
|
||||
|
||||
if (cell!=mMap.end())
|
||||
{
|
||||
cell->second = description;
|
||||
}
|
||||
else
|
||||
{
|
||||
updateSize();
|
||||
|
||||
mMap.insert (std::make_pair (index, description));
|
||||
}
|
||||
|
||||
QModelIndex index2 = getIndex (index);
|
||||
|
||||
dataChanged (index2, index2);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::addCells (int start, int end)
|
||||
{
|
||||
const IdCollection<Cell>& cells = mData.getCells();
|
||||
|
||||
for (int i=start; i<=end; ++i)
|
||||
{
|
||||
const Record<Cell>& cell = cells.getRecord (i);
|
||||
|
||||
const Cell& cell2 = cell.get();
|
||||
|
||||
if (cell2.isExterior())
|
||||
{
|
||||
CellIndex index (cell2.mData.mX, cell2.mData.mY);
|
||||
|
||||
CellDescription description (cell);
|
||||
|
||||
addCell (index, description);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::removeCell (const CellIndex& index)
|
||||
{
|
||||
std::map<CellIndex, CellDescription>::iterator cell = mMap.find (index);
|
||||
|
||||
if (cell!=mMap.end())
|
||||
{
|
||||
mMap.erase (cell);
|
||||
|
||||
QModelIndex index2 = getIndex (index);
|
||||
|
||||
dataChanged (index2, index2);
|
||||
|
||||
updateSize();
|
||||
}
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::addRegion (const std::string& region, unsigned int colour)
|
||||
{
|
||||
mColours[Misc::StringUtils::lowerCase (region)] = colour;
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::removeRegion (const std::string& region)
|
||||
{
|
||||
std::map<std::string, unsigned int>::iterator iter (
|
||||
mColours.find (Misc::StringUtils::lowerCase (region)));
|
||||
|
||||
if (iter!=mColours.end())
|
||||
mColours.erase (iter);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::updateRegions (const std::vector<std::string>& regions)
|
||||
{
|
||||
std::vector<std::string> regions2 (regions);
|
||||
|
||||
std::for_each (regions2.begin(), regions2.end(), &Misc::StringUtils::lowerCase);
|
||||
std::sort (regions2.begin(), regions2.end());
|
||||
|
||||
for (std::map<CellIndex, CellDescription>::const_iterator iter (mMap.begin());
|
||||
iter!=mMap.end(); ++iter)
|
||||
{
|
||||
if (!iter->second.mRegion.empty() &&
|
||||
std::find (regions2.begin(), regions2.end(),
|
||||
Misc::StringUtils::lowerCase (iter->second.mRegion))!=regions2.end())
|
||||
{
|
||||
QModelIndex index = getIndex (iter->first);
|
||||
|
||||
dataChanged (index, index);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::updateSize()
|
||||
{
|
||||
std::pair<CellIndex, CellIndex> size = getSize();
|
||||
|
||||
{
|
||||
int diff = size.first.first - mMin.first;
|
||||
|
||||
if (diff<0)
|
||||
{
|
||||
beginInsertColumns (QModelIndex(), 0, -diff-1);
|
||||
mMin.first = size.first.first;
|
||||
endInsertColumns();
|
||||
}
|
||||
else if (diff>0)
|
||||
{
|
||||
beginRemoveColumns (QModelIndex(), 0, diff-1);
|
||||
mMin.first = size.first.first;
|
||||
endRemoveColumns();
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
int diff = size.first.second - mMin.second;
|
||||
|
||||
if (diff<0)
|
||||
{
|
||||
beginInsertRows (QModelIndex(), 0, -diff-1);
|
||||
mMin.second = size.first.second;
|
||||
endInsertRows();
|
||||
}
|
||||
else if (diff>0)
|
||||
{
|
||||
beginRemoveRows (QModelIndex(), 0, diff-1);
|
||||
mMin.second = size.first.second;
|
||||
endRemoveRows();
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
int diff = size.second.first - mMax.first;
|
||||
|
||||
if (diff>0)
|
||||
{
|
||||
int columns = columnCount();
|
||||
beginInsertColumns (QModelIndex(), columns, columns+diff-1);
|
||||
mMax.first = size.second.first;
|
||||
endInsertColumns();
|
||||
}
|
||||
else if (diff<0)
|
||||
{
|
||||
int columns = columnCount();
|
||||
beginRemoveColumns (QModelIndex(), columns+diff, columns-1);
|
||||
mMax.first = size.second.first;
|
||||
endRemoveColumns();
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
int diff = size.second.second - mMax.second;
|
||||
|
||||
if (diff>0)
|
||||
{
|
||||
int rows = rowCount();
|
||||
beginInsertRows (QModelIndex(), rows, rows+diff-1);
|
||||
mMax.second = size.second.second;
|
||||
endInsertRows();
|
||||
}
|
||||
else if (diff<0)
|
||||
{
|
||||
int rows = rowCount();
|
||||
beginRemoveRows (QModelIndex(), rows+diff, rows-1);
|
||||
mMax.second = size.second.second;
|
||||
endRemoveRows();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
std::pair<CSMWorld::RegionMap::CellIndex, CSMWorld::RegionMap::CellIndex> CSMWorld::RegionMap::getSize()
|
||||
const
|
||||
{
|
||||
const IdCollection<Cell>& cells = mData.getCells();
|
||||
|
||||
int size = cells.getSize();
|
||||
|
||||
CellIndex min (0, 0);
|
||||
CellIndex max (0, 0);
|
||||
|
||||
for (int i=0; i<size; ++i)
|
||||
{
|
||||
const Record<Cell>& cell = cells.getRecord (i);
|
||||
|
||||
const Cell& cell2 = cell.get();
|
||||
|
||||
if (cell2.isExterior())
|
||||
{
|
||||
CellIndex index (cell2.mData.mX, cell2.mData.mY);
|
||||
|
||||
if (min==max)
|
||||
{
|
||||
min = index;
|
||||
max = std::make_pair (min.first+1, min.second+1);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (index.first<min.first)
|
||||
min.first = index.first;
|
||||
else if (index.first>=max.first)
|
||||
max.first = index.first + 1;
|
||||
|
||||
if (index.second<min.second)
|
||||
min.second = index.second;
|
||||
else if (index.second>=max.second)
|
||||
max.second = index.second + 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return std::make_pair (min, max);
|
||||
}
|
||||
|
||||
CSMWorld::RegionMap::RegionMap (Data& data) : mData (data)
|
||||
{
|
||||
buildRegions();
|
||||
buildMap();
|
||||
|
||||
QAbstractItemModel *regions = data.getTableModel (UniversalId (UniversalId::Type_Regions));
|
||||
|
||||
connect (regions, SIGNAL (rowsAboutToBeRemoved (const QModelIndex&, int, int)),
|
||||
this, SLOT (regionsAboutToBeRemoved (const QModelIndex&, int, int)));
|
||||
connect (regions, SIGNAL (rowsInserted (const QModelIndex&, int, int)),
|
||||
this, SLOT (regionsInserted (const QModelIndex&, int, int)));
|
||||
connect (regions, SIGNAL (dataChanged (const QModelIndex&, const QModelIndex&)),
|
||||
this, SLOT (regionsChanged (const QModelIndex&, const QModelIndex&)));
|
||||
|
||||
QAbstractItemModel *cells = data.getTableModel (UniversalId (UniversalId::Type_Cells));
|
||||
|
||||
connect (cells, SIGNAL (rowsAboutToBeRemoved (const QModelIndex&, int, int)),
|
||||
this, SLOT (cellsAboutToBeRemoved (const QModelIndex&, int, int)));
|
||||
connect (cells, SIGNAL (rowsInserted (const QModelIndex&, int, int)),
|
||||
this, SLOT (cellsInserted (const QModelIndex&, int, int)));
|
||||
connect (cells, SIGNAL (dataChanged (const QModelIndex&, const QModelIndex&)),
|
||||
this, SLOT (cellsChanged (const QModelIndex&, const QModelIndex&)));
|
||||
}
|
||||
|
||||
int CSMWorld::RegionMap::rowCount (const QModelIndex& parent) const
|
||||
{
|
||||
if (parent.isValid())
|
||||
return 0;
|
||||
|
||||
return mMax.second-mMin.second;
|
||||
}
|
||||
|
||||
int CSMWorld::RegionMap::columnCount (const QModelIndex& parent) const
|
||||
{
|
||||
if (parent.isValid())
|
||||
return 0;
|
||||
|
||||
return mMax.first-mMin.first;
|
||||
}
|
||||
|
||||
QVariant CSMWorld::RegionMap::data (const QModelIndex& index, int role) const
|
||||
{
|
||||
if (role==Qt::SizeHintRole)
|
||||
return QSize (16, 16);
|
||||
|
||||
if (role==Qt::BackgroundRole)
|
||||
{
|
||||
/// \todo GUI class in non-GUI code. Needs to be addressed eventually.
|
||||
|
||||
std::map<CellIndex, CellDescription>::const_iterator cell =
|
||||
mMap.find (getIndex (index));
|
||||
|
||||
if (cell!=mMap.end())
|
||||
{
|
||||
if (cell->second.mDeleted)
|
||||
return QBrush (Qt::red, Qt::DiagCrossPattern);
|
||||
|
||||
std::map<std::string, unsigned int>::const_iterator iter =
|
||||
mColours.find (Misc::StringUtils::lowerCase (cell->second.mRegion));
|
||||
|
||||
if (iter!=mColours.end())
|
||||
return QBrush (
|
||||
QColor (iter->second>>24, (iter->second>>16) & 255, (iter->second>>8) & 255,
|
||||
iter->second & 255));
|
||||
|
||||
if (cell->second.mRegion.empty())
|
||||
return QBrush (Qt::Dense6Pattern); // no region
|
||||
|
||||
return QBrush (Qt::red, Qt::Dense6Pattern); // invalid region
|
||||
}
|
||||
|
||||
return QBrush (Qt::DiagCrossPattern);
|
||||
}
|
||||
|
||||
if (role==Qt::ToolTipRole)
|
||||
{
|
||||
CellIndex cellIndex = getIndex (index);
|
||||
|
||||
std::ostringstream stream;
|
||||
|
||||
stream << cellIndex.first << ", " << cellIndex.second;
|
||||
|
||||
std::map<CellIndex, CellDescription>::const_iterator cell =
|
||||
mMap.find (cellIndex);
|
||||
|
||||
if (cell!=mMap.end())
|
||||
{
|
||||
if (!cell->second.mName.empty())
|
||||
stream << " " << cell->second.mName;
|
||||
|
||||
if (cell->second.mDeleted)
|
||||
stream << " (deleted)";
|
||||
|
||||
if (!cell->second.mRegion.empty())
|
||||
{
|
||||
stream << "<br>";
|
||||
|
||||
std::map<std::string, unsigned int>::const_iterator iter =
|
||||
mColours.find (Misc::StringUtils::lowerCase (cell->second.mRegion));
|
||||
|
||||
if (iter!=mColours.end())
|
||||
stream << cell->second.mRegion;
|
||||
else
|
||||
stream << "<font color=red>" << cell->second.mRegion << "</font>";
|
||||
}
|
||||
}
|
||||
else
|
||||
stream << " (no cell)";
|
||||
|
||||
return QString::fromUtf8 (stream.str().c_str());
|
||||
}
|
||||
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
Qt::ItemFlags CSMWorld::RegionMap::flags (const QModelIndex& index) const
|
||||
{
|
||||
if (mMap.find (getIndex (index))!=mMap.end())
|
||||
return Qt::ItemIsSelectable | Qt::ItemIsEnabled;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::regionsAboutToBeRemoved (const QModelIndex& parent, int start, int end)
|
||||
{
|
||||
std::vector<std::string> update;
|
||||
|
||||
const IdCollection<ESM::Region>& regions = mData.getRegions();
|
||||
|
||||
for (int i=start; i<=end; ++i)
|
||||
{
|
||||
const Record<ESM::Region>& region = regions.getRecord (i);
|
||||
|
||||
update.push_back (region.get().mId);
|
||||
|
||||
removeRegion (region.get().mId);
|
||||
}
|
||||
|
||||
updateRegions (update);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::regionsInserted (const QModelIndex& parent, int start, int end)
|
||||
{
|
||||
std::vector<std::string> update;
|
||||
|
||||
const IdCollection<ESM::Region>& regions = mData.getRegions();
|
||||
|
||||
for (int i=start; i<=end; ++i)
|
||||
{
|
||||
const Record<ESM::Region>& region = regions.getRecord (i);
|
||||
|
||||
if (!region.isDeleted())
|
||||
{
|
||||
update.push_back (region.get().mId);
|
||||
|
||||
addRegion (region.get().mId, region.get().mMapColor);
|
||||
}
|
||||
}
|
||||
|
||||
updateRegions (update);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::regionsChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight)
|
||||
{
|
||||
// Note: At this point an additional check could be inserted to see if there is any change to the
|
||||
// columns we are interested in. If not we can exit the function here and avoid all updating.
|
||||
|
||||
std::vector<std::string> update;
|
||||
|
||||
const IdCollection<ESM::Region>& regions = mData.getRegions();
|
||||
|
||||
for (int i=topLeft.row(); i<=bottomRight.column(); ++i)
|
||||
{
|
||||
const Record<ESM::Region>& region = regions.getRecord (i);
|
||||
|
||||
update.push_back (region.get().mId);
|
||||
|
||||
if (!region.isDeleted())
|
||||
addRegion (region.get().mId, region.get().mMapColor);
|
||||
else
|
||||
removeRegion (region.get().mId);
|
||||
}
|
||||
|
||||
updateRegions (update);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::cellsAboutToBeRemoved (const QModelIndex& parent, int start, int end)
|
||||
{
|
||||
const IdCollection<Cell>& cells = mData.getCells();
|
||||
|
||||
for (int i=start; i<=end; ++i)
|
||||
{
|
||||
const Record<Cell>& cell = cells.getRecord (i);
|
||||
|
||||
const Cell& cell2 = cell.get();
|
||||
|
||||
if (cell2.isExterior())
|
||||
{
|
||||
CellIndex index (cell2.mData.mX, cell2.mData.mY);
|
||||
|
||||
removeCell (index);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::cellsInserted (const QModelIndex& parent, int start, int end)
|
||||
{
|
||||
addCells (start, end);
|
||||
}
|
||||
|
||||
void CSMWorld::RegionMap::cellsChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight)
|
||||
{
|
||||
// Note: At this point an additional check could be inserted to see if there is any change to the
|
||||
// columns we are interested in. If not we can exit the function here and avoid all updating.
|
||||
|
||||
addCells (topLeft.row(), bottomRight.row());
|
||||
}
|
111
apps/opencs/model/world/regionmap.hpp
Normal file
111
apps/opencs/model/world/regionmap.hpp
Normal file
|
@ -0,0 +1,111 @@
|
|||
#ifndef CSM_WOLRD_REGIONMAP_H
|
||||
#define CSM_WOLRD_REGIONMAP_H
|
||||
|
||||
#include <map>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#include <QAbstractTableModel>
|
||||
|
||||
#include "record.hpp"
|
||||
#include "cell.hpp"
|
||||
|
||||
namespace CSMWorld
|
||||
{
|
||||
class Data;
|
||||
|
||||
/// \brief Model for the region map
|
||||
///
|
||||
/// This class does not holds any record data (other than for the purpose of buffering).
|
||||
class RegionMap : public QAbstractTableModel
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
|
||||
typedef std::pair<int, int> CellIndex;
|
||||
|
||||
private:
|
||||
|
||||
struct CellDescription
|
||||
{
|
||||
bool mDeleted;
|
||||
std::string mRegion;
|
||||
std::string mName;
|
||||
|
||||
CellDescription();
|
||||
|
||||
CellDescription (const Record<Cell>& cell);
|
||||
};
|
||||
|
||||
Data& mData;
|
||||
std::map<CellIndex, CellDescription> mMap;
|
||||
CellIndex mMin; ///< inclusive
|
||||
CellIndex mMax; ///< exclusive
|
||||
std::map<std::string, unsigned int> mColours; ///< region ID, colour (RGBA)
|
||||
|
||||
CellIndex getIndex (const QModelIndex& index) const;
|
||||
///< Translates a Qt model index into a cell index (which can contain negative components)
|
||||
|
||||
QModelIndex getIndex (const CellIndex& index) const;
|
||||
|
||||
void buildRegions();
|
||||
|
||||
void buildMap();
|
||||
|
||||
void addCell (const CellIndex& index, const CellDescription& description);
|
||||
///< May be called on a cell that is already in the map (in which case an update is
|
||||
// performed)
|
||||
|
||||
void addCells (int start, int end);
|
||||
|
||||
void removeCell (const CellIndex& index);
|
||||
///< May be called on a cell that is not in the map (in which case the call is ignored)
|
||||
|
||||
void addRegion (const std::string& region, unsigned int colour);
|
||||
///< May be called on a region that is already listed (in which case an update is
|
||||
/// performed)
|
||||
///
|
||||
/// \note This function does not update the region map.
|
||||
|
||||
void removeRegion (const std::string& region);
|
||||
///< May be called on a region that is not listed (in which case the call is ignored)
|
||||
///
|
||||
/// \note This function does not update the region map.
|
||||
|
||||
void updateRegions (const std::vector<std::string>& regions);
|
||||
///< Update cells affected by the listed regions
|
||||
|
||||
void updateSize();
|
||||
|
||||
std::pair<CellIndex, CellIndex> getSize() const;
|
||||
|
||||
public:
|
||||
|
||||
RegionMap (Data& data);
|
||||
|
||||
virtual int rowCount (const QModelIndex& parent = QModelIndex()) const;
|
||||
|
||||
virtual int columnCount (const QModelIndex& parent = QModelIndex()) const;
|
||||
|
||||
virtual QVariant data (const QModelIndex& index, int role = Qt::DisplayRole) const;
|
||||
|
||||
virtual Qt::ItemFlags flags (const QModelIndex& index) const;
|
||||
|
||||
private slots:
|
||||
|
||||
void regionsAboutToBeRemoved (const QModelIndex& parent, int start, int end);
|
||||
|
||||
void regionsInserted (const QModelIndex& parent, int start, int end);
|
||||
|
||||
void regionsChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight);
|
||||
|
||||
void cellsAboutToBeRemoved (const QModelIndex& parent, int start, int end);
|
||||
|
||||
void cellsInserted (const QModelIndex& parent, int start, int end);
|
||||
|
||||
void cellsChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight);
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
|
@ -33,6 +33,8 @@ namespace
|
|||
"Referenceables" },
|
||||
{ CSMWorld::UniversalId::Class_RecordList, CSMWorld::UniversalId::Type_References,
|
||||
"References" },
|
||||
{ CSMWorld::UniversalId::Class_NonRecord, CSMWorld::UniversalId::Type_RegionMap,
|
||||
"Region Map" },
|
||||
|
||||
{ CSMWorld::UniversalId::Class_None, CSMWorld::UniversalId::Type_None, 0 } // end marker
|
||||
};
|
||||
|
|
|
@ -81,7 +81,8 @@ namespace CSMWorld
|
|||
Type_Static,
|
||||
Type_Weapon,
|
||||
Type_References,
|
||||
Type_Reference
|
||||
Type_Reference,
|
||||
Type_RegionMap
|
||||
};
|
||||
|
||||
private:
|
||||
|
|
|
@ -139,6 +139,10 @@ void CSVDoc::View::setupWorldMenu()
|
|||
QAction *references = new QAction (tr ("References"), this);
|
||||
connect (references, SIGNAL (triggered()), this, SLOT (addReferencesSubView()));
|
||||
world->addAction (references);
|
||||
|
||||
QAction *regionMap = new QAction (tr ("Region Map"), this);
|
||||
connect (regionMap, SIGNAL (triggered()), this, SLOT (addRegionMapSubView()));
|
||||
world->addAction (regionMap);
|
||||
}
|
||||
|
||||
void CSVDoc::View::setupUi()
|
||||
|
@ -362,6 +366,11 @@ void CSVDoc::View::addReferencesSubView()
|
|||
addSubView (CSMWorld::UniversalId::Type_References);
|
||||
}
|
||||
|
||||
void CSVDoc::View::addRegionMapSubView()
|
||||
{
|
||||
addSubView (CSMWorld::UniversalId::Type_RegionMap);
|
||||
}
|
||||
|
||||
void CSVDoc::View::abortOperation (int type)
|
||||
{
|
||||
mDocument->abortOperation (type);
|
||||
|
|
|
@ -151,6 +151,8 @@ namespace CSVDoc
|
|||
|
||||
void addReferencesSubView();
|
||||
|
||||
void addRegionMapSubView();
|
||||
|
||||
void showUserSettings();
|
||||
};
|
||||
}
|
||||
|
|
29
apps/opencs/view/world/regionmapsubview.cpp
Normal file
29
apps/opencs/view/world/regionmapsubview.cpp
Normal file
|
@ -0,0 +1,29 @@
|
|||
|
||||
#include "regionmapsubview.hpp"
|
||||
|
||||
#include <QTableView>
|
||||
#include <QHeaderView>
|
||||
|
||||
CSVWorld::RegionMapSubView::RegionMapSubView (CSMWorld::UniversalId universalId,
|
||||
CSMDoc::Document& document)
|
||||
: CSVDoc::SubView (universalId)
|
||||
{
|
||||
mTable = new QTableView (this);
|
||||
|
||||
mTable->verticalHeader()->hide();
|
||||
mTable->horizontalHeader()->hide();
|
||||
|
||||
mTable->setSelectionMode (QAbstractItemView::ExtendedSelection);
|
||||
|
||||
mTable->setModel (document.getData().getTableModel (universalId));
|
||||
|
||||
mTable->resizeColumnsToContents();
|
||||
mTable->resizeRowsToContents();
|
||||
|
||||
setWidget (mTable);
|
||||
}
|
||||
|
||||
void CSVWorld::RegionMapSubView::setEditLock (bool locked)
|
||||
{
|
||||
|
||||
}
|
27
apps/opencs/view/world/regionmapsubview.hpp
Normal file
27
apps/opencs/view/world/regionmapsubview.hpp
Normal file
|
@ -0,0 +1,27 @@
|
|||
#ifndef CSV_WORLD_REGIONMAPSUBVIEW_H
|
||||
#define CSV_WORLD_REGIONMAPSUBVIEW_H
|
||||
|
||||
#include "../doc/subview.hpp"
|
||||
|
||||
class QTableView;
|
||||
|
||||
namespace CSMDoc
|
||||
{
|
||||
class Document;
|
||||
}
|
||||
|
||||
namespace CSVWorld
|
||||
{
|
||||
class RegionMapSubView : public CSVDoc::SubView
|
||||
{
|
||||
QTableView *mTable;
|
||||
|
||||
public:
|
||||
|
||||
RegionMapSubView (CSMWorld::UniversalId universalId, CSMDoc::Document& document);
|
||||
|
||||
virtual void setEditLock (bool locked);
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
|
@ -6,6 +6,7 @@
|
|||
#include "tablesubview.hpp"
|
||||
#include "dialoguesubview.hpp"
|
||||
#include "scriptsubview.hpp"
|
||||
#include "regionmapsubview.hpp"
|
||||
|
||||
void CSVWorld::addSubViewFactories (CSVDoc::SubViewFactoryManager& manager)
|
||||
{
|
||||
|
@ -38,6 +39,8 @@ void CSVWorld::addSubViewFactories (CSVDoc::SubViewFactoryManager& manager)
|
|||
|
||||
manager.add (CSMWorld::UniversalId::Type_Script, new CSVDoc::SubViewFactory<ScriptSubView>);
|
||||
|
||||
manager.add (CSMWorld::UniversalId::Type_RegionMap, new CSVDoc::SubViewFactory<RegionMapSubView>);
|
||||
|
||||
// manager.add (CSMWorld::UniversalId::Type_Global,
|
||||
// new CSVDoc::SubViewFactoryWithCreateFlag<DialogueSubView> (true));
|
||||
}
|
Loading…
Reference in a new issue