mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-28 03:30:33 +05:00
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:
parent
cfda715c5c
commit
b8e5dd32fc
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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();
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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':
|
||||||
{
|
{
|
||||||
|
@ -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;};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user