mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 10:10:33 +05:00
Fixes for:
- Bug IPAL8767: Polyhedron created on nodes is invisible - Id of the first node/face should be appeared in the field right after selection - Preview of faces by nodes for polyhedron doesnâÂÂt disappear after removing it from list in the "Create Polyhedral Volume" dialog box. - Preview of polyhedron doesnâÂÂt disappear after removing a face from list in the "Create Polyhedral Volume" dialog box.
This commit is contained in:
parent
d72c027376
commit
8d1d443243
@ -151,11 +151,15 @@ class TPolySimulation{
|
|||||||
anIds->InsertId(i,theIds[i]);
|
anIds->InsertId(i,theIds[i]);
|
||||||
|
|
||||||
myGrid->InsertNextCell(theType,anIds);
|
myGrid->InsertNextCell(theType,anIds);
|
||||||
|
if(theIds.size()!=0){
|
||||||
|
myGrid->InsertNextCell(theType,anIds);
|
||||||
|
myGrid->Modified();
|
||||||
|
}
|
||||||
|
|
||||||
anIds->Delete();
|
anIds->Delete();
|
||||||
|
|
||||||
myGrid->Modified();
|
|
||||||
|
|
||||||
SetVisibility(true);
|
SetVisibility(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResetGrid(bool theReset=true){
|
void ResetGrid(bool theReset=true){
|
||||||
@ -382,7 +386,7 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::Init()
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void SMESHGUI_CreatePolyhedralVolumeDlg::ConstructorsClicked(int constructorId)
|
void SMESHGUI_CreatePolyhedralVolumeDlg::ConstructorsClicked(int constructorId)
|
||||||
{
|
{
|
||||||
disconnect(mySelectionMgr, 0, this, 0);
|
//disconnect(mySelectionMgr, 0, this, 0);
|
||||||
|
|
||||||
SALOME_ListIO aList;
|
SALOME_ListIO aList;
|
||||||
mySelectionMgr->setSelectedObjects( aList );
|
mySelectionMgr->setSelectedObjects( aList );
|
||||||
@ -398,6 +402,8 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ConstructorsClicked(int constructorId)
|
|||||||
{
|
{
|
||||||
if ( myActor ){
|
if ( myActor ){
|
||||||
myActor->SetPointRepresentation(true);
|
myActor->SetPointRepresentation(true);
|
||||||
|
myActor->SetEntityMode(SMESH_Actor::eVolumes);
|
||||||
|
myActor->SetRepresentation(SMESH_Actor::eSurface);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
SMESH::SetPointRepresentation(true);
|
SMESH::SetPointRepresentation(true);
|
||||||
@ -416,7 +422,14 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ConstructorsClicked(int constructorId)
|
|||||||
}
|
}
|
||||||
case 1 :
|
case 1 :
|
||||||
{
|
{
|
||||||
|
if( myActor ){
|
||||||
|
myActor->SetPointRepresentation(false);
|
||||||
|
myActor->SetEntityMode(SMESH_Actor::eFaces);
|
||||||
|
myActor->SetEntityMode(SMESH_Actor::eVolumes);
|
||||||
|
myActor->SetRepresentation(SMESH_Actor::eSurface);
|
||||||
|
} else {
|
||||||
SMESH::SetPointRepresentation(false);
|
SMESH::SetPointRepresentation(false);
|
||||||
|
}
|
||||||
myViewWindow->SetSelectionMode(FaceSelection);
|
myViewWindow->SetSelectionMode(FaceSelection);
|
||||||
|
|
||||||
TextLabelIds->setText( tr( "SMESH_ID_FACES" ) );
|
TextLabelIds->setText( tr( "SMESH_ID_FACES" ) );
|
||||||
@ -429,7 +442,7 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ConstructorsClicked(int constructorId)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
connect(mySelectionMgr, SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
|
//connect(mySelectionMgr, SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -581,10 +594,6 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onTextChange(const QString& theNewText)
|
|||||||
for ( int i = 0; i < aListId.count(); i++ ) {
|
for ( int i = 0; i < aListId.count(); i++ ) {
|
||||||
const SMDS_MeshNode * n = aMesh->FindNode( aListId[ i ].toInt() );
|
const SMDS_MeshNode * n = aMesh->FindNode( aListId[ i ].toInt() );
|
||||||
if ( n ) {
|
if ( n ) {
|
||||||
/*if ( mySelectionMgr->IsIndexSelected( myActor->getIO(), n->GetID() ))
|
|
||||||
allOk = false;
|
|
||||||
else
|
|
||||||
mySelectionMgr->AddOrRemoveIndex (myActor->getIO(), n->GetID(), true);*/
|
|
||||||
if (selectedIndices.Add(n->GetID()))
|
if (selectedIndices.Add(n->GetID()))
|
||||||
newIndices.Add(n->GetID());
|
newIndices.Add(n->GetID());
|
||||||
myNbOkElements++;
|
myNbOkElements++;
|
||||||
@ -596,22 +605,14 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onTextChange(const QString& theNewText)
|
|||||||
myViewWindow->highlight( myActor->getIO(), true, true );
|
myViewWindow->highlight( myActor->getIO(), true, true );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* bool aNodesOK = false;
|
|
||||||
if (aListId.count() >= 3)
|
|
||||||
aNodesOK = true;
|
|
||||||
|
|
||||||
allOk = (allOk && aNodesOK);*/
|
|
||||||
|
|
||||||
if ( myNbOkElements>0 && aListId.count()>=3)
|
if ( myNbOkElements>0 && aListId.count()>=3)
|
||||||
AddButton->setEnabled(true);
|
AddButton->setEnabled(true);
|
||||||
else
|
else
|
||||||
AddButton->setEnabled(false);
|
AddButton->setEnabled(false);
|
||||||
|
|
||||||
// if (allOk && !myOkElements)
|
|
||||||
displaySimulation();
|
displaySimulation();
|
||||||
}
|
}
|
||||||
}
|
} else if (GetConstructorId() == 1)
|
||||||
else if (GetConstructorId() == 1)
|
|
||||||
{
|
{
|
||||||
myNbOkElements = 0;
|
myNbOkElements = 0;
|
||||||
buttonOk->setEnabled( false );
|
buttonOk->setEnabled( false );
|
||||||
@ -632,10 +633,6 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onTextChange(const QString& theNewText)
|
|||||||
for ( int i = 0; i < aListId.count(); i++ ) {
|
for ( int i = 0; i < aListId.count(); i++ ) {
|
||||||
const SMDS_MeshElement * e = aMesh->FindElement( aListId[ i ].toInt() );
|
const SMDS_MeshElement * e = aMesh->FindElement( aListId[ i ].toInt() );
|
||||||
if ( e ) {
|
if ( e ) {
|
||||||
/*if ( mySelectionMgr->IsIndexSelected( myActor->getIO(), e->GetID() ))
|
|
||||||
myOkElements = false;
|
|
||||||
else
|
|
||||||
mySelectionMgr->AddOrRemoveIndex (myActor->getIO(), e->GetID(), true);*/
|
|
||||||
if (selectedIndices.Add(e->GetID()))
|
if (selectedIndices.Add(e->GetID()))
|
||||||
newIndices.Add(e->GetID());
|
newIndices.Add(e->GetID());
|
||||||
myNbOkElements++;
|
myNbOkElements++;
|
||||||
@ -715,8 +712,9 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::SelectionIntoArgument()
|
|||||||
int anbNodes = SMESH::GetNameOfSelectedNodes(mySelector, myActor->getIO(), aString);
|
int anbNodes = SMESH::GetNameOfSelectedNodes(mySelector, myActor->getIO(), aString);
|
||||||
if (anbNodes >= 3)
|
if (anbNodes >= 3)
|
||||||
AddButton->setEnabled(true);
|
AddButton->setEnabled(true);
|
||||||
else
|
else if (anbNodes < 3){
|
||||||
break;
|
AddButton->setEnabled(false);
|
||||||
|
}
|
||||||
busy = true;
|
busy = true;
|
||||||
myEditCurrentArgument->setText( aString );
|
myEditCurrentArgument->setText( aString );
|
||||||
busy = false;
|
busy = false;
|
||||||
@ -725,16 +723,19 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::SelectionIntoArgument()
|
|||||||
case 1:{
|
case 1:{
|
||||||
// get selected faces
|
// get selected faces
|
||||||
int aNbFaces = SMESH::GetNameOfSelectedElements(mySelector, myActor->getIO(), aString);
|
int aNbFaces = SMESH::GetNameOfSelectedElements(mySelector, myActor->getIO(), aString);
|
||||||
if (aNbFaces<=1)
|
if (aNbFaces<=1){
|
||||||
return;
|
buttonOk->setEnabled( false );
|
||||||
|
buttonApply->setEnabled( false );
|
||||||
|
} else {
|
||||||
|
buttonOk->setEnabled( true );
|
||||||
|
buttonApply->setEnabled( true );
|
||||||
|
}
|
||||||
busy = true;
|
busy = true;
|
||||||
myEditCurrentArgument->setText( aString );
|
myEditCurrentArgument->setText( aString );
|
||||||
busy = false;
|
busy = false;
|
||||||
|
|
||||||
// OK
|
// OK
|
||||||
myNbOkElements = 1;
|
myNbOkElements = 1;
|
||||||
buttonOk->setEnabled( true );
|
|
||||||
buttonApply->setEnabled( true );
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default: return;
|
default: return;
|
||||||
@ -772,6 +773,11 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::displaySimulation()
|
|||||||
mySimulation->SetPosition(myActor, aType, aVTKIds_faces,false);
|
mySimulation->SetPosition(myActor, aType, aVTKIds_faces,false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(myFacesByNodes->count() == 0){
|
||||||
|
mySimulation->SetVisibility(false);
|
||||||
|
} else {
|
||||||
|
mySimulation->SetVisibility(true);
|
||||||
|
}
|
||||||
if(Preview->isChecked()){
|
if(Preview->isChecked()){
|
||||||
mySimulation->SetPosition(myActor, aType, aVTKIds);
|
mySimulation->SetPosition(myActor, aType, aVTKIds);
|
||||||
}
|
}
|
||||||
@ -818,6 +824,7 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::displaySimulation()
|
|||||||
mySimulation->SetPosition(myActor, aType, aVTKIds);
|
mySimulation->SetPosition(myActor, aType, aVTKIds);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
SMESH::UpdateView();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -937,7 +944,6 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onAdd()
|
|||||||
myNbOkElements = 1;
|
myNbOkElements = 1;
|
||||||
myEditCurrentArgument->clear();
|
myEditCurrentArgument->clear();
|
||||||
AddButton->setEnabled(false);
|
AddButton->setEnabled(false);
|
||||||
RemoveButton->setEnabled(true);
|
|
||||||
buttonOk->setEnabled( true );
|
buttonOk->setEnabled( true );
|
||||||
if(myFacesByNodes->count()>1) buttonApply->setEnabled( true );
|
if(myFacesByNodes->count()>1) buttonApply->setEnabled( true );
|
||||||
}
|
}
|
||||||
@ -956,22 +962,20 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onRemove()
|
|||||||
for (int i = myFacesByNodes->count(); i > 0; i--) {
|
for (int i = myFacesByNodes->count(); i > 0; i--) {
|
||||||
if (myFacesByNodes->isSelected(i-1)) {
|
if (myFacesByNodes->isSelected(i-1)) {
|
||||||
myFacesByNodes->removeItem(i-1);
|
myFacesByNodes->removeItem(i-1);
|
||||||
|
myNbOkElements = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (myFacesByNodes->count() < 1){
|
if (myFacesByNodes->count() < 1){
|
||||||
myNbOkElements = 0;
|
|
||||||
RemoveButton->setEnabled(false);
|
RemoveButton->setEnabled(false);
|
||||||
buttonOk->setEnabled( false );
|
buttonOk->setEnabled( false );
|
||||||
buttonApply->setEnabled( false );
|
buttonApply->setEnabled( false );
|
||||||
}
|
}
|
||||||
else if (myFacesByNodes->count() == 1){
|
else if (myFacesByNodes->count() == 1){
|
||||||
myNbOkElements = 0;
|
|
||||||
buttonOk->setEnabled( false );
|
buttonOk->setEnabled( false );
|
||||||
buttonApply->setEnabled( false );
|
buttonApply->setEnabled( false );
|
||||||
}
|
}
|
||||||
displaySimulation();
|
|
||||||
busy = false;
|
busy = false;
|
||||||
onListSelectionChanged();
|
displaySimulation();
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -982,22 +986,26 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::onListSelectionChanged()
|
|||||||
{
|
{
|
||||||
if (busy || !myActor) return;
|
if (busy || !myActor) return;
|
||||||
busy = true;
|
busy = true;
|
||||||
|
bool isSelected=false;
|
||||||
SALOME_ListIO list;
|
SALOME_ListIO aList;
|
||||||
mySelectionMgr->setSelectedObjects( list );
|
mySelectionMgr->setSelectedObjects( aList );
|
||||||
TColStd_MapOfInteger aIndexes;
|
TColStd_MapOfInteger aIndexes;
|
||||||
QListBoxItem* anItem;
|
QListBoxItem* anItem;
|
||||||
for (anItem = myFacesByNodes->firstItem(); anItem != 0; anItem = anItem->next()) {
|
for (anItem = myFacesByNodes->firstItem(); anItem != 0; anItem = anItem->next()) {
|
||||||
if (anItem->isSelected()) {
|
if (anItem->isSelected()) {
|
||||||
|
isSelected = true;
|
||||||
QStringList anIds = QStringList::split(" ", anItem->text());
|
QStringList anIds = QStringList::split(" ", anItem->text());
|
||||||
for (QStringList::iterator it = anIds.begin(); it != anIds.end(); ++it)
|
for (QStringList::iterator it = anIds.begin(); it != anIds.end(); ++it)
|
||||||
aIndexes.Add((*it).toInt());
|
aIndexes.Add((*it).toInt());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(isSelected) RemoveButton->setEnabled(true);
|
||||||
|
else RemoveButton->setEnabled(false);
|
||||||
mySelector->AddOrRemoveIndex(myActor->getIO(), aIndexes, true );
|
mySelector->AddOrRemoveIndex(myActor->getIO(), aIndexes, true );
|
||||||
myViewWindow->highlight( myActor->getIO(), true, true );
|
myViewWindow->highlight( myActor->getIO(), true, true );
|
||||||
list.Append( myActor->getIO() );
|
mySelectionMgr->clearFilters();
|
||||||
mySelectionMgr->setSelectedObjects( list );
|
aList.Append( myActor->getIO() );
|
||||||
|
mySelectionMgr->setSelectedObjects( aList );
|
||||||
|
|
||||||
busy = false;
|
busy = false;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user