X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_ListModel.cxx;h=a452d2b3ba7145356f386adaf93f09285c28c6ca;hb=58bb6b7459bebeeb089c9ed486c4683a8bae7288;hp=8c1cb7208e2660b4b08a192b88fa450f345f0549;hpb=439579ec24edd8b147cab07f688d446d59029a1e;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_ListModel.cxx b/src/HYDROGUI/HYDROGUI_ListModel.cxx index 8c1cb720..a452d2b3 100644 --- a/src/HYDROGUI/HYDROGUI_ListModel.cxx +++ b/src/HYDROGUI/HYDROGUI_ListModel.cxx @@ -51,9 +51,6 @@ HYDROGUI_ListModel::HYDROGUI_ListModel( QObject* theParent ) myEye = QPixmap( 16, 16 ); myEye.fill( Qt::black ); } - - // Set the supported drag actions for the items in the model - setSupportedDragActions( Qt::MoveAction | Qt::CopyAction ); } /** @@ -63,6 +60,24 @@ HYDROGUI_ListModel::~HYDROGUI_ListModel() { } +void HYDROGUI_ListModel::setBackgroundColor(int theInd, QColor theColor) +{ + myColoredRow[theInd] = theColor; +} + +void HYDROGUI_ListModel::clearAllBackgroundColors() +{ + myColoredRow.clear(); +} + +QColor HYDROGUI_ListModel::getBackgroundColor(int theInd) const +{ + if (myColoredRow.count( theInd )) + return myColoredRow[theInd]; + else + return QColor(); +} + /** */ QVariant HYDROGUI_ListModel::data( const QModelIndex &theIndex, int theRole ) const @@ -82,6 +97,16 @@ QVariant HYDROGUI_ListModel::data( const QModelIndex &theIndex, int theRole ) co return QVariant(); } break; + case Qt::BackgroundRole: + { + if( aColumn==0 && aRow >=0 && aRow < myObjects.count() && myColoredRow.contains(aRow)) + { + QBrush aBackgr(myColoredRow[aRow]); + return aBackgr; + } + else + return QVariant(); + } case Qt::DecorationRole: { @@ -128,9 +153,9 @@ int HYDROGUI_ListModel::rowCount( const QModelIndex &theParent ) const */ void HYDROGUI_ListModel::setObjects( const Object2VisibleList& theObjects ) { + beginResetModel(); myObjects = theObjects; - - reset(); + endResetModel(); } /** @@ -154,9 +179,9 @@ HYDROGUI_ListModel::ObjectList HYDROGUI_ListModel::getObjects() const */ void HYDROGUI_ListModel::addObject( const Object2Visible& theObject ) { + beginResetModel(); myObjects << theObject; - - reset(); + endResetModel(); } /** @@ -172,9 +197,9 @@ void HYDROGUI_ListModel::removeObjectByName( const QString& theObjectName ) } } + beginResetModel(); myObjects.removeAll(anItem); - - reset(); + endResetModel(); } @@ -287,6 +312,14 @@ Qt::DropActions HYDROGUI_ListModel::supportedDropActions() const return Qt::MoveAction | Qt::CopyAction; } +/** +*/ +Qt::DropActions HYDROGUI_ListModel::supportedDragActions() const +{ + // Set the supported drag actions for the items in the model + return Qt::MoveAction | Qt::CopyAction; +} + /** Get list of ids by the list model indexes. @param theIsToSort defines if the list of ids should be sorted in ascending order @@ -372,6 +405,7 @@ bool HYDROGUI_ListModel::move( const int theItem, const OpType theType, if ( aDestinationIndex >= 0 && aDestinationIndex < myObjects.count() ) { int aDestinationRow = isInsertBefore ? aDestinationIndex : aDestinationIndex + 1; if ( beginMoveRows( QModelIndex(), theItem, theItem, QModelIndex(), aDestinationRow ) ) { + myPrevObjects = myObjects; myObjects.move( theItem, aDestinationIndex ); endMoveRows(); aRes = true; @@ -487,4 +521,11 @@ bool HYDROGUI_ListModel::isDragAndDropAllowed( const QList& theItems, void HYDROGUI_ListModel::setDecorationEnabled( const bool theIsToEnable ) { myIsDecorationEnabled = theIsToEnable; -} \ No newline at end of file +} + +void HYDROGUI_ListModel::undoLastMove() +{ + beginResetModel(); + myObjects = myPrevObjects; + endResetModel(); +}