mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 02:00:34 +05:00
preferences of scalar bar is used only when scalar bar actor is created, but user can change scalar bar properties using dialog, as early
This commit is contained in:
parent
e38e79d2e2
commit
53e2da7a18
@ -3303,29 +3303,4 @@ void SMESHGUI::createPreferences()
|
|||||||
|
|
||||||
void SMESHGUI::preferencesChanged( const QString& sect, const QString& name )
|
void SMESHGUI::preferencesChanged( const QString& sect, const QString& name )
|
||||||
{
|
{
|
||||||
if( sect=="SMESH" )
|
|
||||||
{
|
|
||||||
if( name=="scalar_bar_num_colors" || name=="scalar_bar_num_labels" || name=="scalar_bar_orientation" ||
|
|
||||||
name=="scalar_bar_vertical_x" || name=="scalar_bar_vertical_y" || name=="scalar_bar_vertical_width" ||
|
|
||||||
name=="scalar_bar_vertical_height" || name=="scalar_bar_horizontal_x" || name=="scalar_bar_horizontal_y" ||
|
|
||||||
name=="scalar_bar_horizontal_width" || name=="scalar_bar_horizontal_height" )
|
|
||||||
{
|
|
||||||
SVTK_ViewWindow* wnd = SMESH::GetViewWindow( this );
|
|
||||||
if( !wnd )
|
|
||||||
return;
|
|
||||||
|
|
||||||
vtkRenderer* r = wnd->getRenderer();
|
|
||||||
if( !r )
|
|
||||||
return;
|
|
||||||
|
|
||||||
vtkActorCollection* actors = r->GetActors();
|
|
||||||
if( !actors )
|
|
||||||
return;
|
|
||||||
|
|
||||||
actors->InitTraversal();
|
|
||||||
while( vtkActor* a = actors->GetNextActor() )
|
|
||||||
if( SMESH_Actor* sa = dynamic_cast<SMESH_Actor*>( a ) )
|
|
||||||
sa->UpdateScalarBar();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -329,83 +329,89 @@ SMESHGUI_Preferences_ScalarBarDlg::SMESHGUI_Preferences_ScalarBarDlg( SMESHGUI*
|
|||||||
SUIT_ResourceMgr* mgr = SMESH::GetResourceMgr( mySMESHGUI );
|
SUIT_ResourceMgr* mgr = SMESH::GetResourceMgr( mySMESHGUI );
|
||||||
|
|
||||||
QColor titleColor (255, 255, 255);
|
QColor titleColor (255, 255, 255);
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarTitleColor")) {
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_title_color")) {
|
||||||
QStringList aTColor =
|
QStringList aTColor =
|
||||||
QStringList::split(":", mgr->stringValue("SMESH", "ScalarBarTitleColor"), false);
|
QStringList::split(":", mgr->stringValue("SMESH", "scalar_bar_title_color"), false);
|
||||||
titleColor = QColor((aTColor.count() > 0 ? aTColor[0].toInt() : 255),
|
titleColor = QColor((aTColor.count() > 0 ? aTColor[0].toInt() : 255),
|
||||||
(aTColor.count() > 1 ? aTColor[1].toInt() : 255),
|
(aTColor.count() > 1 ? aTColor[1].toInt() : 255),
|
||||||
(aTColor.count() > 2 ? aTColor[2].toInt() : 255));
|
(aTColor.count() > 2 ? aTColor[2].toInt() : 255));
|
||||||
}
|
}
|
||||||
myTitleColorBtn->setPaletteBackgroundColor(titleColor);
|
myTitleColorBtn->setPaletteBackgroundColor(titleColor);
|
||||||
myTitleFontCombo->setCurrentItem(0);
|
myTitleFontCombo->setCurrentItem(0);
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarTitleFont")) {
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_title_font")) {
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarTitleFont") == "Arial")
|
QFont f = mgr->fontValue( "SMESH", "scalar_bar_title_font" );
|
||||||
|
if( f.family()=="Arial" )
|
||||||
myTitleFontCombo->setCurrentItem(0);
|
myTitleFontCombo->setCurrentItem(0);
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarTitleFont") == "Courier")
|
if( f.family()=="Courier" )
|
||||||
myTitleFontCombo->setCurrentItem(1);
|
myTitleFontCombo->setCurrentItem(1);
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarTitleFont") == "Times")
|
if( f.family()=="Times")
|
||||||
myTitleFontCombo->setCurrentItem(2);
|
myTitleFontCombo->setCurrentItem(2);
|
||||||
|
|
||||||
|
myTitleBoldCheck->setChecked ( f.bold() );
|
||||||
|
myTitleItalicCheck->setChecked( f.italic() );
|
||||||
|
myTitleShadowCheck->setChecked( f.underline() );
|
||||||
}
|
}
|
||||||
myTitleBoldCheck->setChecked (mgr && mgr->stringValue("SMESH", "ScalarBarTitleBold") == "true");
|
|
||||||
myTitleItalicCheck->setChecked(mgr && mgr->stringValue("SMESH", "ScalarBarTitleItalic") == "true");
|
|
||||||
myTitleShadowCheck->setChecked(mgr && mgr->stringValue("SMESH", "ScalarBarTitleShadow") == "true");
|
|
||||||
|
|
||||||
QColor labelColor (255, 255, 255);
|
QColor labelColor (255, 255, 255);
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarLabelColor")) {
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_label_color")) {
|
||||||
QStringList aLColor =
|
QStringList aLColor =
|
||||||
QStringList::split(":", mgr->stringValue("SMESH", "ScalarBarLabelColor"), false);
|
QStringList::split(":", mgr->stringValue("SMESH", "scalar_bar_label_color"), false);
|
||||||
labelColor = QColor((aLColor.count() > 0 ? aLColor[0].toInt() : 255),
|
labelColor = QColor((aLColor.count() > 0 ? aLColor[0].toInt() : 255),
|
||||||
(aLColor.count() > 1 ? aLColor[1].toInt() : 255),
|
(aLColor.count() > 1 ? aLColor[1].toInt() : 255),
|
||||||
(aLColor.count() > 2 ? aLColor[2].toInt() : 255));
|
(aLColor.count() > 2 ? aLColor[2].toInt() : 255));
|
||||||
}
|
}
|
||||||
myLabelsColorBtn->setPaletteBackgroundColor(labelColor);
|
myLabelsColorBtn->setPaletteBackgroundColor(labelColor);
|
||||||
myLabelsFontCombo->setCurrentItem(0);
|
myLabelsFontCombo->setCurrentItem(0);
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarLabelFont")) {
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_label_font")) {
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarLabelFont") == "Arial")
|
QFont f = mgr->fontValue( "SMESH", "scalar_bar_label_font" );
|
||||||
|
if (f.family() == "Arial")
|
||||||
myLabelsFontCombo->setCurrentItem(0);
|
myLabelsFontCombo->setCurrentItem(0);
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarLabelFont") == "Courier")
|
if (f.family() == "Courier")
|
||||||
myLabelsFontCombo->setCurrentItem(1);
|
myLabelsFontCombo->setCurrentItem(1);
|
||||||
if (mgr->stringValue("SMESH", "ScalarBarLabelFont") == "Times")
|
if (f.family() == "Times")
|
||||||
myLabelsFontCombo->setCurrentItem(2);
|
myLabelsFontCombo->setCurrentItem(2);
|
||||||
|
|
||||||
|
myLabelsBoldCheck ->setChecked( f.bold() );
|
||||||
|
myLabelsItalicCheck->setChecked( f.italic() );
|
||||||
|
myLabelsShadowCheck->setChecked( f.underline() );
|
||||||
}
|
}
|
||||||
myLabelsBoldCheck ->setChecked(mgr && mgr->stringValue("SMESH", "ScalarBarLabelBold") == "true");
|
|
||||||
myLabelsItalicCheck->setChecked(mgr && mgr->stringValue("SMESH", "ScalarBarLabelItalic") == "true");
|
|
||||||
myLabelsShadowCheck->setChecked(mgr && mgr->stringValue("SMESH", "ScalarBarLabelShadow") == "true");
|
|
||||||
|
|
||||||
int aNbColors = 64;
|
int aNbColors = 64;
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarNbOfColors"))
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_num_colors"))
|
||||||
aNbColors = mgr->integerValue("SMESH", "ScalarBarNbOfColors");
|
aNbColors = mgr->integerValue("SMESH", "scalar_bar_num_colors");
|
||||||
myColorsSpin->setValue(aNbColors);
|
myColorsSpin->setValue(aNbColors);
|
||||||
|
|
||||||
int aNbLabels = 5;
|
int aNbLabels = 5;
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarNbOfLabels"))
|
if (mgr && mgr->hasValue("SMESH", "scalar_bar_num_labels"))
|
||||||
aNbLabels = mgr->integerValue("SMESH", "ScalarBarNbOfLabels");
|
aNbLabels = mgr->integerValue("SMESH", "scalar_bar_num_labels");
|
||||||
myLabelsSpin->setValue(aNbLabels);
|
myLabelsSpin->setValue(aNbLabels);
|
||||||
|
|
||||||
QString aOrientation = (mgr ? mgr->stringValue("SMESH", "ScalarBarOrientation") : "");
|
int aOrientation = ( mgr ? mgr->integerValue( "SMESH", "scalar_bar_orientation", 1 ) : 1 );
|
||||||
if (aOrientation == "Horizontal")
|
bool isHoriz = ( aOrientation==1 );
|
||||||
|
if (aOrientation == 1)
|
||||||
myHorizRadioBtn->setChecked(true);
|
myHorizRadioBtn->setChecked(true);
|
||||||
else
|
else
|
||||||
myVertRadioBtn->setChecked(true);
|
myVertRadioBtn->setChecked(true);
|
||||||
myIniOrientation = myVertRadioBtn->isChecked();
|
myIniOrientation = myVertRadioBtn->isChecked();
|
||||||
|
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarXPosition"))
|
QString name = isHoriz ? "scalar_bar_horizontal_%1" : "scalar_bar_vertical_%1";
|
||||||
myIniX = mgr->doubleValue("SMESH", "ScalarBarXPosition");
|
if (mgr && mgr->hasValue("SMESH", name.arg( "x" )))
|
||||||
|
myIniX = mgr->doubleValue("SMESH", name.arg( "x" ));
|
||||||
else
|
else
|
||||||
myIniX = myHorizRadioBtn->isChecked() ? DEF_HOR_X : DEF_VER_X;
|
myIniX = myHorizRadioBtn->isChecked() ? DEF_HOR_X : DEF_VER_X;
|
||||||
|
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarYPosition"))
|
if (mgr && mgr->hasValue("SMESH", name.arg( "y" )))
|
||||||
myIniY = mgr->doubleValue("SMESH", "ScalarBarYPosition");
|
myIniY = mgr->doubleValue("SMESH", name.arg( "y" ));
|
||||||
else
|
else
|
||||||
myIniY = myHorizRadioBtn->isChecked() ? DEF_HOR_Y : DEF_VER_Y;
|
myIniY = myHorizRadioBtn->isChecked() ? DEF_HOR_Y : DEF_VER_Y;
|
||||||
|
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarWidth"))
|
if (mgr && mgr->hasValue("SMESH", name.arg( "width" )))
|
||||||
myIniW = mgr->doubleValue("SMESH", "ScalarBarWidth");
|
myIniW = mgr->doubleValue("SMESH", name.arg( "width" ));
|
||||||
else
|
else
|
||||||
myIniW = myHorizRadioBtn->isChecked() ? DEF_HOR_W : DEF_VER_W;
|
myIniW = myHorizRadioBtn->isChecked() ? DEF_HOR_W : DEF_VER_W;
|
||||||
|
|
||||||
if (mgr && mgr->hasValue("SMESH", "ScalarBarHeight"))
|
if (mgr && mgr->hasValue("SMESH", name.arg( "height" )))
|
||||||
myIniH = mgr->doubleValue("SMESH", "ScalarBarHeight");
|
myIniH = mgr->doubleValue("SMESH", name.arg( "height" ));
|
||||||
else
|
else
|
||||||
myIniH = myHorizRadioBtn->isChecked() ? DEF_HOR_H : DEF_VER_H;
|
myIniH = myHorizRadioBtn->isChecked() ? DEF_HOR_H : DEF_VER_H;
|
||||||
|
|
||||||
@ -521,43 +527,46 @@ bool SMESHGUI_Preferences_ScalarBarDlg::onApply()
|
|||||||
if (!mgr) return false;
|
if (!mgr) return false;
|
||||||
|
|
||||||
QColor titleColor = myTitleColorBtn->paletteBackgroundColor();
|
QColor titleColor = myTitleColorBtn->paletteBackgroundColor();
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleColor",
|
mgr->setValue("SMESH", "scalar_bar_title_color", titleColor );
|
||||||
QString().sprintf("%d:%d:%d", titleColor.red(), titleColor.green(), titleColor.blue()));
|
|
||||||
if (myTitleFontCombo->currentItem() == 0)
|
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleFont", "Arial");
|
|
||||||
else if (myTitleFontCombo->currentItem() == 1)
|
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleFont", "Courier");
|
|
||||||
else
|
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleFont", "Times");
|
|
||||||
|
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleBold" , myTitleBoldCheck ->isChecked() ? "true" : "false");
|
QFont f;
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleItalic", myTitleItalicCheck->isChecked() ? "true" : "false");
|
if (myTitleFontCombo->currentItem() == 0)
|
||||||
mgr->setValue("SMESH", "ScalarBarTitleShadow", myTitleShadowCheck->isChecked() ? "true" : "false");
|
f.setFamily( "Arial" );
|
||||||
|
else if (myTitleFontCombo->currentItem() == 1)
|
||||||
|
f.setFamily( "Courier" );
|
||||||
|
else
|
||||||
|
f.setFamily( "Times");
|
||||||
|
|
||||||
|
f.setBold( myTitleBoldCheck ->isChecked() );
|
||||||
|
f.setItalic( myTitleItalicCheck->isChecked() );
|
||||||
|
f.setUnderline( myTitleShadowCheck->isChecked() );
|
||||||
|
mgr->setValue( "SMESH", "scalar_bar_title_font", f );
|
||||||
|
|
||||||
QColor labelColor = myLabelsColorBtn->paletteBackgroundColor();
|
QColor labelColor = myLabelsColorBtn->paletteBackgroundColor();
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelColor",
|
mgr->setValue("SMESH", "scalar_bar_label_color", labelColor );
|
||||||
QString().sprintf("%d:%d:%d", labelColor.red(), labelColor.green(),labelColor. blue()));
|
|
||||||
|
|
||||||
if (myLabelsFontCombo->currentItem() == 0)
|
if (myLabelsFontCombo->currentItem() == 0)
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelFont", "Arial");
|
f.setFamily( "Arial" );
|
||||||
else if ( myLabelsFontCombo->currentItem() == 1 )
|
else if ( myLabelsFontCombo->currentItem() == 1 )
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelFont", "Courier");
|
f.setFamily( "Courier");
|
||||||
else
|
else
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelFont", "Times");
|
f.setFamily( "Times");
|
||||||
|
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelBold", myLabelsBoldCheck->isChecked() ? "true" : "false");
|
f.setBold( myLabelsBoldCheck ->isChecked() );
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelItalic", myLabelsItalicCheck->isChecked() ? "true" : "false");
|
f.setItalic( myLabelsItalicCheck->isChecked() );
|
||||||
mgr->setValue("SMESH", "ScalarBarLabelShadow", myLabelsShadowCheck->isChecked() ? "true" : "false");
|
f.setUnderline( myLabelsShadowCheck->isChecked() );
|
||||||
|
mgr->setValue( "SMESH", "scalar_bar_label_font", f );
|
||||||
|
|
||||||
mgr->setValue("SMESH", "ScalarBarNbOfColors", myColorsSpin->value());
|
mgr->setValue("SMESH", "scalar_bar_num_colors", myColorsSpin->value());
|
||||||
mgr->setValue("SMESH", "ScalarBarNbOfLabels", myLabelsSpin->value());
|
mgr->setValue("SMESH", "scalar_bar_num_labels", myLabelsSpin->value());
|
||||||
|
|
||||||
mgr->setValue("SMESH", "ScalarBarOrientation", myHorizRadioBtn->isChecked() ? "Horizontal" : "Vertical");
|
mgr->setValue("SMESH", "scalar_bar_orientation", myHorizRadioBtn->isChecked() ? 1 : 0 );
|
||||||
|
|
||||||
mgr->setValue("SMESH", "ScalarBarXPosition", myXSpin->value());
|
QString name = myHorizRadioBtn->isChecked() ? "scalar_bar_horizontal_%1" : "scalar_bar_vertical_%1";
|
||||||
mgr->setValue("SMESH", "ScalarBarYPosition", myYSpin->value());
|
mgr->setValue("SMESH", name.arg( "x" ), myXSpin->value());
|
||||||
mgr->setValue("SMESH", "ScalarBarWidth", myWidthSpin->value());
|
mgr->setValue("SMESH", name.arg( "y" ), myYSpin->value());
|
||||||
mgr->setValue("SMESH", "ScalarBarHeight", myHeightSpin->value());
|
mgr->setValue("SMESH", name.arg( "width" ), myWidthSpin->value());
|
||||||
|
mgr->setValue("SMESH", name.arg( "height" ), myHeightSpin->value());
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user