ExtractContour(lstOutX,lstOutY,lstOutZ,lstIndexsOut, iContour+1 , &lstTmp3X,&lstTmp3Y,&lstTmp3Z);
// sizeContour2 = SizeContour( &lstTmp2X, &lstTmp2Y, &lstTmp2Z );
sizeContour2 = lstSizeContours[ iContour ];
- printf("EED Warnning! ManualContourModel_Box::RedistributionPointsAllContours_SIN wave3 posible inconsistent contour y=%f iContour=%d\n", lstTmp2Y[0], iContour );
+ printf("EED Warnning! ManualContourModel_Box::RedistributionPointsAllContours_SIN wave3 possible inconsistent contour y=%f iContour=%d\n", lstTmp2Y[0], iContour );
lstInconsistentContourY.push_back( lstTmp2Y[0] );
lstInconsistentContourID.push_back( iContour );
findAlphaBetaSinDistribution( &lstTmp2X,&lstTmp2Y,&lstTmp2Z ,sizeContour2, &lstTmp1X,&lstTmp1Y,&lstTmp1Z, &alpha1,&beta1);
}// IsEditable
// move contour
- if ((GetState()==0) && (GetManualViewBaseContour()->GetPosibleSelected()==true)) {
+ if ((GetState()==0) && (GetManualViewBaseContour()->GetPossibleSelected()==true)) {
GetManualViewBaseContour()->InitMove(x,y,z);
SetState(6);
}
int z=GetZ();
// this->_vtkInteractorStyleBaseView->
- GetManualViewBaseContour()->SelectPosibleContour(x,y,z);
- GetManualViewBaseContour()->SelectPosiblePoint(x,y,z);
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,z);
+ GetManualViewBaseContour()->SelectPossiblePoint(x,y,z);
if (GetState()==1){ SetPoint( bakIdPoint , x , y ,z); }
if (GetState()==5){ SetPoint( bakIdPoint , x , y ,z); }
mvbc->SelectAllPossibleSelected(false);
if (id!=-1)
{
- mvbc->SetPointPosibleSelected(id,true);
+ mvbc->SetPointPossibleSelected(id,true);
}
- mvbc->SetPosibleSelected ( GetManualViewBaseContour()->GetPosibleSelected() );
+ mvbc->SetPossibleSelected ( GetManualViewBaseContour()->GetPossibleSelected() );
mvbc->Refresh();
}
_manViewBaseCont2->SelectAllPossibleSelected(false);
_manViewBaseCont3->SelectAllPossibleSelected(false);
if (id!=-1){
- _manViewBaseCont1->SetPointPosibleSelected(id,true);
- _manViewBaseCont2->SetPointPosibleSelected(id,true);
- _manViewBaseCont3->SetPointPosibleSelected(id,true);
+ _manViewBaseCont1->SetPointPossibleSelected(id,true);
+ _manViewBaseCont2->SetPointPossibleSelected(id,true);
+ _manViewBaseCont3->SetPointPossibleSelected(id,true);
}
- _manViewBaseCont1->SetPosibleSelected ( GetManualViewBaseContour()->GetPosibleSelected() );
- _manViewBaseCont2->SetPosibleSelected ( GetManualViewBaseContour()->GetPosibleSelected() );
- _manViewBaseCont3->SetPosibleSelected ( GetManualViewBaseContour()->GetPosibleSelected() );
+ _manViewBaseCont1->SetPossibleSelected ( GetManualViewBaseContour()->GetPossibleSelected() );
+ _manViewBaseCont2->SetPossibleSelected ( GetManualViewBaseContour()->GetPossibleSelected() );
+ _manViewBaseCont3->SetPossibleSelected ( GetManualViewBaseContour()->GetPossibleSelected() );
_manViewBaseCont1->Refresh();
_manViewBaseCont2->Refresh();
_z = -900;
_editable = true;
- _posibleToMove = true;
+ _possibleToMove = true;
_moving = false;
_created = false;
_keyBoardMoving = false;
cloneObject->SetZ( this->GetZ() );
cloneObject->SetState( this->GetState() );
cloneObject->SetEditable( this->IsEditable() );
- cloneObject->SetPosibleToMove( this->GetPosibleToMove() );
+ cloneObject->SetPossibleToMove( this->GetPossibleToMove() );
cloneObject->SetMoving( this->IsMoving() );
cloneObject->SetCompleteCreation( this->GetIfCompleteCreation() );
cloneObject->SetKeyBoardMoving( this->GetKeyBoardMoving() );
// Delete Point
if ((keyCode==8) || (keyCode==127))
{
- if ( (GetState()==0) && (!GetManualViewBaseContour()->GetPosibleSelected()==true))
+ if ( (GetState()==0) && (!GetManualViewBaseContour()->GetPossibleSelected()==true))
{
DeleteActualMousePoint(X,Y);
}
// _state=0;
// }
SetEditable( false );
- SetPosibleToMove( false );
+ SetPossibleToMove( false );
_state = 0;
//EED 24Avril2009 _state=7;
}
if ((_state!=7) && (_state!=8))
{
SetMoving( false );
- GetManualViewBaseContour()->SelectPosibleContour(x,y,GetZ());
- if( GetIfCompleteCreation() && IsEditable() && !GetManualViewBaseContour()->GetPosibleSelected() && (GetManualViewBaseContour()->GetIdPoint(x,y,GetZ())==-1) )
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,GetZ());
+ if( GetIfCompleteCreation() && IsEditable() && !GetManualViewBaseContour()->GetPossibleSelected() && (GetManualViewBaseContour()->GetIdPoint(x,y,GetZ())==-1) )
{
SetEditable( false );
- SetPosibleToMove( false );
+ SetPossibleToMove( false );
}
} else {
_state = 0;
if (_state==0)
{
int z=GetZ();
- /*bool temp = */ _manViewBaseCont->SelectPosibleContour(x,y,z);
- _manViewBaseCont->SelectPosiblePoint(x,y,z);
- if ( _manViewBaseCont->GetPosibleSelected() )
+ /*bool temp = */ _manViewBaseCont->SelectPossibleContour(x,y,z);
+ _manViewBaseCont->SelectPossiblePoint(x,y,z);
+ if ( _manViewBaseCont->GetPossibleSelected() )
{
_editable = true;
}
}
// ----------------------------------------------------------------------------
-bool manualContourBaseControler::GetPosibleToMove()
+bool manualContourBaseControler::GetPossibleToMove()
{
- return _posibleToMove;
+ return _possibleToMove;
}
// ----------------------------------------------------------------------------
-void manualContourBaseControler::SetPosibleToMove( bool condition )
+void manualContourBaseControler::SetPossibleToMove( bool condition )
{
- _posibleToMove = condition;
+ _possibleToMove = condition;
}
// ----------------------------------------------------------------------------
int GetState();
bool IsEditable();
virtual void SetEditable( bool condition );
- bool GetPosibleToMove();
- void SetPosibleToMove( bool condition );
+ bool GetPossibleToMove();
+ void SetPossibleToMove( bool condition );
bool IsMoving();
void SetMoving( bool condition );
void SetCompleteCreation( bool condition );
int _z;
int _state;
bool _editable;
- bool _posibleToMove;
+ bool _possibleToMove;
bool _moving;
bool _created;
bool _keyBoardMoving;
// Insert a Control Point with shift+ClickLeft
vtkRenderWindowInteractor *vtkrenderwindowinteractor = _vtkInteractorStyleBaseView->GetInteractor();
-
- int ps = GetManualViewBaseContour()->GetPosibleSelected();
if( IsEditable() )
{
// Insert Point with shift + click
- if ( (_vtkInteractorStyleBaseView!=NULL) && (GetState()==0) && ( (vtkrenderwindowinteractor!=NULL) && (vtkrenderwindowinteractor->GetShiftKey()==1) ) && (GetManualViewBaseContour()->GetPosibleSelected()==false) && (GetManualViewBaseContour()->GetIdPoint(x,y,z)==-1) )
+ if ( (_vtkInteractorStyleBaseView!=NULL) && (GetState()==0) && ( (vtkrenderwindowinteractor!=NULL) && (vtkrenderwindowinteractor->GetShiftKey()==1) ) && (GetManualViewBaseContour()->GetPossibleSelected()==false) && (GetManualViewBaseContour()->GetIdPoint(x,y,z)==-1) )
{
ok=true;
InsertPoint(x,y,z);
}
// Insert Control Points IF Contour is Selected
- if ((GetState()==0) && GetManualViewBaseContour()->GetPosibleSelected() && (vtkrenderwindowinteractor->GetShiftKey()==0) )
+ if ((GetState()==0) && GetManualViewBaseContour()->GetPossibleSelected() && (vtkrenderwindowinteractor->GetShiftKey()==0) )
{
ok=true;
InsertPoint(x,y,z);
} // point selected
}
}else{
- SetPosibleToMove( true );
- GetManualViewBaseContour()->SetSelected( GetManualViewBaseContour()->GetPosibleSelected() );
+ SetPossibleToMove( true );
+ GetManualViewBaseContour()->SetSelected( GetManualViewBaseContour()->GetPossibleSelected() );
} // IsEditable
- if ( GetState() == 0 && GetManualViewBaseContour()->GetPosibleSelected() )
+ if ( GetState() == 0 && GetManualViewBaseContour()->GetPossibleSelected() )
{
SetMoving( true );
ok=true;
int shiftKey = _vtkInteractorStyleBaseView->GetInteractor()->GetShiftKey();
if (shiftKey==0)
{
- GetManualViewBaseContour()->SelectPosiblePoint(x,y,z);
+ GetManualViewBaseContour()->SelectPossiblePoint(x,y,z);
}
- GetManualViewBaseContour()->SelectPosibleContour(x,y,z);
+
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,z);
if (GetState()==1)
{
SetPoint( _bakIdPoint , x , y ,z);
}
if (GetState()==5){ SetPoint( _bakIdPoint , x , y ,z); }
if (GetState()==9){ GetManualViewBaseContour()->SetNewPositionGroupSelectedPoints( x,y,z ); }
- if ( GetState()==6 && !IsEditable() && GetPosibleToMove() &&IsMoving() )
+ if ( GetState()==6 && !IsEditable() && GetPossibleToMove() &&IsMoving() )
{
GetManualViewBaseContour()->MoveContour(x,y,z);
} // if State 6
- if (GetState()!=7 || GetManualViewBaseContour()->GetPosibleSelected() )
+ if (GetState()!=7 || GetManualViewBaseContour()->GetPossibleSelected() )
{
GetManualViewBaseContour()->Refresh();
this->_vtkInteractorStyleBaseView->SetRefresh_waiting();
} //IsEditable
// move contour
- if ((GetState()==0) && (GetManualViewBaseContour()->GetPosibleSelected()==true)) {
+ if ((GetState()==0) && (GetManualViewBaseContour()->GetPossibleSelected()==true)) {
GetManualViewBaseContour()->InitMove(x,y,z);
SetState(6);
}
{
int z=GetZ();
- GetManualViewBaseContour()->SelectPosibleContour(x,y,z);
- GetManualViewBaseContour()->SelectPosiblePoint(x,y,z);
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,z);
+ GetManualViewBaseContour()->SelectPossiblePoint(x,y,z);
if (GetState()==1) { SetPoint( bakIdPoint , x , y ,z); }
if (GetState()==5) { SetPoint( bakIdPoint , x , y ,z); }
} // IsEditable
// Move contour
- if ((GetState()==0) && (GetManualViewBaseContour()->GetPosibleSelected()==true)) {
+ if ((GetState()==0) && (GetManualViewBaseContour()->GetPossibleSelected()==true)) {
GetManualViewBaseContour()->InitMove(x,y,z);
SetState(6);
}
// this->_vtkInteractorStyleBaseView->
- GetManualViewBaseContour()->SelectPosibleContour(x,y,z);
- GetManualViewBaseContour()->SelectPosiblePoint(x,y,z);
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,z);
+ GetManualViewBaseContour()->SelectPossiblePoint(x,y,z);
if ( (GetState()==5) || (GetState()==1) ){
}// IsEditable
// move contour
- if ((GetState()==0) && (GetManualViewBaseContour()->GetPosibleSelected()==true)) {
+ if ((GetState()==0) && (GetManualViewBaseContour()->GetPossibleSelected()==true)) {
GetManualViewBaseContour()->InitMove(x,y,z);
SetState(6);
}
{
int z=GetZ();
- GetManualViewBaseContour()->SelectPosibleContour(x,y,z);
- GetManualViewBaseContour()->SelectPosiblePoint(x,y,z);
+ GetManualViewBaseContour()->SelectPossibleContour(x,y,z);
+ GetManualViewBaseContour()->SelectPossiblePoint(x,y,z);
if (GetState()==1){ SetPoint( bakIdPoint , x , y ,z); }
if (GetState()==5){ SetPoint( bakIdPoint , x , y ,z); }
return id;
}
// ----------------------------------------------------------------------------
-int manualView3DContour::SelectPosiblePoint ( int x, int y, int z )// virtual
+int manualView3DContour::SelectPossiblePoint ( int x, int y, int z )// virtual
{
SelectAllPossibleSelected(false);
int id=GetIdPoint2(x,y);
if (id!=-1)
{
- SetPointPosibleSelected(id,true);
+ SetPointPossibleSelected(id,true);
}
return id;
}
virtual void TransfromCoordViewWorld(double &X, double &Y, double &Z, int type);
void SetVtkMPRBaseData(vtkMPRBaseData *vtkmprbasedata);
- virtual int SelectPosiblePoint ( int x, int y, int z );
+ virtual int SelectPossiblePoint ( int x, int y, int z );
void SetDimensions(int w, int h, int d);
int GetIdPoint2(int x, int y);
_manContModel = NULL;
_wxvtkbaseview = NULL;
_selected = false;
- _posibleSelected = false;
+ _possibleSelected = false;
_viewControlPoints = false;
_pts = NULL;
_pd = NULL;
cloneObject-> SetWxVtkBaseView( this->_wxvtkbaseview );
cloneObject-> SetSelected( this->GetSelected() );
- cloneObject-> SetPosibleSelected( this->GetPosibleSelected() );
+ cloneObject-> SetPossibleSelected( this->GetPossibleSelected() );
cloneObject-> SetIfViewControlPoints( this->GetIfViewControlPoints() );
cloneObject-> SetRange( this->GetRange() );
cloneObject-> SetZ( this->GetZ() );
}
// ----------------------------------------------------------------------------
-void manualViewBaseContour::SetPosibleSelected(bool posibleSelected)
+void manualViewBaseContour::SetPossibleSelected(bool possibleSelected)
{
- _posibleSelected=posibleSelected;
+ _possibleSelected = possibleSelected;
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
-bool manualViewBaseContour::GetPosibleSelected()
+bool manualViewBaseContour::GetPossibleSelected()
{
- return _posibleSelected;
+ return _possibleSelected;
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
-void manualViewBaseContour::SetPointPosibleSelected(int id,bool select)
+void manualViewBaseContour::SetPointPossibleSelected(int id,bool select)
{
- _lstViewPoints[id]->SetPosibleSelected(select);
+ _lstViewPoints[id]->SetPossibleSelected(select);
}
// ----------------------------------------------------------------------------
{
int i,size=_lstViewPoints.size();
for (i=0;i<size;i++){
- SetPointPosibleSelected(i,select);
+ SetPointPossibleSelected(i,select);
}
}
// ----------------------------------------------------------------------------
-int manualViewBaseContour::SelectPosiblePoint(int x, int y, int z) // virtual
+int manualViewBaseContour::SelectPossiblePoint(int x, int y, int z) // virtual
{
SelectAllPossibleSelected(false);
int id = GetIdPoint(x,y,z);
if (id!=-1)
{
- SetPointPosibleSelected(id,true);
+ SetPointPossibleSelected(id,true);
}
return id;
}
// ----------------------------------------------------------------------------
-bool manualViewBaseContour::SelectPosibleContour(int x, int y, int z)
+bool manualViewBaseContour::SelectPossibleContour(int x, int y, int z)
{
bool result=false;
- SetPosibleSelected(result);
+ SetPossibleSelected(result);
int id = GetIdPoint(x,y,z);
/* EED 2023-07-29
if( !GetEditable() && !_selected && id!= -1)
{
result = true;
- _posibleSelected = true;
+ _possibleSelected = true;
}else{
if ( (GetEditable()==true) && (id==-1 ) && (this->_lstViewPoints.size()>=2) )
{
if (ifTouchContour(x,y,z)==true)
{
result = true;
- SetPosibleSelected(result);
+ SetPossibleSelected(result);
} // ifTouchContour
}
if (GetEditable()==false)
if (ifTouchContour(x,y,z)==true)
{
result = true;
- SetPosibleSelected(result);
+ SetPossibleSelected(result);
} // ifTouchContor
} // if GetEditable
} // if !GetEditable() && !_selected && id!= -1
if (ifTouchContour(x,y,z)==true)
{
result = true;
- SetPosibleSelected(result);
+ SetPossibleSelected(result);
} // ifTouchContour
}
if (GetEditable()==false)
if (ifTouchContour(x,y,z)==true)
{
result = true;
- SetPosibleSelected(result);
+ SetPossibleSelected(result);
} // ifTouchContor
} // if GetEditable
{
_contourVtkActor->GetProperty()->SetLineWidth( _widthline );
_contourVtkActor->GetProperty()->SetDiffuseColor( _coulorNormal_r , _coulorNormal_g , _coulorNormal_b );
- if (_posibleSelected || (_posibleSelected && GetEditable() ) )
+ /*
+ if (_possibleSelected || (_possibleSelected && GetEditable() ) )
{
_contourVtkActor->GetProperty()->SetDiffuseColor( _coulorEdit_r , _coulorEdit_g , _coulorEdit_b );
}
+*/
+ if ( GetEditable() )
+ {
+ _contourVtkActor->GetProperty()->SetDiffuseColor( _coulorEdit_r , _coulorEdit_g , _coulorEdit_b );
+ }
+
+
if( _selected )
{
_contourVtkActor->GetProperty()->SetDiffuseColor( _coulorSelection_r , _coulorSelection_g , _coulorSelection_b );
}
+
+ if (_possibleSelected )
+ {
+ _contourVtkActor->GetProperty()->SetDiffuseColor( _coulorEdit_r+0.25 , _coulorEdit_g+0.25 , _coulorEdit_b+0.25 );
+ }
+
}
}
virtual void UpdateViewPoint(int id);
virtual void UpdateViewPoints();
void SetSelected(bool selected);
- void SetPosibleSelected(bool posibleSelected);
+ void SetPossibleSelected(bool possibleSelected);
void SetGroupSelectedPoint(int i, bool select);
void SetAllGroupSelectedPoint(bool select);
bool GetSelected();
- bool GetPosibleSelected();
+ bool GetPossibleSelected();
bool GetGroupSelectedPoint(int i);
void DeleteSelectedPoints();
void SelectPoint(int i,bool select);
void SelectLstPoints();
void SelectAllPoints(bool select);
- virtual int SelectPosiblePoint(int x, int y ,int z);
- bool SelectPosibleContour(int x, int y ,int z);
+ virtual int SelectPossiblePoint(int x, int y ,int z);
+ bool SelectPossibleContour(int x, int y ,int z);
void SelectAllPossibleSelected(bool select);
void SetPointSelected(int id,bool select);
- void SetPointPosibleSelected(int id,bool select);
+ void SetPointPossibleSelected(int id,bool select);
void SetIfViewControlPoints(bool ifShow);
bool GetIfViewControlPoints();
void UnSelectPoint(int i);
//
bool _selected;
bool *_editable;
- bool _posibleSelected;
+ bool _possibleSelected;
bool _viewControlPoints;
// text
int i;
for (i=0; i<size; i++)
{
- if (_lstViewPoints[i]->GetPosibleSelected()==true)
+ if (_lstViewPoints[i]->GetPossibleSelected()==true)
{
_id_viewPoint_for_text = i;
} // if
}
}
+
+#define _VECTOR_SUB( a ,b ,r ) \
+ r[0] = a[0]-b[0]; \
+ r[1] = a[1]-b[1]; \
+ r[2] = a[2]-b[2];
+
+#define _VECTOR_MODULE( a ) sqrt(a[0]*a[0] + a[1]*a[1] + a[2]*a[2] )
+
+#define _VECTOR_DOT( a , b ) a[0]*b[0] + a[1]*b[1] + a[2]*b[2]
+
+#define _VECTOR_CROSS( a ,b ,r ) \
+ r[0] = a[1] * b[2] - a[2] * b[1]; \
+ r[1] = a[2] * b[0] - a[0] * b[2]; \
+ r[2] = a[0] * b[1] - a[1] * b[0];
+
+
+double _distanceToSegment( double v[3], double a[3], double b[3] )
+{
+ // https://www.geeksforgeeks.org/program-dot-product-cross-product-two-vector/
+
+ double ab[3]; _VECTOR_SUB(b,a, ab )
+ double av[3]; _VECTOR_SUB(v,a, av )
+ if (_VECTOR_DOT(av,ab) <= 0.0) // Point is lagging behind start of the segment, so perpendicular distance is not viable.
+ {
+ return _VECTOR_MODULE(av) ; // Use distance to start of segment instead.
+ }
+ double bv[3]; _VECTOR_SUB(v,b,bv )
+ if (_VECTOR_DOT(bv,ab) >= 0.0) // Point is advanced past the end of the segment, so perpendicular distance is not viable.
+ {
+ return _VECTOR_MODULE(bv) ; // Use distance to end of the segment instead.
+ }
+ double c[3]; _VECTOR_CROSS(ab,av,c);
+ return _VECTOR_MODULE(c) / _VECTOR_MODULE(ab); // Perpendicular distance of point to segment.
+}
+
// ----------------------------------------------------------------------------
bool manualViewContour::ifTouchContour(int x,int y,int z)
{
double zz = z;
double ppA[3];
double ppB[3];
+ double pp[3];
double d1,d2,d3;
TransfromCoordViewWorld(xx,yy,zz);
//EED 27 sep 2006
xx = xx * _spc[0];
yy = yy * _spc[1];
zz = zz * _spc[2];
- if ( (xx>=_minX) && (yy>=_minY) && (xx<=_maxX) && (yy<=_maxY))
+ pp[0]=xx;
+ pp[1]=yy;
+ pp[2]=zz;
+ if ( (xx>=_minX) && (yy>=_minY) && (xx<=_maxX) && (yy<=_maxY))
{ // inside the boundaring box
+ double dirVec[3];
+ double num;
+ double k;
+ double den;
+ double projX;
+ double projY;
+ double projZ;
if ( ShowLineVersion()==true )
{
_pts->GetPoint(0, ppA);
_pts->GetPoint(1, ppB);
- double dirVec[3];
// direction of the segment
dirVec[0] = ppB[0] - ppA[0];
dirVec[1] = ppB[1] - ppA[1];
dirVec[2] = ppB[2] - ppA[2];
// proj = mpA + k*dirVec
- double num;
- double den = 0.0 ;
+ den = 0.0 ;
num = dirVec[0]*( xx-ppA[0] );
num = num + dirVec[1]*( yy-ppA[1] );
num = num + dirVec[2]*( zz-ppA[2] );
den=dirVec[0]*dirVec[0] + dirVec[1]*dirVec[1] + dirVec[2]*dirVec[2];
- double k;
- if (den!=0)
+ if (den!=0)
{
k = num/den;
} else {
k = 99999999;
}
// projection of th point xx,yy,zz in segment mpA,mpB
- double projX = ppA[0] + k*dirVec[0];
- double projY = ppA[1] + k*dirVec[1];
- double projZ = ppA[2] + k*dirVec[2];
+ projX = ppA[0] + k*dirVec[0];
+ projY = ppA[1] + k*dirVec[1];
+ projZ = ppA[2] + k*dirVec[2];
// distance [projX,projY,projZ] and (xx,yy,zz]
- double d1= sqrt( (projX-xx)*(projX-xx) + (projY-yy)*(projY-yy) +(projZ-zz)*(projZ-zz) );
+ d1 = sqrt( (projX-xx)*(projX-xx) + (projY-yy)*(projY-yy) +(projZ-zz)*(projZ-zz) );
if (d1<=1)
{
result=true;
} // if d1
+
} else {
unsigned int i, nps,nps_t;
nps = _sizePointsContour;
} else {
nps_t = nps-1;
} // if close
- for( i = 0; i < nps_t; i++ )
+
+ for( i = 0; i < nps_t; i++ )
{
_pts->GetPoint(i%nps, ppA);
_pts->GetPoint((i+1)%nps, ppB);
+
+ /* V1 working but not proportional distance throw al contour
d1 = sqrt( (ppA[0]-xx)*(ppA[0]-xx) + (ppA[1]-yy)*(ppA[1]-yy) + (ppA[2]-zz)*(ppA[2]-zz));
d2 = sqrt( (ppB[0]-xx)*(ppB[0]-xx) + (ppB[1]-yy)*(ppB[1]-yy) + (ppB[2]-zz)*(ppB[2]-zz));
d3 = sqrt( (ppB[0]-ppA[0])*(ppB[0]-ppA[0]) + (ppB[1]-ppA[1])*(ppB[1]-ppA[1]) + (ppB[2]-ppA[2])*(ppB[2]-ppA[2]));
- if ( ((d1+d2)>=d3) && ((d1+d2)<=d3*3.3) )
+ if ( ((d1+d2)>=d3) && ((d1+d2)<=d3*1.1) )
{
+ printf("EED manualViewContour::ifTouchContour flag 3\n" );
result = true;
i = nps;
} // if
if ( (d1<0.75*_spc[0]) || (d2<0.75*_spc[0]) )
{
+ printf("EED manualViewContour::ifTouchContour flag 4\n" );
result = true;
i = nps;
} // if
+ */
+
+ /* V2 not working
+
+ // direction of the segment
+ dirVec[0] = ppB[0] - ppA[0];
+ dirVec[1] = ppB[1] - ppA[1];
+ dirVec[2] = ppB[2] - ppA[2];
+ // proj = mpA + k*dirVec
+ den = 0.0 ;
+
+ num = dirVec[0]*( xx-ppA[0] );
+ num = num + dirVec[1]*( yy-ppA[1] );
+ num = num + dirVec[2]*( zz-ppA[2] );
+
+ den=dirVec[0]*dirVec[0] + dirVec[1]*dirVec[1] + dirVec[2]*dirVec[2];
+ if (den!=0)
+ {
+ k = num/den;
+ } else {
+ k = 99999999;
+ }
+ // projection of th point xx,yy,zz in segment mpA,mpB
+ projX = ppA[0] + k*dirVec[0];
+ projY = ppA[1] + k*dirVec[1];
+ projZ = ppA[2] + k*dirVec[2];
+
+ // distance [projX,projY,projZ] and (xx,yy,zz]
+ d1 = sqrt( (projX-xx)*(projX-xx) + (projY-yy)*(projY-yy) +(projZ-zz)*(projZ-zz) );
+
+ printf("EED manualViewContour::ifTouchContour flag 2 %d point=%f %f %f d1=%f\n", nps_t , xx,yy,zz, d1);
+ printf("EED A=%f %f %f B=%f %f %f\n", ppA[0], ppA[1], ppA[2], ppB[0],ppB[1],ppB[2] );
+
+ if (d1<=1)
+ {
+ result = true;
+ i = nps;
+ } // if d1
+*/
+ // V3 ok in mathematical point of view. Missing optimization c++
+ if ( _distanceToSegment(pp,ppA,ppB) <=1 )
+ {
+ result = true;
+ i = nps;
+ }
+
} // for i
} // if GetSizeLstPoints()==2
} // if min max
// ----------------------------------------------------------------------------
manualViewPoint::manualViewPoint(wxVtkBaseView *wxvtkbaseview){
_selected = false;
- _posibleSelected = false;
+ _possibleSelected = false;
_groupSelected = false;
_pts = NULL;
_pd = NULL;
_colorNormal_g = 0.0;
_colorNormal_b = 0.0;
- _colorPosibleSelected_r = 1.0;
- _colorPosibleSelected_g = 1.0;
- _colorPosibleSelected_b = 0.0;
+ _colorPossibleSelected_r = 1.0;
+ _colorPossibleSelected_g = 1.0;
+ _colorPossibleSelected_b = 0.0;
}
// ----------------------------------------------------------------------------
void manualViewPoint::CopyAttributesTo( manualViewPoint * cloneObject)
{
// Fathers object
- cloneObject->SetPosibleSelected(_posibleSelected);
+ cloneObject->SetPossibleSelected(_possibleSelected);
cloneObject->SetSelected(_selected);
cloneObject->SetSpacing(_spc);
cloneObject->SetWidthLine(_widthline);
}
// ----------------------------------------------------------------------------
-void manualViewPoint::SetPosibleSelected(bool posibleSelected)
+void manualViewPoint::SetPossibleSelected(bool possibleSelected)
{
- _posibleSelected = posibleSelected;
+ _possibleSelected = possibleSelected;
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
-bool manualViewPoint::GetPosibleSelected(){
- return _posibleSelected;
+bool manualViewPoint::GetPossibleSelected(){
+ return _possibleSelected;
}
// ----------------------------------------------------------------------------
//EED03
_pointVtkActor->GetProperty()->SetLineWidth( _widthline );
_pointVtkActor->GetProperty()->SetDiffuseColor(_colorNormal_r,_colorNormal_g,_colorNormal_b);
- if (_posibleSelected==true)
+ if (_possibleSelected==true)
{
- _pointVtkActor->GetProperty()->SetDiffuseColor(_colorPosibleSelected_r,_colorPosibleSelected_g,_colorPosibleSelected_b);
- } // if _posibleSelected
+ _pointVtkActor->GetProperty()->SetDiffuseColor(_colorPossibleSelected_r,_colorPossibleSelected_g,_colorPossibleSelected_b);
+ } // if _possibleSelected
// EED 2024-10-25
if (_groupSelected==true)
{
- _pointVtkActor->GetProperty()->SetDiffuseColor(_colorPosibleSelected_r,_colorPosibleSelected_g,_colorPosibleSelected_b);
+ _pointVtkActor->GetProperty()->SetDiffuseColor(_colorPossibleSelected_r,_colorPossibleSelected_g,_colorPossibleSelected_b);
} // if _groupSelected
} // if _pointVtkActor
}
virtual manualViewPoint * Clone();
void CopyAttributesTo( manualViewPoint *cloneObject );
void SetSelected(bool selected);
- void SetPosibleSelected(bool posibleSelected);
+ void SetPossibleSelected(bool possibleSelected);
void SetGroupSelected(bool groupSelected);
bool GetSelected();
- bool GetPosibleSelected();
+ bool GetPossibleSelected();
bool GetGroupSelected();
void DeleteVtkObjects();
vtkActor* CreateVtkPointActor();
// Is point selected
//
bool _selected;
- bool _posibleSelected;
+ bool _possibleSelected;
bool _groupSelected;
vtkPoints *_pts;
double _colorNormal_g;
double _colorNormal_b;
- // Posible selected point color
- double _colorPosibleSelected_r;
- double _colorPosibleSelected_g;
- double _colorPosibleSelected_b;
+ // Possible selected point color
+ double _colorPossibleSelected_r;
+ double _colorPossibleSelected_g;
+ double _colorPossibleSelected_b;
};
#endif // manualViewPoint_h
vtkActor *_pointVtkActor = mv->GetVtkActor();
_pointVtkActor->GetProperty()->SetDiffuseColor( _coulorNormal_r , _coulorNormal_g , _coulorNormal_b );
- if (_posibleSelected || (_posibleSelected && GetEditable() ) )
+ if (_possibleSelected || (_possibleSelected && GetEditable() ) )
{
_pointVtkActor->GetProperty()->SetDiffuseColor( _coulorEdit_r , _coulorEdit_g , _coulorEdit_b );
}
dc.Blit(deviceStart_x, deviceStart_y, bar_width/*-deviceEndMargin*/, bar_height, &temp_dc, 0, 0);
- // Bitmap for posible needed information to be shown
+ // Bitmap for possible needed information to be shown
/*
temp_dc.SelectObject( * information_Bitmap );
dc.Blit(0,bar_height, width, height, &temp_dc, 0, height);
// dc.Blit(deviceStart_y,deviceStart_x, bar_height+deviceStart_y, bar_width+deviceStart_x, &temp_dc, deviceStart_y, deviceStart_x);
dc.Blit(deviceStart_y,deviceStart_x, bar_height, bar_width-deviceEndMargin, &temp_dc, 0, 0);
- // Bitmap for posible needed information to be shown
+ // Bitmap for possible needed information to be shown
/*
temp_dc.SelectObject( * information_Bitmap );
dc.Blit(0,bar_width, height, width, &temp_dc, 0, width );
{
bool addedPoint = false;
wxPoint point = event.GetPosition();
- bool posiblePoint = false;
+ bool possiblePoint = false;
if( getOrientation() )
{
- posiblePoint = point.x>=deviceStart_x && point.y<= (bar_height + deviceStart_y);
+ possiblePoint = point.x>=deviceStart_x && point.y<= (bar_height + deviceStart_y);
}
else
{
- posiblePoint = point.x>=deviceStart_y && point.x<= (bar_height+deviceStart_y) && point.y>deviceStart_x;
+ possiblePoint = point.x>=deviceStart_y && point.x<= (bar_height+deviceStart_y) && point.y>deviceStart_x;
}
- if (posiblePoint)
+ if (possiblePoint)
{
double real_x = getOrientation() ? convertToRealValue( point.x ) : convertToRealValue( point.y );
wxColour selectedColor = getSelectedColour();
_logicalBar->clearPoints();
showedColorPoints.clear();
_logicalBar->setColorPoints(_points);
- //posible needed to update
+ //possible needed to update
}
/**
}
- //calcular criterio para cada posible threshold e ir seleccionando el maximo
+ //calcular criterio para cada ossible threshold e ir seleccionando el maximo
int optimalThreshold = 0;
double optimalCriteria = 0.0;