X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ViewWindow.cpp;h=7c0bc5d9ac14c8c9e225178db90b52ae4344bf63;hb=057e426145a26c02a1c5d6e1c220f92a17d8e53d;hp=fd8f1dc9e19149df50af3e01ac84694438a9ca2b;hpb=199ba9a901b30996e1185a1e7d7b05d972ca8121;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ViewWindow.cpp b/src/XGUI/XGUI_ViewWindow.cpp index fd8f1dc9e..7c0bc5d9a 100644 --- a/src/XGUI/XGUI_ViewWindow.cpp +++ b/src/XGUI/XGUI_ViewWindow.cpp @@ -15,6 +15,7 @@ #include #include #include +#include #include #include @@ -77,27 +78,50 @@ const char* imageCrossCursor[] = { "32 32 3 1", ". c None", "a c #000000", "# c "................................", "................................", "................................", "................................" }; -//************************************************************************** -void ViewerToolbar::repaintBackground() + +ViewerToolbar::ViewerToolbar(QWidget* theParent, XGUI_ViewPort* thePort) + : QToolBar(theParent), myVPort(thePort), myResize(false) { + connect(myVPort, SIGNAL(resized()), this, SLOT(onViewPortResized())); +} + +void ViewerToolbar::paintEvent(QPaintEvent* theEvent) +{ + //QToolBar::paintEvent(theEvent); + // Paint background + QPainter aPainter(this); QRect aRect = rect(); QRect aVPRect = myVPort->rect(); QPoint aGlobPnt = mapToGlobal(aRect.topLeft()); QPoint aPnt = myVPort->mapFromGlobal(aGlobPnt); - QRect aImgRect(QRect(aPnt.x(), aPnt.y() + aVPRect.height() - aRect.height(), + QRect aImgRect(QRect(aPnt.x(), aPnt.y() + aVPRect.height() - aRect.height(), aRect.width(), aRect.height())); - QPainter(this).drawImage(aRect, myVPort->dumpView(aImgRect, false)); + QImage aImg = myVPort->dumpView(aImgRect, myResize); + if (!aImg.isNull()) + aPainter.drawImage(aRect, aImg); + myResize = false; + + // Paint foreground + QStyle *style = this->style(); + QStyleOptionToolBar aOpt; + initStyleOption(&aOpt); + + aOpt.rect = style->subElementRect(QStyle::SE_ToolBarHandle, &aOpt, this); + if (aOpt.rect.isValid()) + style->drawPrimitive(QStyle::PE_IndicatorToolBarHandle, &aOpt, &aPainter, this); } -void ViewerToolbar::paintEvent(QPaintEvent* theEvent) + + +//************************************************************************** +ViewerLabel::ViewerLabel(QWidget* theParent, XGUI_ViewPort* thePort) + : QLabel(theParent), myVPort(thePort), myResize(false) { - repaintBackground(); - //QToolBar::paintEvent(theEvent); + connect(myVPort, SIGNAL(resized()), this, SLOT(onViewPortResized())); } -//************************************************************************** -void ViewerLabel::repaintBackground() +void ViewerLabel::paintEvent(QPaintEvent* theEvent) { QRect aRect = rect(); QRect aVPRect = myVPort->rect(); @@ -106,12 +130,10 @@ void ViewerLabel::repaintBackground() QRect aImgRect(QRect(aPnt.x(), aPnt.y() + aVPRect.height() - aRect.height(), aRect.width(), aRect.height())); - QPainter(this).drawImage(aRect, myVPort->dumpView(aImgRect, false)); -} - -void ViewerLabel::paintEvent(QPaintEvent* theEvent) -{ - repaintBackground(); + QImage aImg = myVPort->dumpView(aImgRect, myResize); + if (!aImg.isNull()) + QPainter(this).drawImage(aRect, aImg); + myResize = false; QLabel::paintEvent(theEvent); } @@ -136,7 +158,8 @@ XGUI_ViewWindow::XGUI_ViewWindow(XGUI_Viewer* theViewer, V3d_TypeOfView theType) myClosable(true), myStartX(0), myStartY(0), myCurrX(0), myCurrY(0), myCurScale(0.0), myCurSketch(0), myDrawRect(false), myEnableDrawMode(false), myCursorIsHand(false), myEventStarted(false), - myLastState(NormalState), myOperation(NOTHING) + myIsActive(false), + myLastState(WindowNormalState), myOperation(NOTHING) { mySelectedPoint = gp_Pnt(0., 0., 0.); setFrameStyle(QFrame::Raised); @@ -148,6 +171,7 @@ XGUI_ViewWindow::XGUI_ViewWindow(XGUI_Viewer* theViewer, V3d_TypeOfView theType) aLay->setContentsMargins(BORDER_SIZE, BORDER_SIZE, BORDER_SIZE, BORDER_SIZE); myViewPort = new XGUI_ViewPort(this, myViewer->v3dViewer(), theType); myViewPort->installEventFilter(this); + myViewPort->setCursor(Qt::ArrowCursor); aLay->addWidget(myViewPort); myPicture = new QLabel(this); @@ -158,14 +182,30 @@ XGUI_ViewWindow::XGUI_ViewWindow(XGUI_Viewer* theViewer, V3d_TypeOfView theType) aLay->addWidget(myPicture); myPicture->hide(); + QVBoxLayout* aVPLay = new QVBoxLayout(myViewPort); + aVPLay->setMargin(0); + aVPLay->setSpacing(0); + aVPLay->setContentsMargins(0,0,0,0); + + QHBoxLayout* aToolLay = new QHBoxLayout(); + aToolLay->setMargin(0); + aToolLay->setSpacing(0); + aToolLay->setContentsMargins(0,0,0,0); + aVPLay->addLayout(aToolLay); + aVPLay->addStretch(); + myGripWgt = new ViewerLabel(this, myViewPort); myGripWgt->setPixmap(QPixmap(":pictures/wnd_grip.png")); - myGripWgt->setGeometry(BORDER_SIZE + 2, BORDER_SIZE + 2, 19, 32); myGripWgt->setMouseTracking(true); myGripWgt->installEventFilter(this); + myGripWgt->setCursor(Qt::OpenHandCursor); + aToolLay->addWidget(myGripWgt); // Create Viewer management buttons myViewBar = new ViewerToolbar(this, myViewPort); + myViewBar->setCursor(Qt::PointingHandCursor); + aToolLay->addWidget(myViewBar); + aToolLay->addStretch(); QAction* aBtn; @@ -232,6 +272,8 @@ XGUI_ViewWindow::XGUI_ViewWindow(XGUI_Viewer* theViewer, V3d_TypeOfView theType) // Create Window management buttons myWindowBar = new ViewerToolbar(this, myViewPort); + myWindowBar->setCursor(Qt::PointingHandCursor); + aToolLay->addWidget(myWindowBar); myMinimizeBtn = new QAction(myWindowBar); myMinimizeBtn->setIcon(MinimizeIco); @@ -248,16 +290,11 @@ XGUI_ViewWindow::XGUI_ViewWindow(XGUI_Viewer* theViewer, V3d_TypeOfView theType) myWindowBar->addAction(aBtn); connect(aBtn, SIGNAL(triggered()), SLOT(onClose())); - myViewBar->hide(); - myWindowBar->hide(); - myGripWgt->hide(); - //Support copy of background on updating of viewer connect(myViewPort, SIGNAL(vpTransformed()), this, SLOT(updateToolBar())); connect(myViewPort, SIGNAL(vpUpdated()), this, SLOT(updateToolBar())); connect(this, SIGNAL(vpTransformationFinished(XGUI_ViewWindow::OperationType)), this, SLOT(updateToolBar())); - } //**************************************************************** @@ -265,19 +302,12 @@ XGUI_ViewWindow::~XGUI_ViewWindow() { } + //**************************************************************** -void XGUI_ViewWindow::resizeEvent(QResizeEvent* theEvent) +void XGUI_ViewWindow::showEvent(QShowEvent* theEvent) { - QSize aSize = theEvent->size(); - QSize aWndBarSize = myWindowBar->sizeHint(); - QSize myViewBarSize = myViewBar->sizeHint(); - - myWindowBar->move(aSize.width() - aWndBarSize.width() - BORDER_SIZE - 4, - BORDER_SIZE + 2); - int aViewBarWidth = aSize.width() - aWndBarSize.width() - myGripWgt->width() - 8; - if (aViewBarWidth > myViewBarSize.width()) - aViewBarWidth = myViewBarSize.width(); - myViewBar->setGeometry(BORDER_SIZE + 18, BORDER_SIZE + 2, aViewBarWidth, myViewBarSize.height()); + QFrame::showEvent(theEvent); + myWindowBar->setFixedSize(myWindowBar->sizeHint()); } //**************************************************************** @@ -286,53 +316,77 @@ void XGUI_ViewWindow::changeEvent(QEvent* theEvent) if (theEvent->type() == QEvent::WindowStateChange) { if (isMinimized()) { - myViewBar->hide(); - myGripWgt->hide(); - myWindowBar->hide(); - myViewPort->hide(); - myPicture->show(); + if (myPicture->isHidden()) { + myViewBar->hide(); + myGripWgt->hide(); + myWindowBar->hide(); + myViewPort->hide(); + myPicture->show(); + } } else { - myPicture->hide(); - myViewPort->show(); + if (myPicture->isVisible()) { + myPicture->hide(); + myViewPort->show(); + } if (isMaximized()) { myMinimizeBtn->setIcon(MinimizeIco); myMaximizeBtn->setIcon(RestoreIco); } + myViewBar->setVisible(myIsActive); + myWindowBar->setVisible(myIsActive); + myGripWgt->setVisible(myIsActive && (!isMaximized())); } } else QWidget::changeEvent(theEvent); } + //**************************************************************** -void XGUI_ViewWindow::onClose() +void XGUI_ViewWindow::windowActivated() { - if (parentWidget()) { - emit tryClosing(this); - if (closable()) { - emit closed(static_cast(parentWidget())); - parentWidget()->close(); + if (!(isMinimized() || parentWidget()->isMinimized())) { + myIsActive = true; + if (isMaximized() || parentWidget()->isMaximized()) { + myMaximizeBtn->setIcon(RestoreIco); + } else { + myMaximizeBtn->setIcon(MaximizeIco); } - } + myViewBar->show(); + myWindowBar->show(); + myGripWgt->setVisible(!(isMaximized() || isMinimized() || + parentWidget()->isMaximized() || parentWidget()->isMinimized())); + } else + myIsActive = false; } //**************************************************************** -void XGUI_ViewWindow::enterEvent(QEvent* theEvent) +void XGUI_ViewWindow::windowDeactivated() { - if (!isMinimized()) { - myViewBar->show(); - myWindowBar->show(); - if (!isMaximized()) - myGripWgt->show(); + myIsActive = false; + if (!(isMinimized() || parentWidget()->isMinimized())) { + if (isMaximized() || parentWidget()->isMaximized()) { + myMaximizeBtn->setIcon(RestoreIco); + } else { + myMaximizeBtn->setIcon(MaximizeIco); + } + myViewBar->hide(); + myWindowBar->hide(); + myGripWgt->hide(); } } + //**************************************************************** -void XGUI_ViewWindow::leaveEvent(QEvent* theEvent) +void XGUI_ViewWindow::onClose() { - myViewBar->hide(); - myGripWgt->hide(); - myWindowBar->hide(); + if (parentWidget()) { + emit tryClosing(this); + if (closable()) { + emit closed(static_cast(parentWidget())); + parentWidget()->close(); + } + } } //**************************************************************** @@ -342,28 +396,37 @@ void XGUI_ViewWindow::onMinimize() int aW = width(); int aH = height(); double aR = aW / 100.; - int aNewH = int(aH / aR); - myPicture->setPixmap(aPMap.scaled(100, aNewH)); + int aNewH = int(aH / aR); + myPicture->setPixmap(aPMap.scaled(100, aNewH)); - myLastState = isMaximized() ? MaximizedState : NormalState; + myLastState = (isMaximized() || parentWidget()->isMaximized()) ? MaximizedState : WindowNormalState; showMinimized(); - parentWidget()->setGeometry(parentWidget()->x(), parentWidget()->y(), - 100, aNewH); + parentWidget()->showMinimized(); + parentWidget()->setGeometry(parentWidget()->x(), parentWidget()->y(), 100, aNewH); + parentWidget()->lower(); + windowDeactivated(); + myViewer->onWindowMinimized((QMdiSubWindow*)parentWidget()); } //**************************************************************** void XGUI_ViewWindow::onMaximize() { - if (isMaximized()) { + if (isMaximized() || parentWidget()->isMaximized()) { myMaximizeBtn->setIcon(MaximizeIco); myGripWgt->show(); showNormal(); + parentWidget()->showNormal(); } else { myMaximizeBtn->setIcon(RestoreIco); myGripWgt->hide(); showMaximized(); + parentWidget()->showMaximized(); } + parentWidget()->activateWindow(); myMinimizeBtn->setIcon(MinimizeIco); + + // In order to avoid frosen background in toolbars when it shown as a second view + QTimer::singleShot(50, parentWidget(), SLOT(setFocus())); } //**************************************************************** @@ -408,10 +471,16 @@ bool XGUI_ViewWindow::processWindowControls(QObject *theObj, QEvent *theEvent) case QEvent::MouseButtonDblClick: if (theObj == myPicture) { myMoving = false; - if (myLastState == MaximizedState) + if (myLastState == MaximizedState) { showMaximized(); - else + } else { showNormal(); + } + myViewer->onWindowActivated((QMdiSubWindow*)parentWidget()); + + // In order to avoid frosen background in toolbars when it shown as a second view + QTimer::singleShot(20, parentWidget(), SLOT(setFocus())); + return true; } } @@ -463,6 +532,10 @@ bool XGUI_ViewWindow::eventFilter(QObject *theObj, QEvent *theEvent) if (processViewPort(theEvent)) { return true; } + if (theEvent->type() == QEvent::KeyRelease) { + emit keyReleased(this, (QKeyEvent*) theEvent); + return true; + } } return QFrame::eventFilter(theObj, theEvent); } @@ -603,6 +676,16 @@ void XGUI_ViewWindow::vpMousePressEvent(QMouseEvent* theEvent) l_mbPressEvent = new QMouseEvent( *theEvent );*/ } +//**************************************************************** +void XGUI_ViewWindow::contextMenuEvent(QContextMenuEvent* theEvent) +{ + if (theEvent->modifiers() == Qt::NoModifier) { + // Temporary: has to be removed when viewer popup will be defined + //QFrame::contextMenuEvent(theEvent); + emit contextMenuRequested(theEvent); + } +} + //**************************************************************** void XGUI_ViewWindow::vpMouseReleaseEvent(QMouseEvent* theEvent) { @@ -619,10 +702,6 @@ void XGUI_ViewWindow::vpMouseReleaseEvent(QMouseEvent* theEvent) } */ emit mouseReleased(this, theEvent); - if (theEvent->button() == Qt::RightButton && prevState == -1) { - QContextMenuEvent aEvent(QContextMenuEvent::Mouse, theEvent->pos(), theEvent->globalPos()); - emit contextMenuRequested(&aEvent); - } } break; case ROTATE: @@ -648,7 +727,7 @@ void XGUI_ViewWindow::vpMouseReleaseEvent(QMouseEvent* theEvent) myCurrX = theEvent->x(); myCurrY = theEvent->y(); drawRect(); - QRect rect = makeRect(myStartX, myStartY, myCurrX, myCurrY); + QRect rect = XGUI_Tools::makeRect(myStartX, myStartY, myCurrX, myCurrY); if (!rect.isEmpty()) myViewPort->fitRect(rect); endDrawRect(); @@ -780,7 +859,7 @@ void XGUI_ViewWindow::drawRect() } myRectBand->setUpdatesEnabled(false); - QRect aRect = makeRect(myStartX, myStartY, myCurrX, myCurrY); + QRect aRect = XGUI_Tools::makeRect(myStartX, myStartY, myCurrX, myCurrY); myRectBand->initGeometry(aRect); if (!myRectBand->isVisible()) @@ -944,7 +1023,11 @@ void XGUI_ViewWindow::cloneView() QMdiSubWindow* vw = myViewer->createView(); XGUI_ViewWindow* aNewWnd = static_cast(vw->widget()); aNewWnd->viewPort()->syncronizeWith(myViewPort); + emit viewCloned( vw ); + + // In order to avoid frosen background in toolbars when it shown as a second view + QTimer::singleShot(20, vw, SLOT(setFocus())); } void XGUI_ViewWindow::dumpView() @@ -956,7 +1039,7 @@ void XGUI_ViewWindow::dumpView() QApplication::setOverrideCursor( Qt::WaitCursor ); QImage aPicture = myViewPort->dumpView(); - QString aFmt = extension(aFileName).toUpper(); + QString aFmt = XGUI_Tools::extension(aFileName).toUpper(); if( aFmt.isEmpty() ) aFmt = QString( "BMP" ); // default format else if( aFmt == "JPG" ) @@ -964,9 +1047,9 @@ void XGUI_ViewWindow::dumpView() Handle(Visual3d_View) a3dView = myViewPort->getView()->View(); if (aFmt == "PS") - a3dView->Export(_strdup(qPrintable(aFileName)), Graphic3d_EF_PostScript); + a3dView->Export(strdup(qPrintable(aFileName)), Graphic3d_EF_PostScript); else if (aFmt == "EPS") - a3dView->Export(_strdup(qPrintable(aFileName)), Graphic3d_EF_EnhPostScript); + a3dView->Export(strdup(qPrintable(aFileName)), Graphic3d_EF_EnhPostScript); else aPicture.save( aFileName, aFmt.toLatin1() ); QApplication::restoreOverrideCursor(); @@ -1095,13 +1178,13 @@ void XGUI_ViewWindow::updateToolBar() myGripWgt->update(); myViewBar->update(); myWindowBar->update(); - //QTimer::singleShot(50, Qt::VeryCoarseTimer, this, SLOT(repaintToolBar())); } -/*void XGUI_ViewWindow::repaintToolBar() +/*! + \brief Update state of enable draw mode state. +*/ +void XGUI_ViewWindow::updateEnabledDrawMode() { - QApplication::sync(); - myGripWgt->repaint(); - myViewBar->repaint(); - myWindowBar->repaint(); -}*/ + myEnableDrawMode = myViewer->isSelectionEnabled() && + myViewer->isMultiSelectionEnabled(); +}