// Object Viewer Qt - MMORPG Framework // Copyright (C) 2010 Winch Gate Property Limited // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as // published by the Free Software Foundation, either version 3 of the // License, or (at your option) any later version. // // This program 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 Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . #include #include "tile_item.h" //#include "tile_widget.h" #include Node::Node() : m_parentItem(0) { } Node::Node(const QVector &data, Node *parent) { m_parentItem = parent; m_itemData = data; } Node::~Node() { qDeleteAll(m_childItems); m_childItems.clear(); } void Node::appendChild(Node *item) { m_childItems.append(item); } Node *Node::child(int row) { //nlinfo("row %d and size %d", row, childItems.size()); return m_childItems.value(row); } int Node::childCount() const { return m_childItems.count(); } int Node::childNumber() const { if(m_parentItem) return m_parentItem->m_childItems.indexOf(const_cast(this)); return 0; } bool Node::insertChildren(int position, int count, int columns) { if(position<0 || position>m_childItems.size()) return false; for(int row = 0; row < count; row++) { QVector data(columns); Node *item = new Node(data, this); m_childItems.insert(position, item); } return true; } bool Node::removeChildren(int position, int count) { if(position<0 || position+count>m_childItems.size()) return false; for(int row=0; row m_itemData.size()) return false; for(int column=0; columninsertColumns(position, columns); return true; } int Node::row() const { if(m_parentItem) return m_parentItem->m_childItems.indexOf(const_cast(this)); return 0; } int Node::columnCount() const { return m_itemData.count(); } QVariant Node::data(int column, int role) const { if(role == Qt::DisplayRole || role == TileModel::TileFilenameIndexRole || role == TileModel::TileFilenameRole || role == TileModel::TileIndexRole) return m_itemData.value(column); return QVariant(); } bool Node::setData(int column, const QVariant &value) { if(column < 0 || column >= m_itemData.size()) return false; m_itemData[column] = value; return true; } Node *Node::parent() { return m_parentItem; } void Node::setParent(Node *parent) { m_parentItem = parent; } void Node::appendRow(const QList &items) { Q_FOREACH(Node *item, items) appendRow(item); } void Node::appendRow(Node *item) { item->setParent(this); m_childItems.append(item); } void Node::swapRows( int a, int b ) { Node *temp = m_childItems[ a ]; m_childItems[ a ] = m_childItems[ b ]; m_childItems[ b ] = temp; } /////////////////////////////////////////////////// TileSetNode::TileSetNode(QString tileSetName, Node *parent) : m_tileSetName(tileSetName) { m_parentItem = parent; m_oriented = false; } TileSetNode::~TileSetNode() { qDeleteAll(m_childItems); m_childItems.clear(); } QVariant TileSetNode::data(int column, int role) const { if(role == Qt::DisplayRole || role == TileModel::TileFilenameIndexRole || role == TileModel::TileFilenameRole || role == TileModel::TileIndexRole) return QVariant(m_tileSetName); return QVariant(); } int TileSetNode::columnCount() const { return 1; } /////////////////////////////////////////////////// TileTypeNode::TileTypeNode(TileModel::TNodeTileType type, Node *parent) : m_nodeTileType(type) { m_parentItem = parent; } TileTypeNode::~TileTypeNode() { qDeleteAll(m_childItems); m_childItems.clear(); } QVariant TileTypeNode::data(int column, int role) const { if(role == Qt::DisplayRole || role == TileModel::TileFilenameIndexRole || role == TileModel::TileFilenameRole || role == TileModel::TileIndexRole) return QVariant(TileModel::getTileTypeName(m_nodeTileType)); return QVariant(); } int TileTypeNode::columnCount() const { return 1; } TileModel::TNodeTileType TileTypeNode::getTileType() { return m_nodeTileType; } bool TileTypeNode::removeChildren( int position, int count ) { bool ok = Node::removeChildren( position, count ); if( !ok ) return false; reindex(); return true; } void TileTypeNode::reindex() { int i = 0; QListIterator< Node* > itr( m_childItems ); while( itr.hasNext() ) { TileItemNode *n = dynamic_cast< TileItemNode* >( itr.next() ); if( n == NULL ) continue; n->setId( i ); i++; } } /////////////////////////////////////////////////// TileItemNode::TileItemNode(int tileId, TileModel::TTileChannel channel, QString filename, Node *parent) : m_tileId(tileId) { m_tileFilename[channel] = filename; m_parentItem = parent; //nlinfo("dispalying tile %d - %s", m_tileId, m_tileFilename[TileModel::TileDiffuse].toAscii().data()); } TileItemNode::~TileItemNode() { qDeleteAll(m_childItems); } void TileItemNode::setTileFilename(TileModel::TTileChannel channel, QString filename) { m_tileFilename[channel] = filename; } QString TileItemNode::getTileFilename(TileModel::TTileChannel channel) { QMap< TileModel::TTileChannel, QString >::const_iterator itr = m_tileFilename.find( channel ); if( itr == m_tileFilename.end() ) return ""; return itr.value(); } QVariant TileItemNode::data(int column, int role) const { // find some way to know which file/bitmap to display QString tileFilename = m_tileFilename[TileModel::TileDiffuse]; if(role == TileModel::TilePixmapRole || role == Qt::DecorationRole) { TileTypeNode *parent = dynamic_cast(m_parentItem); if(parent == NULL) return QVariant(); // Retrieve the target tile size. uint32 tileSize = TileModel::getTileTypeSize(parent->getTileType()); if(tileFilename.isEmpty() || tileFilename == "empty") tileFilename = ":/placeHolder/images/empty_image.png"; QPixmap pixmap;// = new QPixmap(); if(!pixmap.load(tileFilename)) nlinfo("failed to load %s", tileFilename.toAscii().data()); if(TileModel::CurrentZoomFactor == TileModel::TileZoom200) tileSize *= 2; else if(TileModel::CurrentZoomFactor == TileModel::TileZoom50) tileSize /= 2; pixmap.scaled(tileSize, tileSize); return pixmap; } else if(role == Qt::DisplayRole) { return QVariant(tileFilename); } else if(role == TileModel::TileFilenameRole) { return QVariant(tileFilename); } else if(role == TileModel::TileIndexRole) { return QVariant("("+QString::number(m_tileId)+")"); } else if(role == TileModel::TileFilenameIndexRole) { return QVariant(tileFilename + " ("+QString::number(m_tileId)+")"); } return QVariant(); } int TileItemNode::columnCount() const { return 1; }