rnc: EDF 1618 GEOM: changed the wrning message when building an arc from endpoint and center. The message show now the value of the error too

This commit is contained in:
gdd 2011-04-29 14:54:11 +00:00
parent cfda715c5c
commit b8e5dd32fc
7 changed files with 122 additions and 87 deletions

View File

@ -134,7 +134,7 @@
<widget class="SalomeApp_DoubleSpinBox" name="SpinBox_DS"/> <widget class="SalomeApp_DoubleSpinBox" name="SpinBox_DS"/>
</item> </item>
<item row="4" column="0" colspan="3"> <item row="4" column="0" colspan="3">
<layout class="QHBoxLayout" name="horizontalLayout"> <layout class="QHBoxLayout" name="horizontalLayout" stretch="0,1,0">
<item> <item>
<widget class="QCheckBox" name="checkBox"> <widget class="QCheckBox" name="checkBox">
<property name="text"> <property name="text">
@ -149,6 +149,19 @@
</property> </property>
</widget> </widget>
</item> </item>
<item>
<spacer name="horizontalSpacer">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>40</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
</layout> </layout>
</item> </item>
</layout> </layout>

View File

@ -6,10 +6,16 @@
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>380</width> <width>390</width>
<height>236</height> <height>236</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy">
<sizepolicy hsizetype="Preferred" vsizetype="Preferred">
<horstretch>0</horstretch>
<verstretch>0</verstretch>
</sizepolicy>
</property>
<property name="windowTitle"> <property name="windowTitle">
<string>Form</string> <string>Form</string>
</property> </property>
@ -62,7 +68,7 @@
</property> </property>
<property name="sizeHint" stdset="0"> <property name="sizeHint" stdset="0">
<size> <size>
<width>30</width> <width>35</width>
<height>0</height> <height>0</height>
</size> </size>
</property> </property>

View File

@ -1964,6 +1964,13 @@ bool EntityGUI_SketcherDlg::isValid( QString& msg )
//================================================================================= //=================================================================================
bool EntityGUI_SketcherDlg::execute( ObjectList& objects ) bool EntityGUI_SketcherDlg::execute( ObjectList& objects )
{ {
SUIT_ResourceMgr* resMgr = SUIT_Session::session()->resourceMgr();
int aPrecision = resMgr->integerValue( "Geometry", "length_precision", 6 );
int DigNum = qAbs(aPrecision); // options for the format of numbers in myNewCommand
char Format = 'f';
if ( aPrecision < 0 ) // f --> DigNum is the number of digits after the decimal point
Format = 'g'; // g --> DigNum is the maximum number of significant digits
QString aParameters; QString aParameters;
if ( mySketchState == FIRST_POINT ) { if ( mySketchState == FIRST_POINT ) {
@ -1988,16 +1995,25 @@ bool EntityGUI_SketcherDlg::execute( ObjectList& objects )
Sketcher_Profile aProfile2( Command2.toAscii() ); Sketcher_Profile aProfile2( Command2.toAscii() );
//Error Message //Error Message
if ( mySketchType == PT_ABS_CENTER || if ( mySketchType == PT_ABS_CENTER || mySketchType == PT_REL_CENTER ){
mySketchType == PT_REL_CENTER ){ if (aProfile2.Error() > Precision::Confusion()){
Group4Spin->label->show(); Group4Spin->label->show();
Group4Spin->label->setText( tr( aProfile2.ErrMsg().c_str() ) ); Group4Spin->label->setText( tr("GEOM_SKETCHER_WARNING") + QString::number( aProfile2.Error(), Format, DigNum));
}
else{
Group4Spin->label->hide();
}
} }
else else
Group4Spin->label->hide(); Group4Spin->label->hide();
if ( mySketchType == PT_SEL_CENTER ){ if ( mySketchType == PT_SEL_CENTER ){
Group2Sel->label->show(); if (aProfile2.Error() > Precision::Confusion()){
Group2Sel->label->setText( tr( aProfile2.ErrMsg().c_str() ) ); Group2Sel->label->show();
Group2Sel->label->setText( tr("GEOM_SKETCHER_WARNING") + QString::number( aProfile2.Error(), Format, DigNum));
}
else{
Group2Sel->label->hide();
}
} }
else else
Group2Sel->label->hide(); Group2Sel->label->hide();

View File

@ -1563,7 +1563,7 @@ Please, select face, shell or solid and try again</translation>
</message> </message>
<message> <message>
<source>GEOM_SKETCHER_WARNING</source> <source>GEOM_SKETCHER_WARNING</source>
<translation>Warning : The specified End Point is not on the Arc</translation> <translation>Warning: End point not on the arc, distance = </translation>
</message> </message>
<message> <message>
<source>GEOM_SKETCHER_CENTER_X</source> <source>GEOM_SKETCHER_CENTER_X</source>

View File

@ -235,7 +235,7 @@ Choisissez une face, une coque ou un solide et essayez de nouveau</translation>
</message> </message>
<message> <message>
<source>GEOM_BUT_CLOSE_SKETCH</source> <source>GEOM_BUT_CLOSE_SKETCH</source>
<translation>Fermer le contour et valider</translation> <translation>Fermer le contour</translation>
</message> </message>
<message> <message>
<source>GEOM_BUT_END_SKETCH</source> <source>GEOM_BUT_END_SKETCH</source>
@ -1543,7 +1543,7 @@ Choisissez une face, une coque ou un solide et essayez de nouveau</translation>
</message> </message>
<message> <message>
<source>GEOM_SKETCHER_WARNING</source> <source>GEOM_SKETCHER_WARNING</source>
<translation>Attention : Le point final choisi n'est pas sur l'arc</translation> <translation>Attention : Point final distant de l'arc de : </translation>
</message> </message>
<message> <message>
<source>GEOM_SKETCHER_CENTER_X</source> <source>GEOM_SKETCHER_CENTER_X</source>

View File

@ -67,7 +67,6 @@ Sketcher_Profile::Sketcher_Profile()
//======================================================================= //=======================================================================
Sketcher_Profile::Sketcher_Profile(const char* aCmd) Sketcher_Profile::Sketcher_Profile(const char* aCmd)
{ {
myErrMsg = "";
enum {line, circle, point, none} move; enum {line, circle, point, none} move;
Standard_Integer i = 1; Standard_Integer i = 1;
@ -91,6 +90,7 @@ Sketcher_Profile::Sketcher_Profile(const char* aCmd)
Handle(Geom_Surface) Surface; Handle(Geom_Surface) Surface;
myOK = Standard_False; myOK = Standard_False;
myError = 0;
//TCollection_AsciiString aCommand(CORBA::string_dup(aCmd)); //TCollection_AsciiString aCommand(CORBA::string_dup(aCmd));
TCollection_AsciiString aCommand ((char*)aCmd); TCollection_AsciiString aCommand ((char*)aCmd);
@ -252,106 +252,104 @@ Sketcher_Profile::Sketcher_Profile(const char* aCmd)
case 'A': // TAngential arc by end point case 'A': // TAngential arc by end point
{ {
if (n1 != 3) goto badargs; if (n1 != 3) goto badargs;
Standard_Real vx = a(1).RealValue(); Standard_Real vx = a(1).RealValue();
Standard_Real vy = a(2).RealValue(); Standard_Real vy = a(2).RealValue();
if (a(0) == "AA") { if (a(0) == "AA") {
vx -= x; vx -= x;
vy -= y; vy -= y;
} }
Standard_Real det = dx * vy - dy * vx; Standard_Real det = dx * vy - dy * vx;
if ( Abs(det) > Precision::Confusion()) { if ( Abs(det) > Precision::Confusion()) {
Standard_Real c = (dx * vx + dy * vy) Standard_Real c = (dx * vx + dy * vy)
/ Sqrt((dx * dx + dy * dy) * (vx * vx + vy * vy)); // Cosine of alpha = arc of angle / 2 , alpha in [0,Pi] / Sqrt((dx * dx + dy * dy) * (vx * vx + vy * vy)); // Cosine of alpha = arc of angle / 2 , alpha in [0,Pi]
radius = (vx * vx + vy * vy)* Sqrt(dx * dx + dy * dy) // radius = distance between start and end point / 2 * sin(alpha) radius = (vx * vx + vy * vy)* Sqrt(dx * dx + dy * dy) // radius = distance between start and end point / 2 * sin(alpha)
/ (2.0 * det); // radius is > 0 or < 0 / (2.0 * det); // radius is > 0 or < 0
if (Abs(radius) > Precision::Confusion()) { if (Abs(radius) > Precision::Confusion()) {
angle = 2.0 * acos(c); // angle in [0,2Pi] angle = 2.0 * acos(c); // angle in [0,2Pi]
move = circle; move = circle;
} }
else else
move = none; move = none;
break; break;
} }
else else
move = none; move = none;
break; break;
} }
case 'U': // Arc by end point and radiUs case 'U': // Arc by end point and radiUs
{ {
if (n1 != 5) goto badargs; if (n1 != 5) goto badargs;
Standard_Real vx = a(1).RealValue(); Standard_Real vx = a(1).RealValue();
Standard_Real vy = a(2).RealValue(); Standard_Real vy = a(2).RealValue();
radius = a(3).RealValue(); radius = a(3).RealValue();
reversed = a(4).IntegerValue(); reversed = a(4).IntegerValue();
if (a(0) == "UU") { // Absolute if (a(0) == "UU") { // Absolute
vx -= x; vx -= x;
vy -= y; vy -= y;
} }
Standard_Real length = Sqrt(vx * vx + vy * vy); Standard_Real length = Sqrt(vx * vx + vy * vy);
if ( (4.0 - (vx * vx + vy * vy) / (radius * radius) >= 0.0 ) && (length > Precision::Confusion()) ) { if ( (4.0 - (vx * vx + vy * vy) / (radius * radius) >= 0.0 ) && (length > Precision::Confusion()) ) {
Standard_Real c = 0.5 * Sqrt(4.0 - (vx * vx + vy * vy) / (radius * radius)); // Cosine of alpha = arc angle / 2 , alpha in [0,Pi/2] Standard_Real c = 0.5 * Sqrt(4.0 - (vx * vx + vy * vy) / (radius * radius)); // Cosine of alpha = arc angle / 2 , alpha in [0,Pi/2]
angle = 2.0 * acos(c); // angle in [0,Pi] angle = 2.0 * acos(c); // angle in [0,Pi]
if ( reversed == 2 ) if ( reversed == 2 )
angle = angle - 2 * PI; angle = angle - 2 * PI;
dx = 0.5 * ( vy * 1.0/radius dx = 0.5 * ( vy * 1.0/radius
+ vx * Sqrt(4.0 / (vx * vx + vy * vy) - 1.0 / (radius * radius))); + vx * Sqrt(4.0 / (vx * vx + vy * vy) - 1.0 / (radius * radius)));
dy = - 0.5 * ( vx * 1.0/radius dy = - 0.5 * ( vx * 1.0/radius
- vy * Sqrt(4.0 / (vx * vx + vy * vy) - 1.0 / (radius * radius))); - vy * Sqrt(4.0 / (vx * vx + vy * vy) - 1.0 / (radius * radius)));
move = circle; move = circle;
} }
else{ else{
move = none; move = none;
} }
break; break;
} }
case 'E': // Arc by end point and cEnter case 'E': // Arc by end point and cEnter
{ {
myErrMsg = ""; if (n1 != 7) goto badargs;
if (n1 != 7) goto badargs; Standard_Real vx = a(1).RealValue();
Standard_Real vx = a(1).RealValue();
Standard_Real vy = a(2).RealValue(); Standard_Real vy = a(2).RealValue();
Standard_Real vxc = a(3).RealValue(); Standard_Real vxc = a(3).RealValue();
Standard_Real vyc = a(4).RealValue(); Standard_Real vyc = a(4).RealValue();
reversed = a(5).IntegerValue(); reversed = a(5).IntegerValue();
control_Tolerance = a(6).IntegerValue(); control_Tolerance = a(6).IntegerValue();
if (a(0) == "EE") { // Absolute if (a(0) == "EE") { // Absolute
vx -= x; vx -= x;
vy -= y; vy -= y;
vxc -= x; vxc -= x;
vyc -= y; vyc -= y;
} }
radius = Sqrt( vxc * vxc + vyc * vyc ); radius = Sqrt( vxc * vxc + vyc * vyc );
Standard_Real det = vx * vyc - vy * vxc; Standard_Real det = vx * vyc - vy * vxc;
Standard_Real length = Sqrt(vx * vx + vy * vy); Standard_Real length = Sqrt(vx * vx + vy * vy);
Standard_Real length2 = Sqrt((vx-vxc) * (vx-vxc) + (vy-vyc) * (vy-vyc)); Standard_Real length2 = Sqrt((vx-vxc) * (vx-vxc) + (vy-vyc) * (vy-vyc));
Standard_Real length3 = Sqrt(vxc * vxc + vyc * vyc); Standard_Real length3 = Sqrt(vxc * vxc + vyc * vyc);
Standard_Real error = Abs(length2 - radius); Standard_Real error = Abs(length2 - radius);
if ( error > Precision::Confusion() ){ myError = error;
MESSAGE("Warning : The specified end point is not on the Arc, distance = "<<error); if ( error > Precision::Confusion() ){
myErrMsg = "GEOM_SKETCHER_WARNING";//"Warning : The specified End Point is not on the Arc"; MESSAGE("Warning : The specified end point is not on the Arc, distance = "<<error);
} }
if ( error > Precision::Confusion() && // Don't create the arc if the end point if ( error > Precision::Confusion() && control_Tolerance == 1) // Don't create the arc if the end point
control_Tolerance == 1) // is too far from it move = none; // is too far from it
move = none; else if ( (length > Precision::Confusion()) &&
else if ( (length > Precision::Confusion()) && (length2 > Precision::Confusion()) &&
(length2 > Precision::Confusion()) && (length3 > Precision::Confusion()) ) {
(length3 > Precision::Confusion()) ) { Standard_Real c = ( radius * radius - (vx * vxc + vy * vyc) )
Standard_Real c = ( radius * radius - (vx * vxc + vy * vyc) ) / ( radius * Sqrt((vx-vxc) * (vx-vxc) + (vy-vyc) * (vy-vyc)) ) ; // Cosine of arc angle
/ ( radius * Sqrt((vx-vxc) * (vx-vxc) + (vy-vyc) * (vy-vyc)) ) ; // Cosine of arc angle angle = acos(c); // angle in [0,Pi]
angle = acos(c); // angle in [0,Pi] if ( reversed == 2 )
if ( reversed == 2 ) angle = angle - 2 * PI;
angle = angle - 2 * PI; if (det < 0)
if (det < 0) angle = -angle;
angle = -angle; dx = vyc / radius;
dx = vyc / radius; dy = -vxc / radius;
dy = -vxc / radius; move = circle;
move = circle; }
} else {
else { move = none;
move = none; }
} break;
break;
} }
case 'I': case 'I':
{ {

View File

@ -45,6 +45,7 @@ private:
TopoDS_Shape myShape; TopoDS_Shape myShape;
bool myOK; bool myOK;
std::string myErrMsg; std::string myErrMsg;
double myError;
public: public:
Standard_EXPORT gp_Pnt GetLastPoint(){return myLastPoint;}; Standard_EXPORT gp_Pnt GetLastPoint(){return myLastPoint;};
@ -53,5 +54,6 @@ public:
Standard_EXPORT const TopoDS_Shape& GetShape(){return myShape;}; Standard_EXPORT const TopoDS_Shape& GetShape(){return myShape;};
Standard_EXPORT bool IsDone(){return myOK;}; Standard_EXPORT bool IsDone(){return myOK;};
Standard_EXPORT std::string ErrMsg(){return myErrMsg;}; Standard_EXPORT std::string ErrMsg(){return myErrMsg;};
Standard_EXPORT double Error(){return myError;};
}; };