mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 02:00:34 +05:00
0020104: EDF 861 SMESH : Mesh element info evolution
This commit is contained in:
parent
efc89ab066
commit
adc76cf234
@ -136,7 +136,7 @@ SMESHGUI_WhatIsDlg::SMESHGUI_WhatIsDlg( SMESHGUI* theModule )
|
|||||||
|
|
||||||
// information text browser
|
// information text browser
|
||||||
Info = new QTextBrowser(GroupArguments);
|
Info = new QTextBrowser(GroupArguments);
|
||||||
Info->setMinimumSize(200, 150);
|
Info->setMinimumSize(300, 200);
|
||||||
GroupArgumentsLayout->addWidget(Info, 1, 0, 1, 2);
|
GroupArgumentsLayout->addWidget(Info, 1, 0, 1, 2);
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
@ -439,19 +439,19 @@ void SMESHGUI_WhatIsDlg::SelectionIntoArgument()
|
|||||||
myActor->GetObject()->GetMesh()->FindElement(aString.toInt());
|
myActor->GetObject()->GetMesh()->FindElement(aString.toInt());
|
||||||
if (e) {
|
if (e) {
|
||||||
QString anInfo;
|
QString anInfo;
|
||||||
anInfo=tr("ENTITY_TYPE") + ": ";
|
anInfo="<b>" + tr("ENTITY_TYPE") + ":</b> ";
|
||||||
if(e->GetType() == SMDSAbs_Node) {
|
if(e->GetType() == SMDSAbs_Node) {
|
||||||
anInfo+=tr("MESH_NODE")+"\n";
|
anInfo+=tr("MESH_NODE")+"<br>";
|
||||||
//const SMDS_MeshNode *en = (SMDS_MeshNode*) e; // VSR: not used!
|
//const SMDS_MeshNode *en = (SMDS_MeshNode*) e; // VSR: not used!
|
||||||
} else if(e->GetType() == SMDSAbs_Edge) {
|
} else if(e->GetType() == SMDSAbs_Edge) {
|
||||||
anInfo+=tr("SMESH_EDGE")+"\n";
|
anInfo+=tr("SMESH_EDGE")+"<br>";
|
||||||
anInfo+=tr("SMESH_MESHINFO_TYPE")+": ";
|
anInfo+="<b>" + tr("SMESH_MESHINFO_TYPE")+":</b> ";
|
||||||
const SMDS_MeshEdge *ee = (SMDS_MeshEdge*) e;
|
const SMDS_MeshEdge *ee = (SMDS_MeshEdge*) e;
|
||||||
anInfo+=(ee->IsQuadratic()?tr("SMESH_MESHINFO_ORDER2"):tr("SMESH_MESHINFO_ORDER1"))+"\n";
|
anInfo+=(ee->IsQuadratic()?tr("SMESH_MESHINFO_ORDER2"):tr("SMESH_MESHINFO_ORDER1"))+"<br>";
|
||||||
} else if(e->GetType() == SMDSAbs_Face) {
|
} else if(e->GetType() == SMDSAbs_Face) {
|
||||||
const SMDS_MeshFace *ef = (SMDS_MeshFace*) e;
|
const SMDS_MeshFace *ef = (SMDS_MeshFace*) e;
|
||||||
anInfo+=tr("SMESH_FACE")+"\n";
|
anInfo+=tr("SMESH_FACE")+"<br>";
|
||||||
anInfo+=tr("SMESH_MESHINFO_TYPE")+": ";
|
anInfo+="<b>" + tr("SMESH_MESHINFO_TYPE")+":</b> ";
|
||||||
if(!ef->IsPoly())
|
if(!ef->IsPoly())
|
||||||
anInfo+=(ef->IsQuadratic()?tr("SMESH_MESHINFO_ORDER2"):tr("SMESH_MESHINFO_ORDER1"))+" ";
|
anInfo+=(ef->IsQuadratic()?tr("SMESH_MESHINFO_ORDER2"):tr("SMESH_MESHINFO_ORDER1"))+" ";
|
||||||
switch(ef->NbNodes()) {
|
switch(ef->NbNodes()) {
|
||||||
@ -470,10 +470,10 @@ void SMESHGUI_WhatIsDlg::SelectionIntoArgument()
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
anInfo+="\n";
|
anInfo+="<br>";
|
||||||
} else if(e->GetType() == SMDSAbs_Volume) {
|
} else if(e->GetType() == SMDSAbs_Volume) {
|
||||||
anInfo+=tr("SMESH_VOLUME")+"\n";
|
anInfo+=tr("SMESH_VOLUME")+"<br>";
|
||||||
anInfo+=tr("SMESH_MESHINFO_TYPE")+": ";
|
anInfo+="<b>" + tr("SMESH_MESHINFO_TYPE")+":</b> ";
|
||||||
const SMDS_MeshVolume *ev = (SMDS_MeshVolume*) e;
|
const SMDS_MeshVolume *ev = (SMDS_MeshVolume*) e;
|
||||||
SMDS_VolumeTool vt(ev);
|
SMDS_VolumeTool vt(ev);
|
||||||
if(vt.GetVolumeType() != SMDS_VolumeTool::POLYHEDA)
|
if(vt.GetVolumeType() != SMDS_VolumeTool::POLYHEDA)
|
||||||
@ -511,19 +511,37 @@ void SMESHGUI_WhatIsDlg::SelectionIntoArgument()
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
anInfo+="\n";
|
anInfo+="<br>";
|
||||||
}
|
}
|
||||||
if(e->GetType() != SMDSAbs_Node)
|
|
||||||
anInfo+=tr("GRAVITY_CENTER") + ":\n";
|
|
||||||
gp_XYZ anXYZ(0.,0.,0.);
|
gp_XYZ anXYZ(0.,0.,0.);
|
||||||
SMDS_ElemIteratorPtr nodeIt = e->nodesIterator();
|
SMDS_ElemIteratorPtr nodeIt = e->nodesIterator();
|
||||||
int nbNodes = 0;
|
int nbNodes = 0;
|
||||||
|
QString aNodesInfo="";
|
||||||
for( ; nodeIt->more(); nbNodes++) {
|
for( ; nodeIt->more(); nbNodes++) {
|
||||||
const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( nodeIt->next() );
|
const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( nodeIt->next() );
|
||||||
anXYZ.Add( gp_XYZ( node->X(), node->Y(), node->Z() ) );
|
anXYZ.Add( gp_XYZ( node->X(), node->Y(), node->Z() ) );
|
||||||
|
if(e->GetType() != SMDSAbs_Node)
|
||||||
|
aNodesInfo+=QString("<b>Node %1:</b><br>Id=%2, X=%3, Y=%4, Z=%5<br>").arg(nbNodes+1).arg(node->GetID()).arg(node->X()).arg(node->Y()).arg(node->Z());
|
||||||
|
// Calculate Connectivity
|
||||||
|
SMDS_ElemIteratorPtr it = node->GetInverseElementIterator();
|
||||||
|
if (it) {
|
||||||
|
aNodesInfo+="<b>" + tr("CONNECTED_ELEMENTS") + ":</b>";
|
||||||
|
while (it->more()) {
|
||||||
|
const SMDS_MeshElement* elem = it->next();
|
||||||
|
aNodesInfo+=QString(" %1").arg(elem->GetID());
|
||||||
|
}
|
||||||
|
if ( (nbNodes+1) != e->NbNodes())
|
||||||
|
aNodesInfo+=QString("<br><br>");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
if(e->GetType() != SMDSAbs_Node)
|
||||||
|
anInfo+="<b>" + tr("GRAVITY_CENTER") + ":</b><br>";
|
||||||
anXYZ.Divide(e->NbNodes());
|
anXYZ.Divide(e->NbNodes());
|
||||||
anInfo+=QString("X=%1\nY=%2\nZ=%3\n").arg(anXYZ.X()).arg(anXYZ.Y()).arg(anXYZ.Z());
|
anInfo+=QString("X=%1, Y=%2, Z=%3").arg(anXYZ.X()).arg(anXYZ.Y()).arg(anXYZ.Z());
|
||||||
|
if(e->GetType() != SMDSAbs_Node)
|
||||||
|
anInfo+="<br>";
|
||||||
|
if (aNodesInfo!="")
|
||||||
|
anInfo+= "<br>" + aNodesInfo;
|
||||||
Info->setText(anInfo);
|
Info->setText(anInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4698,6 +4698,10 @@ It is impossible to read point coordinates from file</translation>
|
|||||||
<source>GRAVITY_CENTER</source>
|
<source>GRAVITY_CENTER</source>
|
||||||
<translation>Gravity center</translation>
|
<translation>Gravity center</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>CONNECTED_ELEMENTS</source>
|
||||||
|
<translation>Connected With Elements</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_FileInfoDlg</name>
|
<name>SMESHGUI_FileInfoDlg</name>
|
||||||
|
Loading…
Reference in New Issue
Block a user