From 339a90e7aceab93e3f1ddb3a62e47b6b146943c4 Mon Sep 17 00:00:00 2001 From: CHARRAS Date: Sun, 6 Jan 2008 12:43:57 +0000 Subject: [PATCH] Block commands now works with zones. --- change_log.txt | 7 + common/base_struct.cpp | 14 + include/base_struct.h | 22 ++ include/pcbstruct.h | 9 + pcbnew/block.cpp | 534 +++++++++------------------------ pcbnew/class_board.h | 6 +- pcbnew/class_cotation.cpp | 169 +++++++---- pcbnew/class_cotation.h | 32 +- pcbnew/class_mire.cpp | 13 + pcbnew/class_mire.h | 10 + pcbnew/class_module.cpp | 25 ++ pcbnew/class_module.h | 8 + pcbnew/class_pcb_text.cpp | 21 -- pcbnew/class_pcb_text.h | 11 + pcbnew/class_track.cpp | 16 + pcbnew/class_track.h | 9 + pcbnew/class_zone.cpp | 102 ++++++- pcbnew/class_zone.h | 40 +++ pcbnew/classpcb.cpp | 37 +-- polygon/CMakeLists.txt | 1 - polygon/PolyLine.cpp | 316 +------------------ polygon/PolyLine.h | 20 +- polygon/cdisplaylist_stuff.cpp | 67 ----- polygon/freepcbDisplayList.h | 230 -------------- polygon/makefile.include | 3 +- 25 files changed, 618 insertions(+), 1104 deletions(-) delete mode 100644 polygon/cdisplaylist_stuff.cpp diff --git a/change_log.txt b/change_log.txt index 7b6a8bada6..ada586dc25 100644 --- a/change_log.txt +++ b/change_log.txt @@ -4,6 +4,13 @@ Started 2007-June-11 Please add newer entries at the top, list the date and your name with email address. +2008-jan-06 UPDATE Jean-Pierre Charras +================================================================================ ++pcbnew: + Block commands now works with zones. + Some code cleanning. + + 2008-Jan-5 UPDATE Dick Hollenbeck ================================================================================ +pcbnew: diff --git a/common/base_struct.cpp b/common/base_struct.cpp index ac2e4d8f1a..c109c095d0 100644 --- a/common/base_struct.cpp +++ b/common/base_struct.cpp @@ -294,6 +294,20 @@ bool EDA_TextStruct::HitTest( const wxPoint& posref ) return false; } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * @param refArea the given EDA_Rect to test + * @return bool - true if a hit, else false + */ +/*********************************************************/ +bool EDA_TextStruct::HitTest( EDA_Rect& refArea ) +/*********************************************************/ +{ + if( refArea.Inside( m_Pos ) ) + return true; + return false; +} /*******************************/ int EDA_TextStruct::Pitch() diff --git a/include/base_struct.h b/include/base_struct.h index aa4e1ba689..2d3453e6c0 100644 --- a/include/base_struct.h +++ b/include/base_struct.h @@ -89,6 +89,7 @@ enum SEARCH_RESULT { class EDA_BaseStruct; class WinEDA_DrawFrame; class BOARD; +class EDA_Rect; /** * Class INSPECTOR @@ -254,6 +255,18 @@ public: return false; // derived classes should override this function } + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, an ending point must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + virtual bool HitTest( EDA_Rect& refArea ) + { + return false; // derived classes should override this function + } + /** * Function IterateForward @@ -419,6 +432,15 @@ public: bool HitTest( const wxPoint& ref_pos ); /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, the anchor must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + + /** * Function Len_Size * Return the text lenght in internal units */ diff --git a/include/pcbstruct.h b/include/pcbstruct.h index 37baf9ec03..c9f5111d95 100644 --- a/include/pcbstruct.h +++ b/include/pcbstruct.h @@ -301,6 +301,15 @@ public: */ bool HitTest( const wxPoint& ref_pos ); + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, an ending point must be inside this rect. + * @param refPos the given EDA_Rect to test + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + /** * Function GetClass * returns the class name. diff --git a/pcbnew/block.cpp b/pcbnew/block.cpp index f22d0d25bd..b544b1dd73 100644 --- a/pcbnew/block.cpp +++ b/pcbnew/block.cpp @@ -21,9 +21,6 @@ static void DrawMovingBlockOutlines( WinEDA_DrawPanel* panel, wxDC* DC, bool erase ); -static EDA_BaseStruct* IsStructInBox( DrawBlockStruct& blocklocate, EDA_BaseStruct* PtStruct ); -static TRACK* IsSegmentInBox( DrawBlockStruct& blocklocate, TRACK* PtSegm ); -static MODULE* IsModuleInBox( DrawBlockStruct& blocklocate, MODULE* Module ); /* Variables locales :*/ static bool Block_Include_Modules = TRUE; @@ -461,18 +458,16 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) if( Block_Include_Modules ) { MODULE* module; - Affiche_Message( _( "Delete Footprints" ) ); module = m_Pcb->m_Modules; for( ; module != NULL; module = (MODULE*) NextS ) { NextS = module->Next(); - if( IsModuleInBox( GetScreen()->BlockLocate, module ) == NULL ) - continue; - /* le module est ici bon a etre efface */ - module->m_Flags = 0; - module->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - module->DeleteStructure(); - m_Pcb->m_Status_Pcb = 0; + if( module->HitTest( GetScreen()->BlockLocate ) ) + { + module->m_Flags = 0; + module->DeleteStructure(); + m_Pcb->m_Status_Pcb = 0; + } } } @@ -481,14 +476,12 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) { TRACK* pt_segm; - Affiche_Message( _( "Delete tracks" ) ); for( pt_segm = m_Pcb->m_Track; pt_segm != NULL; pt_segm = (TRACK*) NextS ) { NextS = pt_segm->Next(); - if( IsSegmentInBox( GetScreen()->BlockLocate, pt_segm ) ) + if( pt_segm->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre efface */ - pt_segm->Draw( DrawPanel, DC, GR_XOR ); pt_segm->DeleteStructure(); } } @@ -502,7 +495,6 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) if( !Block_Include_Edges_Items ) masque_layer &= ~EDGE_LAYER; - Affiche_Message( _( "Delete draw layers" ) ); PtStruct = m_Pcb->m_Drawings; for( ; PtStruct != NULL; PtStruct = NextS ) { @@ -515,7 +507,7 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) #define STRUCT ( (DRAWSEGMENT*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ Trace_DrawSegmentPcb( DrawPanel, DC, (DRAWSEGMENT*) PtStruct, GR_XOR ); @@ -525,7 +517,7 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) case TYPETEXTE: if( !Block_Include_PcbTextes ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* le texte est ici bon a etre efface */ ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); @@ -538,10 +530,9 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) #define STRUCT ( (MIREPCB*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); PtStruct->DeleteStructure(); break; @@ -550,10 +541,8 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) #define STRUCT ( (COTATION*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; - /* l'element est ici bon a etre efface */ - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); PtStruct->DeleteStructure(); break; @@ -571,17 +560,23 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) for( pt_segm = m_Pcb->m_Zone; pt_segm != NULL; pt_segm = NextSegZ ) { NextSegZ = pt_segm->Next(); - if( IsSegmentInBox( GetScreen()->BlockLocate, pt_segm ) ) + if( PtStruct->HitTest( GetScreen()->BlockLocate ) ) { - /* The segment zone is in the block: delete it */ - pt_segm->Draw( DrawPanel, DC, GR_XOR ); pt_segm->DeleteStructure(); } } + + for ( unsigned ii = 0; ii < m_Pcb->m_ZoneDescriptorList.size(); ii++ ) + { + if( m_Pcb->m_ZoneDescriptorList[ii]->HitTest( GetScreen()->BlockLocate ) ) + { + m_Pcb->Delete(m_Pcb->m_ZoneDescriptorList[ii]); + ii--; // because the current data was removed, ii points actually the next data + } + } } - /* Rafraichissement de l'ecran : */ - RedrawActiveWindow( DC, TRUE ); + DrawPanel->Refresh( TRUE ); if( g_Show_Ratsnest ) Compile_Ratsnest( DC, TRUE ); } @@ -591,16 +586,17 @@ void WinEDA_BasePcbFrame::Block_Delete( wxDC* DC ) void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) /****************************************************/ -/* - * routine de Rotation de 90 deg du block deja selectionne - * les elements sont tournes autour du centre du block +/** + * Function Block_Rotate + * Rotate 90 deg the selected block + * The rotation centre is the centre of the block */ { MODULE* module; EDA_BaseStruct* PtStruct; int masque_layer; wxPoint oldpos; - int Nx, Ny, centerX, centerY; /* centre de rotation de l'ensemble des elements */ + wxPoint centre; /* rotation centre for the rotation transform */ if( !InstallBlockCmdFrame( this, _( "Rotate Block" ) ) ) return; @@ -608,36 +604,27 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) oldpos = GetScreen()->m_Curseur; GetScreen()->BlockLocate.Normalize(); - /* calcul du centre de Rotation */ - centerX = GetScreen()->BlockLocate.Centre().x; - centerY = GetScreen()->BlockLocate.Centre().y; + centre = GetScreen()->BlockLocate.Centre(); // This is the rotation centre GetScreen()->SetModify(); /* Rotation des modules */ if( Block_Include_Modules ) { - Affiche_Message( _( "Footprint rotation" ) ); bool Show_Ratsnest_tmp = g_Show_Ratsnest; g_Show_Ratsnest = false; int Angle_Rot_Module = 900; module = m_Pcb->m_Modules; for( ; module != NULL; module = (MODULE*) module->Pnext ) { - if( IsModuleInBox( GetScreen()->BlockLocate, module ) == NULL ) + if( ! module->HitTest( GetScreen()->BlockLocate ) ) continue; - /* le module est ici bon a etre modifie */ m_Pcb->m_Status_Pcb = 0; module->m_Flags = 0; - module->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); - - /* calcul de la nouvelle position du Module */ - Nx = module->m_Pos.x; Ny = module->m_Pos.y; - RotatePoint( &Nx, &Ny, centerX, centerY, 900 ); - GetScreen()->m_Curseur.x = Nx; - GetScreen()->m_Curseur.y = Ny; - Place_Module( module, DC ); - - /* Rotation du module autour de son ancre */ + /* Move the footprint before rotate it */ + RotatePoint( &module->m_Pos, centre, 900 ); + GetScreen()->m_Curseur = module->m_Pos; + Place_Module( module, NULL ); + /* Rotate the footprint */ Rotate_Module( DC, module, Angle_Rot_Module, TRUE ); } @@ -646,28 +633,24 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) g_Show_Ratsnest = Show_Ratsnest_tmp; } - /* Deplacement des Segments de piste */ + /* Move and rotate the track segments */ if( Block_Include_Tracks ) { TRACK* track; - - Affiche_Message( _( "Track rotation" ) ); track = m_Pcb->m_Track; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ m_Pcb->m_Status_Pcb = 0; - track->Draw( DrawPanel, DC, GR_XOR ); // effacement - RotatePoint( &track->m_Start.x, &track->m_Start.y, centerX, centerY, 900 ); - RotatePoint( &track->m_End.x, &track->m_End.y, centerX, centerY, 900 ); - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage + RotatePoint( &track->m_Start, centre, 900 ); + RotatePoint( &track->m_End, centre, 900 ); } track = track->Next(); } } - /* Deplacement des Segments de Zone */ + /* Move and rotate the zone fill segments, and outlines */ if( Block_Include_Zones ) { TRACK* track; @@ -676,15 +659,20 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) track = (TRACK*) m_Pcb->m_Zone; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) - { /* la piste est ici bonne a etre deplacee */ - track->Draw( DrawPanel, DC, GR_XOR ); // effacement - RotatePoint( &track->m_Start.x, &track->m_Start.y, centerX, centerY, 900 ); - RotatePoint( &track->m_End.x, &track->m_End.y, centerX, centerY, 900 ); - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage + if( track->HitTest( GetScreen()->BlockLocate ) ) + { + RotatePoint( &track->m_Start, centre, 900 ); + RotatePoint( &track->m_End, centre, 900 ); } track = track->Next(); } + for ( unsigned ii = 0; ii < m_Pcb->m_ZoneDescriptorList.size(); ii++ ) + { + if( m_Pcb->m_ZoneDescriptorList[ii]->HitTest( GetScreen()->BlockLocate ) ) + { + m_Pcb->m_ZoneDescriptorList[ii]->Rotate(centre, 900); + } + } } masque_layer = EDGE_LAYER; @@ -693,7 +681,7 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) if( !Block_Include_Edges_Items ) masque_layer &= ~EDGE_LAYER; - Affiche_Message( _( "Draw layers rotation" ) ); + /* Move and rotate the graphic items */ PtStruct = m_Pcb->m_Drawings; for( ; PtStruct != NULL; PtStruct = PtStruct->Pnext ) { @@ -704,13 +692,10 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) #define STRUCT ( (DRAWSEGMENT*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; - /* l'element est ici bon a etre efface */ - Trace_DrawSegmentPcb( DrawPanel, DC, (DRAWSEGMENT*) PtStruct, GR_XOR ); - RotatePoint( &STRUCT->m_Start.x, &STRUCT->m_Start.y, centerX, centerY, 900 ); - RotatePoint( &STRUCT->m_End.x, &STRUCT->m_End.y, centerX, centerY, 900 ); - Trace_DrawSegmentPcb( DrawPanel, DC, (DRAWSEGMENT*) PtStruct, GR_OR ); + RotatePoint( &STRUCT->m_Start, centre, 900 ); + RotatePoint( &STRUCT->m_End, centre, 900 ); break; case TYPETEXTE: @@ -718,18 +703,14 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) #define STRUCT ( (TEXTE_PCB*) PtStruct ) if( !Block_Include_PcbTextes ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; - /* le texte est ici bon a etre deplace */ - ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - /* Redessin du Texte */ - RotatePoint( &STRUCT->m_Pos.x, &STRUCT->m_Pos.y, centerX, centerY, 900 ); + RotatePoint( &STRUCT->m_Pos, centre, 900 ); STRUCT->m_Orient += 900; if( STRUCT->m_Orient >= 3600 ) STRUCT->m_Orient -= 3600; STRUCT->CreateDrawData(); - ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; case TYPEMIRE: @@ -737,12 +718,10 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) #define STRUCT ( (MIREPCB*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre modifie */ - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - RotatePoint( &STRUCT->m_Pos.x, &STRUCT->m_Pos.y, centerX, centerY, 900 ); - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + RotatePoint( &STRUCT->m_Pos, centre, 900 ); break; case TYPECOTATION: @@ -750,37 +729,9 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) #define STRUCT ( (COTATION*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; - /* l'element est ici bon a etre modifie */ - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - - RotatePoint( &STRUCT->m_Pos.x, &STRUCT->m_Pos.y, centerX, centerY, 900 ); - - RotatePoint( &STRUCT->m_Text->m_Pos.x, &STRUCT->m_Text->m_Pos.y, - centerX, centerY, 900 ); - STRUCT->m_Text->m_Orient += 900; - if( STRUCT->m_Text->m_Orient >= 3600 ) - STRUCT->m_Text->m_Orient -= 3600; - if( (STRUCT->m_Text->m_Orient > 900) - && (STRUCT->m_Text->m_Orient <2700) ) - STRUCT->m_Text->m_Orient -= 1800; - - RotatePoint( &STRUCT->Barre_ox, &STRUCT->Barre_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->Barre_fx, &STRUCT->Barre_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->TraitG_ox, &STRUCT->TraitG_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->TraitG_fx, &STRUCT->TraitG_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->TraitD_ox, &STRUCT->TraitD_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->TraitD_fx, &STRUCT->TraitD_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheG1_ox, &STRUCT->FlecheG1_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheG1_fx, &STRUCT->FlecheG1_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheG2_ox, &STRUCT->FlecheG2_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheG2_fx, &STRUCT->FlecheG2_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheD1_ox, &STRUCT->FlecheD1_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheD1_fx, &STRUCT->FlecheD1_fy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheD2_ox, &STRUCT->FlecheD2_oy, centerX, centerY, 900 ); - RotatePoint( &STRUCT->FlecheD2_fx, &STRUCT->FlecheD2_fy, centerX, centerY, 900 ); - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + STRUCT->Rotate(centre, 900); break; default: @@ -788,7 +739,7 @@ void WinEDA_BasePcbFrame::Block_Rotate( wxDC* DC ) } } - RedrawActiveWindow( DC, TRUE ); + DrawPanel->Refresh( TRUE ); if( g_Show_Ratsnest ) Compile_Ratsnest( DC, TRUE ); } @@ -803,9 +754,9 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) * les elements sont inverse / axe horizontal, * l'axe d'inversion est la mediane horizontale du block */ +{ #define INVERT( pos ) (pos) = centerY - ( (pos) - centerY ) #define INVERT_ANGLE( phi ) (phi) = -(phi) -{ MODULE* module; EDA_BaseStruct* PtStruct; int masque_layer; @@ -827,23 +778,21 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) if( Block_Include_Modules ) { bool Show_Ratsnest_tmp = g_Show_Ratsnest; g_Show_Ratsnest = false; - Affiche_Message( _( "Footprint mirroring" ) ); module = m_Pcb->m_Modules; for( ; module != NULL; module = (MODULE*) module->Pnext ) { - if( IsModuleInBox( GetScreen()->BlockLocate, module ) == NULL ) + if( ! module->HitTest( GetScreen()->BlockLocate ) ) continue; /* le module est ici bon a etre efface */ m_Pcb->m_Status_Pcb = 0; module->m_Flags = 0; - module->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); /* calcul de la nouvelle position du Module */ Ny = module->m_Pos.y; INVERT( Ny ); GetScreen()->m_Curseur.x = module->m_Pos.x; GetScreen()->m_Curseur.y = Ny; - Place_Module( module, DC ); + Place_Module( module, NULL ); /* inversion du module */ Change_Side_Module( module, DC ); @@ -860,22 +809,18 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) { TRACK* track; - Affiche_Message( _( "Track mirroring" ) ); track = m_Pcb->m_Track; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ m_Pcb->m_Status_Pcb = 0; - track->Draw( DrawPanel, DC, GR_XOR ); // effacement INVERT( track->m_Start.y ); INVERT( track->m_End.y ); if( track->Type() != TYPEVIA ) { track->SetLayer( ChangeSideNumLayer( track->GetLayer() ) ); } - - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage } track = (TRACK*) track->Pnext; } @@ -886,20 +831,25 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) { TRACK* track; - Affiche_Message( _( "Zone mirroring" ) ); track = (TRACK*) m_Pcb->m_Zone; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ - track->Draw( DrawPanel, DC, GR_XOR ); // effacement INVERT( track->m_Start.y ); INVERT( track->m_End.y ); track->SetLayer( ChangeSideNumLayer( track->GetLayer() ) ); - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage } track = (TRACK*) track->Pnext; } + for ( unsigned ii = 0; ii < m_Pcb->m_ZoneDescriptorList.size(); ii++ ) + { + if( m_Pcb->m_ZoneDescriptorList[ii]->HitTest( GetScreen()->BlockLocate ) ) + { + m_Pcb->m_ZoneDescriptorList[ii]->Mirror( wxPoint(0, centerY) ); + m_Pcb->m_ZoneDescriptorList[ii]->SetLayer( ChangeSideNumLayer( m_Pcb->m_ZoneDescriptorList[ii]->GetLayer() ) ); + } + } } masque_layer = EDGE_LAYER; @@ -908,7 +858,6 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) if( !Block_Include_Edges_Items ) masque_layer &= ~EDGE_LAYER; - Affiche_Message( _( "Draw layers mirroring" ) ); PtStruct = m_Pcb->m_Drawings; for( ; PtStruct != NULL; PtStruct = PtStruct->Pnext ) { @@ -919,10 +868,9 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) #define STRUCT ( (DRAWSEGMENT*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre selectionne */ - Trace_DrawSegmentPcb( DrawPanel, DC, (DRAWSEGMENT*) PtStruct, GR_XOR ); if( STRUCT->m_Shape == S_ARC ) { INVERT_ANGLE( STRUCT->m_Angle ); @@ -930,7 +878,6 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) INVERT( STRUCT->m_Start.y ); INVERT( STRUCT->m_End.y ); STRUCT->SetLayer( ChangeSideNumLayer( STRUCT->GetLayer() ) ); - Trace_DrawSegmentPcb( DrawPanel, DC, (DRAWSEGMENT*) PtStruct, GR_OR ); break; case TYPETEXTE: @@ -938,11 +885,9 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) #define STRUCT ( (TEXTE_PCB*) PtStruct ) if( !Block_Include_PcbTextes ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* le texte est ici bon a etre selectionne*/ - ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - /* Redessin du Texte */ INVERT( STRUCT->m_Pos.y ); INVERT_ANGLE( STRUCT->m_Orient ); if( (STRUCT->GetLayer() == COPPER_LAYER_N) || (STRUCT->GetLayer() == CMP_N) ) @@ -951,7 +896,6 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) } STRUCT->SetLayer( ChangeSideNumLayer( STRUCT->GetLayer() ) ); STRUCT->CreateDrawData(); - ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; case TYPEMIRE: @@ -959,13 +903,11 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) #define STRUCT ( (MIREPCB*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre modifie */ - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); INVERT( STRUCT->m_Pos.y ); STRUCT->SetLayer( ChangeSideNumLayer( STRUCT->GetLayer() ) ); - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; case TYPECOTATION: @@ -973,38 +915,12 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) #define STRUCT ( (COTATION*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre modifie */ - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - - INVERT( STRUCT->m_Pos.y ); - INVERT( STRUCT->m_Text->m_Pos.y ); - INVERT_ANGLE( STRUCT->m_Text->m_Orient ); - if( STRUCT->m_Text->m_Orient >= 3600 ) - STRUCT->m_Text->m_Orient -= 3600; - if( (STRUCT->m_Text->m_Orient > 900) - && (STRUCT->m_Text->m_Orient <2700) ) - STRUCT->m_Text->m_Orient -= 1800; - - INVERT( STRUCT->Barre_oy ); - INVERT( STRUCT->Barre_fy ); - INVERT( STRUCT->TraitG_oy ); - INVERT( STRUCT->TraitG_fy ); - INVERT( STRUCT->TraitD_oy ); - INVERT( STRUCT->TraitD_fy ); - INVERT( STRUCT->FlecheG1_oy ); - INVERT( STRUCT->FlecheG1_fy ); - INVERT( STRUCT->FlecheG2_oy ); - INVERT( STRUCT->FlecheG2_fy ); - INVERT( STRUCT->FlecheD1_oy ); - INVERT( STRUCT->FlecheD1_fy ); - INVERT( STRUCT->FlecheD2_oy ); - INVERT( STRUCT->FlecheD2_fy ); + STRUCT->Mirror( wxPoint(0, centerY) ); STRUCT->SetLayer( ChangeSideNumLayer( STRUCT->GetLayer() ) ); - - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; default: @@ -1012,7 +928,7 @@ void WinEDA_BasePcbFrame::Block_Invert( wxDC* DC ) } } - RedrawActiveWindow( DC, TRUE ); + DrawPanel->Refresh( TRUE ); if( g_Show_Ratsnest ) Compile_Ratsnest( DC, TRUE ); } @@ -1029,8 +945,8 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) MODULE* module; EDA_BaseStruct* PtStruct; int masque_layer; - int deltaX, deltaY; wxPoint oldpos; + wxPoint MoveVector = GetScreen()->BlockLocate.m_MoveVector; oldpos = GetScreen()->m_Curseur; DrawPanel->ManageCurseur = NULL; @@ -1047,50 +963,36 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) if( Block_Include_Modules ) { bool Show_Ratsnest_tmp = g_Show_Ratsnest; g_Show_Ratsnest = false; - Affiche_Message( _( "Move footprints" ) ); module = m_Pcb->m_Modules; oldpos = GetScreen()->m_Curseur; for( ; module != NULL; module = (MODULE*) module->Pnext ) { - if( IsModuleInBox( GetScreen()->BlockLocate, module ) == NULL ) + if( ! module->HitTest( GetScreen()->BlockLocate ) ) continue; /* le module est ici bon a etre deplace */ m_Pcb->m_Status_Pcb = 0; module->m_Flags = 0; - module->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); - - /* calcul du deplacement pour la routine Place_Module */ - /* calcul du vecteur de deplacement */ - GetScreen()->m_Curseur.x = module->m_Pos.x + GetScreen()->BlockLocate.m_MoveVector.x; - GetScreen()->m_Curseur.y = module->m_Pos.y + GetScreen()->BlockLocate.m_MoveVector.y; - Place_Module( module, DC ); + GetScreen()->m_Curseur = module->m_Pos + MoveVector; + Place_Module( module, NULL ); } GetScreen()->m_Curseur = oldpos; g_Show_Ratsnest = Show_Ratsnest_tmp; } - /* calcul du vecteur de deplacement pour les deplacements suivants */ - deltaX = GetScreen()->BlockLocate.m_MoveVector.x; - deltaY = GetScreen()->BlockLocate.m_MoveVector.y; - /* Deplacement des Segments de piste */ if( Block_Include_Tracks ) { TRACK* track; - - Affiche_Message( _( "Move tracks" ) ); track = m_Pcb->m_Track; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ m_Pcb->m_Status_Pcb = 0; - track->Draw( DrawPanel, DC, GR_XOR ); // effacement - track->m_Start.x += deltaX; track->m_Start.y += deltaY; - track->m_End.x += deltaX; track->m_End.y += deltaY; - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage + track->m_Start += MoveVector; + track->m_End += MoveVector; } track = (TRACK*) track->Pnext; } @@ -1100,20 +1002,23 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) if( Block_Include_Zones ) { TRACK* track; - - Affiche_Message( _( "Move zones" ) ); - track = (TRACK*) m_Pcb->m_Zone; + track = (TRACK*) m_Pcb->m_Zone; while( track ) { - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ - track->Draw( DrawPanel, DC, GR_XOR ); // effacement - track->m_Start.x += deltaX; track->m_Start.y += deltaY; - track->m_End.x += deltaX; track->m_End.y += deltaY; - track->Draw( DrawPanel, DC, GR_OR ); // reaffichage + track->m_Start += MoveVector; + track->m_End += MoveVector; } track = (TRACK*) track->Pnext; } + for ( unsigned ii = 0; ii < m_Pcb->m_ZoneDescriptorList.size(); ii++ ) + { + if( m_Pcb->m_ZoneDescriptorList[ii]->HitTest( GetScreen()->BlockLocate ) ) + { + m_Pcb->m_ZoneDescriptorList[ii]->Move( MoveVector ); + } + } } masque_layer = EDGE_LAYER; @@ -1122,7 +1027,6 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) if( !Block_Include_Edges_Items ) masque_layer &= ~EDGE_LAYER; - Affiche_Message( _( "Move draw layers" ) ); PtStruct = m_Pcb->m_Drawings; for( ; PtStruct != NULL; PtStruct = PtStruct->Pnext ) { @@ -1133,13 +1037,11 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) #define STRUCT ( (DRAWSEGMENT*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ - Trace_DrawSegmentPcb( DrawPanel, DC, STRUCT, GR_XOR ); - STRUCT->m_Start.x += deltaX; STRUCT->m_Start.y += deltaY; - STRUCT->m_End.x += deltaX; STRUCT->m_End.y += deltaY; - Trace_DrawSegmentPcb( DrawPanel, DC, STRUCT, GR_OR ); + STRUCT->m_Start += MoveVector; + STRUCT->m_End += MoveVector; break; case TYPETEXTE: @@ -1147,13 +1049,11 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) #define STRUCT ( (TEXTE_PCB*) PtStruct ) if( !Block_Include_PcbTextes ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* le texte est ici bon a etre deplace */ - STRUCT->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); /* Redessin du Texte */ - STRUCT->m_Pos.x += deltaX; STRUCT->m_Pos.y += deltaY; - ( (TEXTE_PCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + STRUCT->m_Pos += MoveVector; break; case TYPEMIRE: @@ -1161,12 +1061,10 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) #define STRUCT ( (MIREPCB*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - STRUCT->m_Pos.x += deltaX; STRUCT->m_Pos.y += deltaY; - ( (MIREPCB*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + STRUCT->m_Pos += MoveVector; break; case TYPECOTATION: @@ -1174,29 +1072,10 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) #define STRUCT ( (COTATION*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_XOR ); - STRUCT->m_Pos.x += deltaX; - STRUCT->m_Pos.y += deltaY; - STRUCT->m_Text->m_Pos.x += deltaX; - STRUCT->m_Text->m_Pos.y += deltaY; - STRUCT->Barre_ox += deltaX; STRUCT->Barre_oy += deltaY; - STRUCT->Barre_fx += deltaX; STRUCT->Barre_fy += deltaY; - STRUCT->TraitG_ox += deltaX; STRUCT->TraitG_oy += deltaY; - STRUCT->TraitG_fx += deltaX; STRUCT->TraitG_fy += deltaY; - STRUCT->TraitD_ox += deltaX; STRUCT->TraitD_oy += deltaY; - STRUCT->TraitD_fx += deltaX; STRUCT->TraitD_fy += deltaY; - STRUCT->FlecheG1_ox += deltaX; STRUCT->FlecheG1_oy += deltaY; - STRUCT->FlecheG1_fx += deltaX; STRUCT->FlecheG1_fy += deltaY; - STRUCT->FlecheG2_ox += deltaX; STRUCT->FlecheG2_oy += deltaY; - STRUCT->FlecheG2_fx += deltaX; STRUCT->FlecheG2_fy += deltaY; - STRUCT->FlecheD1_ox += deltaX; STRUCT->FlecheD1_oy += deltaY; - STRUCT->FlecheD1_fx += deltaX; STRUCT->FlecheD1_fy += deltaY; - STRUCT->FlecheD2_ox += deltaX; STRUCT->FlecheD2_oy += deltaY; - STRUCT->FlecheD2_fx += deltaX; STRUCT->FlecheD2_fy += deltaY; - ( (COTATION*) PtStruct )->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + ( (COTATION*) PtStruct )->Move( wxPoint(MoveVector) ); break; default: @@ -1204,7 +1083,7 @@ void WinEDA_BasePcbFrame::Block_Move( wxDC* DC ) } } - DrawPanel->Refresh( TRUE );; + DrawPanel->Refresh( TRUE ); if( g_Show_Ratsnest ) Compile_Ratsnest( DC, TRUE ); } @@ -1221,8 +1100,8 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) MODULE* module; EDA_BaseStruct* PtStruct; int masque_layer; - int deltaX, deltaY; wxPoint oldpos; + wxPoint MoveVector = GetScreen()->BlockLocate.m_MoveVector; oldpos = GetScreen()->m_Curseur; DrawPanel->ManageCurseur = NULL; @@ -1238,15 +1117,15 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) /* Module copy */ if( Block_Include_Modules ) { - bool Show_Ratsnest_tmp = g_Show_Ratsnest; g_Show_Ratsnest = false; - Affiche_Message( _( "Module copy" ) ); + bool Show_Ratsnest_tmp = g_Show_Ratsnest; + g_Show_Ratsnest = false; module = m_Pcb->m_Modules; oldpos = GetScreen()->m_Curseur; for( ; module != NULL; module = (MODULE*) module->Pnext ) { MODULE* new_module; - if( IsModuleInBox( GetScreen()->BlockLocate, module ) == NULL ) + if( ! module->HitTest( GetScreen()->BlockLocate ) ) continue; /* le module est ici bon a etre deplace */ m_Pcb->m_Status_Pcb = 0; @@ -1258,10 +1137,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) new_module->Pback = m_Pcb; m_Pcb->m_Modules->Pback = new_module; m_Pcb->m_Modules = new_module; - /* calcul du deplacement pour la routine Place_Module */ - /* calcul du vecteur de deplacement */ - GetScreen()->m_Curseur.x = module->m_Pos.x + GetScreen()->BlockLocate.m_MoveVector.x; - GetScreen()->m_Curseur.y = module->m_Pos.y + GetScreen()->BlockLocate.m_MoveVector.y; + GetScreen()->m_Curseur = module->m_Pos + MoveVector; Place_Module( new_module, DC ); } @@ -1269,56 +1145,59 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) g_Show_Ratsnest = Show_Ratsnest_tmp; } - /* calcul du vecteur de deplacement pour les deplacements suivants */ - deltaX = GetScreen()->BlockLocate.m_MoveVector.x; - deltaY = GetScreen()->BlockLocate.m_MoveVector.y; - /* Deplacement des Segments de piste */ if( Block_Include_Tracks ) { TRACK* track, * next_track, * new_track; - - Affiche_Message( _( "Track copy" ) ); track = m_Pcb->m_Track; while( track ) { next_track = track->Next(); - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( track->HitTest( GetScreen()->BlockLocate ) ) { /* la piste est ici bonne a etre deplacee */ m_Pcb->m_Status_Pcb = 0; new_track = track->Copy(); new_track->Insert( m_Pcb, NULL ); - new_track->m_Start.x += deltaX; new_track->m_Start.y += deltaY; - new_track->m_End.x += deltaX; new_track->m_End.y += deltaY; + new_track->m_Start += MoveVector; + new_track->m_End += MoveVector; new_track->Draw( DrawPanel, DC, GR_OR ); // reaffichage } track = next_track; } } - /* Deplacement des Segments de Zone */ + /* Duplicate Zones */ if( Block_Include_Zones ) { - TRACK* track, * next_track, * new_track; - - Affiche_Message( _( "Zone copy" ) ); - track = (TRACK*) m_Pcb->m_Zone; - while( track ) + SEGZONE* segzone, * new_segzone; + segzone = m_Pcb->m_Zone; + while( segzone ) { - next_track = track->Next(); - if( IsSegmentInBox( GetScreen()->BlockLocate, track ) ) + if( segzone->HitTest( GetScreen()->BlockLocate ) ) { - /* la piste est ici bonne a etre deplacee */ - new_track = new TRACK( m_Pcb ); - new_track = track->Copy(); - new_track->Insert( m_Pcb, NULL ); - new_track->m_Start.x += deltaX; new_track->m_Start.y += deltaY; - new_track->m_End.x += deltaX; new_track->m_End.y += deltaY; - new_track->Draw( DrawPanel, DC, GR_OR ); // reaffichage + /* la piste est ici bonne a etre dupliquee */ + new_segzone = (SEGZONE*) segzone->Copy(); + new_segzone->Insert( m_Pcb, NULL ); + new_segzone->m_Start += MoveVector; + new_segzone->m_End += MoveVector; + new_segzone->Draw( DrawPanel, DC, GR_OR ); // reaffichage } - track = next_track; + segzone = segzone->Next(); } + + unsigned imax = m_Pcb->m_ZoneDescriptorList.size(); + for ( unsigned ii = 0; ii < imax; ii++ ) + { + if( m_Pcb->m_ZoneDescriptorList[ii]->HitTest( GetScreen()->BlockLocate ) ) + { + ZONE_CONTAINER * new_zone = new ZONE_CONTAINER(m_Pcb); + new_zone->Copy( m_Pcb->m_ZoneDescriptorList[ii] ); + new_zone->Move( MoveVector ); + m_Pcb->m_ZoneDescriptorList.push_back(new_zone); + new_zone->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); + } + } } masque_layer = EDGE_LAYER; @@ -1327,7 +1206,6 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) if( !Block_Include_Edges_Items ) masque_layer &= ~EDGE_LAYER; - Affiche_Message( _( "Draw layers copy" ) ); PtStruct = m_Pcb->m_Drawings; for( ; PtStruct != NULL; PtStruct = PtStruct->Pnext ) { @@ -1339,7 +1217,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) #define STRUCT ( (DRAWSEGMENT*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre copie */ @@ -1350,8 +1228,8 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) new_drawsegment->Pback = m_Pcb; m_Pcb->m_Drawings->Pback = new_drawsegment; m_Pcb->m_Drawings = new_drawsegment; - new_drawsegment->m_Start.x += deltaX; new_drawsegment->m_Start.y += deltaY; - new_drawsegment->m_End.x += deltaX; new_drawsegment->m_End.y += deltaY; + new_drawsegment->m_Start += MoveVector; + new_drawsegment->m_End += MoveVector; Trace_DrawSegmentPcb( DrawPanel, DC, new_drawsegment, GR_OR ); break; } @@ -1362,7 +1240,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) #define STRUCT ( (TEXTE_PCB*) PtStruct ) if( !Block_Include_PcbTextes ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* le texte est ici bon a etre deplace */ TEXTE_PCB* new_pcbtext = new TEXTE_PCB( m_Pcb ); @@ -1372,7 +1250,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) m_Pcb->m_Drawings->Pback = new_pcbtext; m_Pcb->m_Drawings = new_pcbtext; /* Redessin du Texte */ - new_pcbtext->m_Pos.x += deltaX; new_pcbtext->m_Pos.y += deltaY; + new_pcbtext->m_Pos += MoveVector; new_pcbtext->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; } @@ -1383,7 +1261,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) #define STRUCT ( (MIREPCB*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre efface */ MIREPCB* new_mire = new MIREPCB( m_Pcb ); @@ -1392,7 +1270,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) new_mire->Pback = m_Pcb; m_Pcb->m_Drawings->Pback = new_mire; m_Pcb->m_Drawings = new_mire; - new_mire->m_Pos.x += deltaX; new_mire->m_Pos.y += deltaY; + new_mire->m_Pos += MoveVector; new_mire->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; } @@ -1403,7 +1281,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) #define STRUCT ( (COTATION*) PtStruct ) if( (g_TabOneLayerMask[STRUCT->GetLayer()] & masque_layer) == 0 ) break; - if( IsStructInBox( GetScreen()->BlockLocate, PtStruct ) == NULL ) + if( ! PtStruct->HitTest( GetScreen()->BlockLocate ) ) break; /* l'element est ici bon a etre copie */ COTATION* new_cotation = new COTATION( m_Pcb ); @@ -1412,24 +1290,7 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) new_cotation->Pback = m_Pcb; m_Pcb->m_Drawings->Pback = new_cotation; m_Pcb->m_Drawings = new_cotation; - new_cotation->m_Pos.x += deltaX; - new_cotation->m_Pos.y += deltaY; - new_cotation->m_Text->m_Pos.x += deltaX; - new_cotation->m_Text->m_Pos.y += deltaY; - new_cotation->Barre_ox += deltaX; new_cotation->Barre_oy += deltaY; - new_cotation->Barre_fx += deltaX; new_cotation->Barre_fy += deltaY; - new_cotation->TraitG_ox += deltaX; new_cotation->TraitG_oy += deltaY; - new_cotation->TraitG_fx += deltaX; new_cotation->TraitG_fy += deltaY; - new_cotation->TraitD_ox += deltaX; new_cotation->TraitD_oy += deltaY; - new_cotation->TraitD_fx += deltaX; new_cotation->TraitD_fy += deltaY; - new_cotation->FlecheG1_ox += deltaX; new_cotation->FlecheG1_oy += deltaY; - new_cotation->FlecheG1_fx += deltaX; new_cotation->FlecheG1_fy += deltaY; - new_cotation->FlecheG2_ox += deltaX; new_cotation->FlecheG2_oy += deltaY; - new_cotation->FlecheG2_fx += deltaX; new_cotation->FlecheG2_fy += deltaY; - new_cotation->FlecheD1_ox += deltaX; new_cotation->FlecheD1_oy += deltaY; - new_cotation->FlecheD1_fx += deltaX; new_cotation->FlecheD1_fy += deltaY; - new_cotation->FlecheD2_ox += deltaX; new_cotation->FlecheD2_oy += deltaY; - new_cotation->FlecheD2_fx += deltaX; new_cotation->FlecheD2_fy += deltaY; + new_cotation->Move( MoveVector ); new_cotation->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR ); break; } @@ -1439,98 +1300,3 @@ void WinEDA_BasePcbFrame::Block_Duplicate( wxDC* DC ) } } } - - -/*******************************************************************/ -static EDA_BaseStruct* IsStructInBox( DrawBlockStruct& blocklocate, - EDA_BaseStruct* PtStruct ) -/******************************************************************/ - -/* Teste si la structure PtStruct est inscrite dans le block selectionne - */ -{ - switch( PtStruct->Type() ) - { - case TYPEDRAWSEGMENT: - #undef STRUCT - #define STRUCT ( (DRAWSEGMENT*) PtStruct ) - if( !blocklocate.Inside( STRUCT->m_Start.x, STRUCT->m_Start.y ) ) - return NULL; - if( !blocklocate.Inside( STRUCT->m_End.x, STRUCT->m_End.y ) ) - return NULL; - return PtStruct; - - case TYPETEXTE: - #undef STRUCT - #define STRUCT ( (TEXTE_PCB*) PtStruct ) - if( !blocklocate.Inside( STRUCT->m_Pos.x, STRUCT->m_Pos.y ) ) - return NULL; - return PtStruct; - - case TYPEMIRE: - #undef STRUCT - #define STRUCT ( (MIREPCB*) PtStruct ) - if( !blocklocate.Inside( STRUCT->m_Pos.x, STRUCT->m_Pos.y ) ) - return NULL; - return PtStruct; - - case TYPECOTATION: - #undef STRUCT - #define STRUCT ( (COTATION*) PtStruct ) - if( !blocklocate.Inside( STRUCT->m_Pos.x, STRUCT->m_Pos.y ) ) - return NULL; - return PtStruct; - - default: - return NULL; - } - - return NULL; -} - - -/**************************************************************************/ -static TRACK* IsSegmentInBox( DrawBlockStruct& blocklocate, TRACK* PtSegm ) -/**************************************************************************/ - -/* Teste si la structure PtStruct est inscrite dans le block selectionne - * Retourne PtSegm si oui - * NULL si non - */ -{ - if( blocklocate.Inside( PtSegm->m_Start.x, PtSegm->m_Start.y ) ) - return PtSegm; - - if( blocklocate.Inside( PtSegm->m_End.x, PtSegm->m_End.y ) ) - return PtSegm; - - return NULL; -} - - -/****************************************************************************/ -static MODULE* IsModuleInBox( DrawBlockStruct& blocklocate, MODULE* Module ) -/****************************************************************************/ - -/* Teste si le Module est inscrit dans le block selectionne - * Retourne Module si oui - * NULL si non - */ -{ - bool is_out_of_box = FALSE; - - Module->SetRectangleExinscrit(); - - if( Module->m_RealBoundaryBox.m_Pos.x < blocklocate.GetX() ) - is_out_of_box = TRUE; - if( Module->m_RealBoundaryBox.m_Pos.y < blocklocate.GetY() ) - is_out_of_box = TRUE; - if( Module->m_RealBoundaryBox.GetRight() > blocklocate.GetRight() ) - is_out_of_box = TRUE; - if( Module->m_RealBoundaryBox.GetBottom() > blocklocate.GetBottom() ) - is_out_of_box = TRUE; - - if( is_out_of_box ) - return NULL; - return Module; -} diff --git a/pcbnew/class_board.h b/pcbnew/class_board.h index 1acd983a91..cd2210326c 100644 --- a/pcbnew/class_board.h +++ b/pcbnew/class_board.h @@ -18,11 +18,11 @@ class BOARD : public BOARD_ITEM friend class WinEDA_PcbFrame; private: - std::vector m_markers; ///< MARKERs for clearance problems, owned by pointer - std::vector m_ZoneDescriptorList; ///< edge zone descriptors, owned by pointer - +public: + std::vector m_ZoneDescriptorList; ///< edge zone descriptors, owned by pointer + public: WinEDA_BasePcbFrame* m_PcbFrame; // Window de visualisation EDA_Rect m_BoundaryBox; // Board size and position diff --git a/pcbnew/class_cotation.cpp b/pcbnew/class_cotation.cpp index 255c2c64f8..e6e4154090 100644 --- a/pcbnew/class_cotation.cpp +++ b/pcbnew/class_cotation.cpp @@ -226,70 +226,109 @@ bool COTATION::ReadCotationDescr( FILE* File, int* LineNum ) return FALSE; } - -#if 0 -/**************************************************/ -bool COTATION::WriteCotationDescr( FILE* File ) -/**************************************************/ +/****************************************/ +void COTATION::Move(const wxPoint& offset) +/****************************************/ +/** + * Function Move + * @param offset : moving vector + */ { - if( GetState( DELETED ) ) - return FALSE; - - fprintf( File, "$COTATION\n" ); - - fprintf( File, "Ge %d %d %lX\n", m_Shape, - m_Layer, m_TimeStamp ); - - fprintf( File, "Va %d\n", m_Value ); - - if( !m_Text->m_Text.IsEmpty() ) - fprintf( File, "Te \"%s\"\n", CONV_TO_UTF8( m_Text->m_Text ) ); - else - fprintf( File, "Te \"?\"\n" ); - - fprintf( File, "Po %d %d %d %d %d %d %d\n", - m_Text->m_Pos.x, m_Text->m_Pos.y, - m_Text->m_Size.x, m_Text->m_Size.y, - m_Text->m_Width, m_Text->m_Orient, - m_Text->m_Miroir ); - - fprintf( File, "Sb %d %d %d %d %d %d\n", S_SEGMENT, - Barre_ox, Barre_oy, - Barre_fx, Barre_fy, m_Width ); - - fprintf( File, "Sd %d %d %d %d %d %d\n", S_SEGMENT, - TraitD_ox, TraitD_oy, - TraitD_fx, TraitD_fy, m_Width ); - - fprintf( File, "Sg %d %d %d %d %d %d\n", S_SEGMENT, - TraitG_ox, TraitG_oy, - TraitG_fx, TraitG_fy, m_Width ); - - fprintf( File, "S1 %d %d %d %d %d %d\n", S_SEGMENT, - FlecheD1_ox, FlecheD1_oy, - FlecheD1_fx, FlecheD1_fy, m_Width ); - - fprintf( File, "S2 %d %d %d %d %d %d\n", S_SEGMENT, - FlecheD2_ox, FlecheD2_oy, - FlecheD2_fx, FlecheD2_fy, m_Width ); - - - fprintf( File, "S3 %d %d %d %d %d %d\n", S_SEGMENT, - FlecheG1_ox, FlecheG1_oy, - FlecheG1_fx, FlecheG1_fy, m_Width ); - - fprintf( File, "S4 %d %d %d %d %d %d\n", S_SEGMENT, - FlecheG2_ox, FlecheG2_oy, - FlecheG2_fx, FlecheG2_fy, m_Width ); - - fprintf( File, "$EndCOTATION\n" ); - - return 1; + m_Pos += offset; + m_Text->m_Pos += offset; + Barre_ox += offset.x; Barre_oy += offset.y; + Barre_fx += offset.x; Barre_fy += offset.y; + TraitG_ox += offset.x; TraitG_oy += offset.y; + TraitG_fx += offset.x; TraitG_fy += offset.y; + TraitD_ox += offset.x; TraitD_oy += offset.y; + TraitD_fx += offset.x; TraitD_fy += offset.y; + FlecheG1_ox += offset.x; FlecheG1_oy += offset.y; + FlecheG1_fx += offset.x; FlecheG1_fy += offset.y; + FlecheG2_ox += offset.x; FlecheG2_oy += offset.y; + FlecheG2_fx += offset.x; FlecheG2_fy += offset.y; + FlecheD1_ox += offset.x; FlecheD1_oy += offset.y; + FlecheD1_fx += offset.x; FlecheD1_fy += offset.y; + FlecheD2_ox += offset.x; FlecheD2_oy += offset.y; + FlecheD2_fx += offset.x; FlecheD2_fy += offset.y; } -#endif +/******************************************************/ +void COTATION::Rotate(const wxPoint& centre, int angle) +/******************************************************/ +/** + * Function Rotate + * @param offset : Rotation point + * @param angle : Rotation angle in 0.1 degrees + */ +{ + RotatePoint( &m_Pos, centre, 900 ); + + RotatePoint( &m_Text->m_Pos, centre, 900 ); + m_Text->m_Orient += 900; + if( m_Text->m_Orient >= 3600 ) + m_Text->m_Orient -= 3600; + if( (m_Text->m_Orient > 900) + && (m_Text->m_Orient <2700) ) + m_Text->m_Orient -= 1800; + + RotatePoint( &Barre_ox, &Barre_oy, centre.x, centre.y, 900 ); + RotatePoint( &Barre_fx, &Barre_fy, centre.x, centre.y, 900 ); + RotatePoint( &TraitG_ox, &TraitG_oy, centre.x, centre.y, 900 ); + RotatePoint( &TraitG_fx, &TraitG_fy, centre.x, centre.y, 900 ); + RotatePoint( &TraitD_ox, &TraitD_oy, centre.x, centre.y, 900 ); + RotatePoint( &TraitD_fx, &TraitD_fy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheG1_ox, &FlecheG1_oy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheG1_fx, &FlecheG1_fy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheG2_ox, &FlecheG2_oy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheG2_fx, &FlecheG2_fy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheD1_ox, &FlecheD1_oy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheD1_fx, &FlecheD1_fy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheD2_ox, &FlecheD2_oy, centre.x, centre.y, 900 ); + RotatePoint( &FlecheD2_fx, &FlecheD2_fy, centre.x, centre.y, 900 ); +} + + +/**********************************************/ +void COTATION::Mirror(const wxPoint& axis_pos) +/**********************************************/ +/** + * Function Mirror + * Mirror the Dimension , relative to a given horizontal axis + * the text is not mirrored. only its position (and angle) is mirrored + * the layer is not changed + * @param axis_pos : vertical axis position + */ +{ +#define INVERT( pos ) (pos) = axis_pos.y - ( (pos) - axis_pos.y ) +#define INVERT_ANGLE( phi ) (phi) = -(phi) + INVERT( m_Pos.y ); + INVERT( m_Text->m_Pos.y ); + INVERT_ANGLE( m_Text->m_Orient ); + if( m_Text->m_Orient >= 3600 ) + m_Text->m_Orient -= 3600; + if( (m_Text->m_Orient > 900) && (m_Text->m_Orient <2700) ) + m_Text->m_Orient -= 1800; + + INVERT( Barre_oy ); + INVERT( Barre_fy ); + INVERT( TraitG_oy ); + INVERT( TraitG_fy ); + INVERT( TraitD_oy ); + INVERT( TraitD_fy ); + INVERT( FlecheG1_oy ); + INVERT( FlecheG1_fy ); + INVERT( FlecheG2_oy ); + INVERT( FlecheG2_fy ); + INVERT( FlecheD1_oy ); + INVERT( FlecheD1_fy ); + INVERT( FlecheD2_oy ); + INVERT( FlecheD2_fy ); +} + +/****************************************/ bool COTATION::Save( FILE* aFile ) const +/****************************************/ { if( GetState( DELETED ) ) return true; @@ -571,3 +610,15 @@ bool COTATION::HitTest( const wxPoint& ref_pos ) return false; } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * @param EDA_Rect : the given EDA_Rect + * @return bool - true if a hit, else false + */ +bool COTATION::HitTest( EDA_Rect& refArea ) +{ + if( refArea.Inside( m_Pos ) ) + return true; + return false; +} diff --git a/pcbnew/class_cotation.h b/pcbnew/class_cotation.h index 2af1ae90b9..6524b6379b 100644 --- a/pcbnew/class_cotation.h +++ b/pcbnew/class_cotation.h @@ -54,8 +54,29 @@ public: void Copy( COTATION* source ); void Draw( WinEDA_DrawPanel* panel, wxDC* DC, const wxPoint& offset, int mode_color ); + + /** + * Function Move + * @param offset : moving vector + */ + void Move(const wxPoint& offset); + + /** + * Function Rotate + * @param offset : Rotation point + * @param angle : Rotation angle in 0.1 degrees + */ + void Rotate(const wxPoint& centre, int angle); + + /** + * Function Mirror + * Mirror the Dimension , relative to a given horizontal axis + * the text is not mirrored. only its position (and angle) is mirrored + * the layer is not changed + * @param axis_pos : vertical axis position + */ + void Mirror(const wxPoint& axis_pos); - /** * Function Display_Infos * has knowledge about the frame and how and where to put status information @@ -73,6 +94,15 @@ public: */ bool HitTest( const wxPoint& ref_pos ); + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, the anchor must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + /** * Function GetClass diff --git a/pcbnew/class_mire.cpp b/pcbnew/class_mire.cpp index 672a1a12ba..24c1d74a3d 100644 --- a/pcbnew/class_mire.cpp +++ b/pcbnew/class_mire.cpp @@ -219,3 +219,16 @@ bool MIREPCB::HitTest( const wxPoint& refPos ) return abs(dX)<=rayon && abs(dY)<=rayon; } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * @param EDA_Rect : the given EDA_Rect + * @return bool - true if a hit, else false + */ +bool MIREPCB::HitTest( EDA_Rect& refArea ) +{ + if( refArea.Inside( m_Pos ) ) + return true; + return false; +} + diff --git a/pcbnew/class_mire.h b/pcbnew/class_mire.h index 1103d1cbbd..aab58a7889 100644 --- a/pcbnew/class_mire.h +++ b/pcbnew/class_mire.h @@ -50,6 +50,16 @@ public: * @return bool - true if a hit, else false */ bool HitTest( const wxPoint& refPos ); + + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, the anchor must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + }; diff --git a/pcbnew/class_module.cpp b/pcbnew/class_module.cpp index 58e5dabc4f..548baf2695 100644 --- a/pcbnew/class_module.cpp +++ b/pcbnew/class_module.cpp @@ -1284,6 +1284,31 @@ bool MODULE::HitTest( const wxPoint& refPos ) } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect the bounds of this object. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ +bool MODULE::HitTest( EDA_Rect& refArea ) +{ + bool is_out_of_box = false; + + SetRectangleExinscrit(); + + if( m_RealBoundaryBox.m_Pos.x < refArea.GetX() ) + is_out_of_box = true; + if( m_RealBoundaryBox.m_Pos.y < refArea.GetY() ) + is_out_of_box = true; + if( m_RealBoundaryBox.GetRight() > refArea.GetRight() ) + is_out_of_box = true; + if( m_RealBoundaryBox.GetBottom() > refArea.GetBottom() ) + is_out_of_box = true; + + return is_out_of_box ? false : true; +} + + // see class_module.h SEARCH_RESULT MODULE::Visit( INSPECTOR* inspector, const void* testData, const KICAD_T scanTypes[] ) diff --git a/pcbnew/class_module.h b/pcbnew/class_module.h index 1e5c4e8c5d..545956ecf9 100644 --- a/pcbnew/class_module.h +++ b/pcbnew/class_module.h @@ -170,6 +170,14 @@ public: /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect the bounds of this object. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + + /** * Function GetReference * @return wxString - the reference designator text. */ diff --git a/pcbnew/class_pcb_text.cpp b/pcbnew/class_pcb_text.cpp index 32f820b84d..ac7fa95e90 100644 --- a/pcbnew/class_pcb_text.cpp +++ b/pcbnew/class_pcb_text.cpp @@ -112,27 +112,6 @@ int TEXTE_PCB::ReadTextePcbDescr( FILE* File, int* LineNum ) } -#if 0 // replaced by Save() -/**************************************************/ -int TEXTE_PCB::WriteTextePcbDescr( FILE* File ) -/**************************************************/ -{ - if( GetState( DELETED ) ) - return 0; - - if( m_Text.IsEmpty() ) - return 0; - fprintf( File, "$TEXTPCB\n" ); - fprintf( File, "Te \"%s\"\n", CONV_TO_UTF8( m_Text ) ); - fprintf( File, "Po %d %d %d %d %d %d\n", - m_Pos.x, m_Pos.y, m_Size.x, m_Size.y, m_Width, m_Orient ); - fprintf( File, "De %d %d %lX %d\n", m_Layer, m_Miroir, m_TimeStamp, 0 ); - fprintf( File, "$EndTEXTPCB\n" ); - return 1; -} -#endif - - bool TEXTE_PCB::Save( FILE* aFile ) const { if( GetState( DELETED ) ) diff --git a/pcbnew/class_pcb_text.h b/pcbnew/class_pcb_text.h index 66a4ba0b4d..80567150aa 100644 --- a/pcbnew/class_pcb_text.h +++ b/pcbnew/class_pcb_text.h @@ -68,6 +68,17 @@ public: } + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * @param refArea the given EDA_Rect to test + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ) + { + return EDA_TextStruct::HitTest( refArea ); + } + /** * Function GetClass * returns the class name. diff --git a/pcbnew/class_track.cpp b/pcbnew/class_track.cpp index 080d07620d..f62a9a0fd4 100644 --- a/pcbnew/class_track.cpp +++ b/pcbnew/class_track.cpp @@ -875,6 +875,22 @@ bool TRACK::HitTest( const wxPoint& ref_pos ) return false; } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, an ending point must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool TRACK::HitTest( EDA_Rect& refArea ) +{ + if( refArea.Inside( m_Start ) ) + return true; + if( refArea.Inside( m_End ) ) + return true; + return false; +} + #if defined (DEBUG) diff --git a/pcbnew/class_track.h b/pcbnew/class_track.h index e5b681f254..8a4bfd1c9d 100644 --- a/pcbnew/class_track.h +++ b/pcbnew/class_track.h @@ -201,6 +201,15 @@ public: bool HitTest( const wxPoint& refPos ); /** + * Function HitTest (overlayed) + * tests if the given wxRect intersect this object. + * For now, an ending point must be inside this rect. + * @param refPos A wxPoint to test + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + + /** * Function GetClass * returns the class name. * @return wxString diff --git a/pcbnew/class_zone.cpp b/pcbnew/class_zone.cpp index 053c76b760..4585f936a1 100644 --- a/pcbnew/class_zone.cpp +++ b/pcbnew/class_zone.cpp @@ -10,6 +10,7 @@ #include "common.h" #include "PolyLine.h" #include "pcbnew.h" +#include "trigo.h" /**********************/ /* Class EDGE_ZONE */ @@ -51,7 +52,7 @@ ZONE_CONTAINER::ZONE_CONTAINER( BOARD* parent ) : m_PadOption = THERMAL_PAD; utility = 0; // flags used in polygon calculations utility2 = 0; // flags used in polygon calculations - m_Poly = new CPolyLine( NULL ); // Outlines + m_Poly = new CPolyLine(); // Outlines } @@ -403,6 +404,29 @@ int ZONE_CONTAINER::HitTestForEdge( const wxPoint& refPos ) return -1; } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect contains the bounds of this object. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ +bool ZONE_CONTAINER::HitTest( EDA_Rect& refArea ) +{ + bool is_out_of_box = false; + + CRect rect = m_Poly->GetCornerBounds(); + + if( rect.left < refArea.GetX() ) + is_out_of_box = true; + if( rect.top < refArea.GetY() ) + is_out_of_box = true; + if( rect.right > refArea.GetRight() ) + is_out_of_box = true; + if( rect.bottom > refArea.GetBottom() ) + is_out_of_box = true; + + return is_out_of_box ? false : true; +} /************************************************************/ void ZONE_CONTAINER::Display_Infos( WinEDA_DrawFrame* frame ) @@ -448,3 +472,79 @@ void ZONE_CONTAINER::Display_Infos( WinEDA_DrawFrame* frame ) msg.Printf( wxT( "%d" ), m_Poly->m_HatchLines.size() ); Affiche_1_Parametre( frame, text_pos, _( "Hatch lines" ), msg, BLUE ); } + + +/* Geometric transformations: */ +/** + * Function Move + * Move the outlines + * @param offset = moving vector + */ +void ZONE_CONTAINER::Move(const wxPoint& offset ) +{ + for ( unsigned ii = 0; ii < m_Poly->corner.size(); ii++ ) + { + m_Poly->corner[ii].x += offset.x; + m_Poly->corner[ii].y += offset.y; + } + m_Poly->Hatch(); +} + +/** + * Function Move + * Move the outlines + * @param centre = rot centre + * @param angle = in 0.1 degree + */ +void ZONE_CONTAINER::Rotate( const wxPoint& centre, int angle) +{ + for ( unsigned ii = 0; ii < m_Poly->corner.size(); ii++ ) + { + wxPoint pos; + pos.x = m_Poly->corner[ii].x; + pos.y = m_Poly->corner[ii].y; + RotatePoint(&pos, centre, angle ); + m_Poly->corner[ii].x = pos.x; + m_Poly->corner[ii].y = pos.y; + } + + m_Poly->Hatch(); +} + + +/** + * Function Mirror + * flip the outlines , relative to a given horizontal axis + * @param mirror_ref = vertical axis position + */ +void ZONE_CONTAINER::Mirror( const wxPoint& mirror_ref) +{ + for ( unsigned ii = 0; ii < m_Poly->corner.size(); ii++ ) + { + m_Poly->corner[ii].y -= mirror_ref.y; + m_Poly->corner[ii].y = - m_Poly->corner[ii].y; + m_Poly->corner[ii].y += mirror_ref.y; + } + m_Poly->Hatch(); +} + + +/** Function copy + * copy data from the source. + * flags and some poinetrs are NOT copied + */ +void ZONE_CONTAINER::Copy( ZONE_CONTAINER * src ) +{ + m_Parent = src->m_Parent; + m_Layer = src->m_Layer; + SetNet(src->GetNet()); + m_TimeStamp = GetTimeStamp(); + m_Poly->Copy(src->m_Poly); // copy outlines + m_CornerSelection = -1; // For corner moving, corner index to drag, or -1 if no selection + m_ZoneClearance = src->m_ZoneClearance; // clearance value + m_GridFillValue = src->m_GridFillValue; // Grid used for filling + m_PadOption = src->m_PadOption; + m_Poly->SetHatch(src->m_Poly->GetHatchStyle()); +} + + diff --git a/pcbnew/class_zone.h b/pcbnew/class_zone.h index 1e22dbfd97..9f5908a2ff 100644 --- a/pcbnew/class_zone.h +++ b/pcbnew/class_zone.h @@ -44,6 +44,12 @@ public: wxPoint & GetPosition( ) { static wxPoint pos ;return pos; } void UnLink(void) {}; + /** Function copy + * copy data from the source. + * flags and some poinetrs are NOT copied + */ + void Copy( ZONE_CONTAINER * src ); + void Display_Infos( WinEDA_DrawFrame* frame ); /** Function Draw @@ -81,6 +87,14 @@ public: */ int HitTestForEdge( const wxPoint& refPos ); + /** + * Function HitTest (overlayed) + * tests if the given EDA_Rect contains the bounds of this object. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool HitTest( EDA_Rect& refArea ); + /** Function Fill_Zone() * Calculate the zone filling * The zone outline is a frontier, and can be complex (with holes) @@ -92,6 +106,32 @@ public: * @return error level (0 = no error) */ int Fill_Zone( WinEDA_PcbFrame* frame, wxDC* DC, bool verbose = TRUE); + + /* Geometric transformations: */ + /** + * Function Move + * Move the outlines + * @param offset = moving vector + */ + void Move(const wxPoint& offset ); + + /** + * Function Move + * Move the outlines + * @param centre = rot centre + * @param angle = in 0.1 degree + */ + void Rotate( const wxPoint& centre, int angle); + + + /** + * Function Mirror + * Mirror the outlines , relative to a given horizontal axis + * the layer is not changed + * @param mirror_ref = vertical axis position + */ + void Mirror( const wxPoint& mirror_ref); + }; /*******************/ diff --git a/pcbnew/classpcb.cpp b/pcbnew/classpcb.cpp index c1df8afcf3..b55fbcd522 100644 --- a/pcbnew/classpcb.cpp +++ b/pcbnew/classpcb.cpp @@ -85,27 +85,6 @@ void DRAWSEGMENT::Copy( DRAWSEGMENT* source ) m_TimeStamp = source->m_TimeStamp; } -#if 0 // replaced by Save() -/********************************************************/ -bool DRAWSEGMENT::WriteDrawSegmentDescr( FILE* File ) -/********************************************************/ -{ - if( GetState( DELETED ) ) - return FALSE; - - fprintf( File, "$DRAWSEGMENT\n" ); - fprintf( File, "Po %d %d %d %d %d %d\n", - m_Shape, - m_Start.x, m_Start.y, - m_End.x, m_End.y, m_Width ); - fprintf( File, "De %d %d %d %lX %X\n", - m_Layer, m_Type, m_Angle, - m_TimeStamp, ReturnStatus() ); - fprintf( File, "$EndDRAWSEGMENT\n" ); - return TRUE; -} -#endif - bool DRAWSEGMENT::Save( FILE* aFile ) const { @@ -270,6 +249,22 @@ bool DRAWSEGMENT::HitTest( const wxPoint& ref_pos ) } +/** + * Function HitTest (overlayed) + * tests if the given EDA_Rect intersect this object. + * For now, an ending point must be inside this rect. + * @param refArea : the given EDA_Rect + * @return bool - true if a hit, else false + */ + bool DRAWSEGMENT::HitTest( EDA_Rect& refArea ) +{ + if( refArea.Inside( m_Start ) ) + return true; + if( refArea.Inside( m_End ) ) + return true; + return false; +} + /**************************************************/ /* Class SCREEN: classe de gestion d'un affichage */ diff --git a/polygon/CMakeLists.txt b/polygon/CMakeLists.txt index d1517e042f..4e9cd8fa05 100644 --- a/polygon/CMakeLists.txt +++ b/polygon/CMakeLists.txt @@ -1,5 +1,4 @@ SET(POLYGON_SRCS - cdisplaylist_stuff.cpp GenericPolygonClipperLibrary.cpp math_for_graphics.cpp php_polygon.cpp diff --git a/polygon/PolyLine.cpp b/polygon/PolyLine.cpp index b78ef2b420..eb8aab2941 100644 --- a/polygon/PolyLine.cpp +++ b/polygon/PolyLine.cpp @@ -1,10 +1,12 @@ -// PolyLine.cpp ... implementation of CPolyLine class - -// from FreePCB. +// PolyLine.cpp ... implementation of CPolyLine class from FreePCB. +// // Adaptation for kicad // using namespace std; +#define SetSize reserve // used in conversion from freePCB to kicad.: The code using it must be rewitten + + #include #include @@ -12,30 +14,13 @@ using namespace std; #define to_int(x) (int)round((x)) -/* Stuff to compile PolyLine.cpp, used in std::vector as CArray. does not work. must be redesigned, only for test */ -#define SetSize reserve - #define pi 3.14159265359 #define DENOM 10 // to use mils for php clipping //#define DENOM 1 // to use internal units for php clipping -// dl is a pointer to CDisplayList for drawing graphic elements -// if dl = NULL, doesn't draw anything but can still hold data -// -CPolyLine::CPolyLine( CDisplayList * dl ) -{ - m_dlist = dl; - m_HatchStyle = 0; - m_sel_box = 0; - m_gpc_poly = new gpc_polygon; - m_gpc_poly->num_contours = 0; - m_php_poly = new polygon; -} - CPolyLine::CPolyLine() { - m_dlist = NULL; m_HatchStyle = 0; m_sel_box = 0; utility = 0; @@ -496,8 +481,8 @@ int CPolyLine::RestoreArcs( std::vector * arc_array, std::vectorsize(); iarc++ ) { int arc_xi = (*arc_array)[iarc].xi; @@ -804,22 +789,6 @@ void CPolyLine::InsertCorner( int ic, int x, int y ) // void CPolyLine::Undraw() { - if( m_dlist && bDrawn ) - { - // remove display elements, if present - for( unsigned i=0; iRemove( dl_side[i] ); - for( unsigned i=0; iRemove( dl_side_sel[i] ); - for( unsigned i=0; iRemove( dl_corner_sel[i] ); - - // remove pointers - dl_side.clear(); - dl_side_sel.clear(); - dl_corner_sel.clear(); - } - m_HatchLines.clear(); bDrawn = FALSE; } @@ -828,274 +797,18 @@ void CPolyLine::Undraw() // if side style is ARC_CW or ARC_CCW but endpoints are not angled, // convert to STRAIGHT // -void CPolyLine::Draw( CDisplayList * dl ) +void CPolyLine::Draw( ) { // first, undraw if necessary if( bDrawn ) Undraw(); - // use new display list if provided - if( dl ) - m_dlist = dl; - -#if 0 - int i_start_contour = 0; - if( m_dlist ) - { - // set up std::vectors - dl_side.SetSize( corner.size() ); - if( m_sel_box ) - { - dl_side_sel.SetSize( corner.size() ); - dl_corner_sel.SetSize( corner.size() ); - } - else - { - dl_side_sel.clear(); - dl_corner_sel.clear(); - } - // now draw elements - for( int ic=0; icAddSelector( m_id, m_ptr, m_layer, DL_HOLLOW_RECT, - 1, 0, 0, xi-m_sel_box, yi-m_sel_box, - xi+m_sel_box, yi+m_sel_box, 0, 0 ); - } - if( ic<(corner.size()-1) || corner[ic].end_contour ) - { - // draw side - if( xi == xf || yi == yf ) - { - // if endpoints not angled, make side STRAIGHT - side_style[ic] = STRAIGHT; - } - int g_type = DL_LINE; - if( side_style[ic] == STRAIGHT ) - g_type = DL_LINE; - else if( side_style[ic] == ARC_CW ) - g_type = DL_ARC_CW; - else if( side_style[ic] == ARC_CCW ) - g_type = DL_ARC_CCW; - m_id.sst = ID_SIDE; - dl_side[ic] = m_dlist->Add( m_id, m_ptr, m_layer, g_type, - 1, m_w, 0, xi, yi, xf, yf, 0, 0 ); - if( m_sel_box ) - { - m_id.sst = ID_SEL_SIDE; - dl_side_sel[ic] = m_dlist->AddSelector( m_id, m_ptr, m_layer, g_type, - 1, m_w, 0, xi, yi, xf, yf, 0, 0 ); - } - } - } -// if( m_HatchStyle ) -// Hatch(); - } -#endif Hatch(); bDrawn = TRUE; } -// start dragging new corner to be inserted into side, make side and hatching invisible -// -void CPolyLine::StartDraggingToInsertCorner( CDC * pDC, int ic, int x, int y ) -{ - if( !m_dlist ) - ASSERT(0); - - int icont = GetContour( ic ); - int istart = GetContourStart( icont ); - int iend = GetContourEnd( icont ); - int post_c; - - if( ic == iend ) - post_c = istart; - else - post_c = ic + 1; - int xi = corner[ic].x; - int yi = corner[ic].y; - int xf = corner[post_c].x; - int yf = corner[post_c].y; - m_dlist->StartDraggingLineVertex( pDC, x, y, xi, yi, xf, yf, - LAY_SELECTION, LAY_SELECTION, 1, 1, DSS_STRAIGHT, DSS_STRAIGHT, - 0, 0, 0, 0, 1 ); - m_dlist->CancelHighLight(); - m_dlist->Set_visible( dl_side[ic], 0 ); -/* for( int ih=0; ihSet_visible( dl_hatch[ih], 0 ); -*/ -} - -// cancel dragging inserted corner, make side and hatching visible again -// -void CPolyLine::CancelDraggingToInsertCorner( int ic ) -{ - if( !m_dlist ) - ASSERT(0); - - int post_c; - if( ic == (int)(corner.size()-1) ) - post_c = 0; - else - post_c = ic + 1; - m_dlist->StopDragging(); -/* m_dlist->Set_visible( dl_side[ic], 1 ); - for( int ih=0; ihSet_visible( dl_hatch[ih], 1 ); -*/ -} - -// start dragging corner to new position, make adjacent sides and hatching invisible -// -void CPolyLine::StartDraggingToMoveCorner( CDC * pDC, int ic, int x, int y ) -{ - if( !m_dlist ) - ASSERT(0); - - // see if corner is the first or last corner of an open contour - int icont = GetContour( ic ); - int istart = GetContourStart( icont ); - int iend = GetContourEnd( icont ); - if( !GetClosed() - && icont == GetNumContours() - 1 - && (ic == istart || ic == iend) ) - { - // yes - int style, xi, yi, iside; - if( ic == istart ) - { - // first corner - iside = ic; - xi = GetX( ic+1 ); - yi = GetY( ic+1 ); - style = GetSideStyle( iside ); - // reverse arc since we are drawing from corner 1 to 0 - if( style == CPolyLine::ARC_CW ) - style = CPolyLine::ARC_CCW; - else if( style == CPolyLine::ARC_CCW ) - style = CPolyLine::ARC_CW; - } - else - { - // last corner - iside = ic - 1; - xi = GetX( ic-1 ); - yi = GetY( ic-1); - style = GetSideStyle( iside ); - } - m_dlist->StartDraggingArc( pDC, style, GetX(ic), GetY(ic), xi, yi, LAY_SELECTION, 1, 1 ); - m_dlist->CancelHighLight(); - m_dlist->Set_visible( dl_side[iside], 0 ); -/* for( int ih=0; ihSet_visible( dl_hatch[ih], 0 ); -*/ - } - else - { - // no - // get indexes for preceding and following corners - int pre_c, post_c; - int poly_side_style1, poly_side_style2; - int style1 = DSS_STRAIGHT, style2 = DSS_STRAIGHT; - if( ic == istart ) - { - pre_c = iend; - post_c = istart+1; - poly_side_style1 = side_style[iend]; - poly_side_style2 = side_style[istart]; - } - else if( ic == iend ) - { - // last side - pre_c = ic-1; - post_c = istart; - poly_side_style1 = side_style[ic-1]; - poly_side_style2 = side_style[ic]; - } - else - { - pre_c = ic-1; - post_c = ic+1; - poly_side_style1 = side_style[ic-1]; - poly_side_style2 = side_style[ic]; - } - if( poly_side_style1 == STRAIGHT ) - style1 = DSS_STRAIGHT; - else if( poly_side_style1 == ARC_CW ) - style1 = DSS_ARC_CW; - else if( poly_side_style1 == ARC_CCW ) - style1 = DSS_ARC_CCW; - if( poly_side_style2 == STRAIGHT ) - style2 = DSS_STRAIGHT; - else if( poly_side_style2 == ARC_CW ) - style2 = DSS_ARC_CW; - else if( poly_side_style2 == ARC_CCW ) - style2 = DSS_ARC_CCW; - int xi = corner[pre_c].x; - int yi = corner[pre_c].y; - int xf = corner[post_c].x; - int yf = corner[post_c].y; - m_dlist->StartDraggingLineVertex( pDC, x, y, xi, yi, xf, yf, - LAY_SELECTION, LAY_SELECTION, 1, 1, style1, style2, - 0, 0, 0, 0, 1 ); - m_dlist->CancelHighLight(); - m_dlist->Set_visible( dl_side[pre_c], 0 ); - m_dlist->Set_visible( dl_side[ic], 0 ); -/* for( int ih=0; ihSet_visible( dl_hatch[ih], 0 ); -*/ } -} - -// cancel dragging corner to new position, make sides and hatching visible again -// - -// highlight side by drawing line over it -// -void CPolyLine::HighlightSide( int is ) -{ - if( !m_dlist ) - ASSERT(0); - if( GetClosed() && is >= (int)corner.size() ) - return; - if( !GetClosed() && is >= (int)(corner.size()-1) ) - return; - - int style = DL_LINE; - if( side_style[is] == CPolyLine::STRAIGHT ) - style = DL_LINE; - else if( side_style[is] == CPolyLine::ARC_CW ) - style = DL_ARC_CW; - else if( side_style[is] == CPolyLine::ARC_CCW ) - style = DL_ARC_CCW; - m_dlist->HighLight( style, - m_dlist->Get_x( dl_side_sel[is] ), - m_dlist->Get_y( dl_side_sel[is] ), - m_dlist->Get_xf( dl_side_sel[is] ), - m_dlist->Get_yf( dl_side_sel[is] ), - m_dlist->Get_w( dl_side_sel[is]) ); -} - - int CPolyLine::GetX( int ic ) { return corner[ic].x; @@ -1672,16 +1385,13 @@ int CPolyLine::TestIntersection( CPolyLine * poly ) void CPolyLine::Copy( CPolyLine * src ) { Undraw(); - m_dlist = src->m_dlist; - m_sel_box = src->m_sel_box; + // copy corners - for( unsigned i=0; i< src->corner.size(); i++ ) - corner.push_back(src->corner[i]); + for( unsigned ii=0; ii < src->corner.size(); ii++ ) + corner.push_back(src->corner[ii]); // copy side styles - int nsides = src->GetNumSides(); - side_style.SetSize(nsides); - for( int i=0; iside_style[i]; + for( unsigned ii=0; ii < src->side_style.size(); ii++ ) + side_style.push_back(src->side_style[ii]); // don't copy the Gpc_poly, just clear the old one FreeGpcPoly(); } diff --git a/polygon/PolyLine.h b/polygon/PolyLine.h index 24898819f7..35f314356d 100644 --- a/polygon/PolyLine.h +++ b/polygon/PolyLine.h @@ -10,8 +10,6 @@ // // When used for copper areas, the first contour is the outer edge // of the area, subsequent ones are "holes" in the copper. -// -// If a CDisplayList pointer is provided, the polyline can draw itself #ifndef POLYLINE_H #define POLYLINE_H @@ -68,7 +66,7 @@ public: enum { DEF_SIZE = 50, DEF_ADD = 50 }; // number of array elements to add at a time // constructors/destructor - CPolyLine( CDisplayList * dl ); +// CPolyLine( CDisplayList * dl = NULL ); CPolyLine(); ~CPolyLine(); @@ -84,16 +82,16 @@ public: void RemoveAllContours( void ); // drawing functions - void HighlightSide( int is ); +/* void HighlightSide( int is ); void HighlightCorner( int ic ); void StartDraggingToInsertCorner( CDC * pDC, int ic, int x, int y); void StartDraggingToMoveCorner( CDC * pDC, int ic, int x, int y); void CancelDraggingToInsertCorner( int ic ); void CancelDraggingToMoveCorner( int ic ); - void Undraw(); - void Draw( CDisplayList * dl = NULL ); +*/ void Undraw(); + void Draw( ); void Hatch(); - void MakeVisible( bool visible = TRUE ); +// void MakeVisible( bool visible = TRUE ); void MoveOrigin( int x_off, int y_off ); // misc. functions @@ -152,7 +150,7 @@ public: void ClipPhpPolygon( int php_op, CPolyLine * poly ); private: - CDisplayList * m_dlist; // display list +// CDisplayList * m_dlist; // display list int m_layer; // layer to draw on int m_Width; // line width int m_sel_box; // corner selection box width/2 @@ -161,9 +159,9 @@ public: std::vector corner; // array of points for corners std::vector side_style; // array of styles for sides private: - std::vector dl_side; // graphic elements - std::vector dl_side_sel; - std::vector dl_corner_sel; +// std::vector dl_side; // graphic elements +// std::vector dl_side_sel; +// std::vector dl_corner_sel; public: int m_HatchStyle; // hatch style, see enum above std::vector m_HatchLines; // hatch lines diff --git a/polygon/cdisplaylist_stuff.cpp b/polygon/cdisplaylist_stuff.cpp deleted file mode 100644 index 55595cada9..0000000000 --- a/polygon/cdisplaylist_stuff.cpp +++ /dev/null @@ -1,67 +0,0 @@ -/* stuff for class CDisplayList */ - -#include "PolyLine.h" - -void CDisplayList::Set_visible( dl_element * el, int visible ) -{ -} - -int CDisplayList::StopDragging() -{ - return 0; -} - -int CDisplayList::CancelHighLight() -{ - return 0; -} - -id CDisplayList::Remove( dl_element * element ) -{ - return 0; -} - -int CDisplayList::Get_w( dl_element * el ) -{ - return 0; -} - -int CDisplayList::Get_x( dl_element * el ) -{ - return 0; -} -int CDisplayList::Get_y( dl_element * el ) -{ - return 0; -} - -int CDisplayList::Get_xf( dl_element * el ) -{ - return 0; -} -int CDisplayList::Get_yf( dl_element * el ) -{ - return 0; -} - -int CDisplayList::HighLight( int gtype, int x, int y, int xf, int yf, int w, int orig_layer ) -{ - return 0; -} - -int CDisplayList::StartDraggingLineVertex( CDC * pDC, int x, int y, int xi, int yi, - int xf, int yf, - int layer1, int layer2, int w1, int w2, - int style1, int style2, - int layer_no_via, int via_w, int via_holew, int dir, - int crosshair ) -{ - return 0; -} - -int CDisplayList::StartDraggingArc( CDC * pDC, int style, int x, int y, int xi, int yi, - int layer, int w, int crosshair ) -{ - return 0; -} - diff --git a/polygon/freepcbDisplayList.h b/polygon/freepcbDisplayList.h index d2839e92ec..04e7ffdf80 100644 --- a/polygon/freepcbDisplayList.h +++ b/polygon/freepcbDisplayList.h @@ -4,11 +4,6 @@ #ifndef FP_DISPLAY_LIST_H #define FP_DISPLAY_LIST_H -//#define DL_MAX_LAYERS 32 -#define DL_MAGIC 2674 - -#define PCBU_PER_WU 25400 // conversion from PCB units to world units - // graphics element types enum { @@ -31,25 +26,6 @@ enum DL_X // X }; -// dragging line shapes -enum -{ - DS_NONE = 0, - DS_LINE_VERTEX, // vertex between two lines - DS_LINE, // line - DS_ARC_STRAIGHT, // straight line (used when drawing polylines) - DS_ARC_CW, // clockwise arc (used when drawing polylines) - DS_ARC_CCW // counterclockwise arc (used when drawing polylines) -}; - -// styles of line segment when dragging line or line vertex -enum -{ - DSS_STRAIGHT = 100, // straight line - DSS_ARC_CW, // clockwise arc - DSS_ARC_CCW // counterclockwise arc -}; - // inflection modes for DS_LINE and DS_LINE_VERTEX enum { @@ -60,210 +36,4 @@ enum }; -class CDisplayList; - -// this structure contains an element of the display list -class dl_element -{ - friend class CDisplayList; -public: - CDisplayList * dlist; - int magic; - dl_element * prev; - dl_element * next; - id m_id; // identifier (see ids.h) - void * ptr; // pointer to object drawing this element - int gtype; // type of primitive - int visible; // 0 to hide -//private: - int sel_vert; // for selection rectangles, 1 if part is vertical - int w; // width (for round or square shapes) - int holew; // hole width (for round holes) - int x_org, y_org; // x origin (for rotation, reflection, etc.) - int x, y; // starting or center position of element - int xf, yf; // opposite corner (for rectangle or line) - int radius; // radius of corners for DL_RRECT - int layer; // layer to draw on - int orig_layer; // for elements on highlight layer, - // the original layer, the highlight will - // only be drawn if this layer is visible -}; - -class CDisplayList -{ -private: - // display-list parameters for each layer - dl_element m_start[MAX_LAYERS], m_end[MAX_LAYERS]; - int m_rgb[MAX_LAYERS][3]; // layer colors - BOOL m_vis[MAX_LAYERS]; // layer visibility flags - int m_layer_in_order[MAX_LAYERS]; // array of layers in draw order - int m_order_for_layer[MAX_LAYERS]; // draw order for each layer - - // window parameters - int m_pcbu_per_wu; // i.e. nm per world unit - CRect m_client_r; // client rect (pixels) - CRect m_screen_r; // client rect (screen coords) - int m_pane_org_x; // left border of drawing pane (pixels) - int m_pane_org_y; // bottom border of drawing pane (pixels) - int m_bottom_pane_h; // height of bottom pane - CDC * memDC; // pointer to memory DC - - double m_scale; // world units per pixel - int m_org_x; // world x-coord of left side of screen (world units) - int m_org_y; // world y-coord of bottom of screen (world units) - int m_max_x; // world x_coord of right side of screen (world units) - int m_max_y; // world y_coord of top of screen (world units) - - int w_ext_x, w_ext_y; // window extents (world units) - int v_ext_x, v_ext_y; // viewport extents (pixels) - double m_wu_per_pixel_x; // ratio w_ext_x/v_ext_x (world units per pixel) - double m_wu_per_pixel_y; // ratio w_ext_y/v_ext_y (world units per pixel) - double m_pcbu_per_pixel_x; - double m_pcbu_per_pixel_y; - - // general dragging parameters - int m_drag_angle; // angle of rotation of selection rectangle (starts at 0) - int m_drag_side; // 0 = no change, 1 = switch to opposite - int m_drag_vert; // 1 if item being dragged is a vertical part - - // parameters for dragging polyline sides and trace segments - // that can be modified while dragging - int m_drag_flag; // 1 if dragging something - int m_drag_shape; // shape - int m_last_drag_shape; // last shape drawn - int m_drag_x; // last cursor position for dragged shape - int m_drag_y; - int m_drag_xi; // start of rubberband drag line - int m_drag_yi; - int m_drag_xf; // end of rubberband drag line - int m_drag_yf; - int m_drag_layer_1; // line layer - int m_drag_w1; // line width - int m_drag_style1; // line style - int m_inflection_mode; // inflection mode - int m_last_inflection_mode; // last mode drawn - // extra parameters when dragging vertex between 2 line segments - int m_drag_style2; - int m_drag_layer_2; - int m_drag_w2; - // parameters used to draw leading via if necessary - int m_drag_layer_no_via; - int m_drag_via_w; - int m_drag_via_holew; - int m_drag_via_drawn; - - // arrays of lines and ratlines being dragged - // these can be rotated and flipped while being dragged - int m_drag_layer; // layer - int m_drag_max_lines; // max size of array for line segments - int m_drag_num_lines; // number of line segments to drag - CPoint * m_drag_line_pt; // array of relative coords for line endpoints - int m_drag_max_ratlines; // max size of ratline array - int m_drag_num_ratlines; // number of ratlines to drag - CPoint * m_drag_ratline_start_pt; // absolute coords for ratline start points - CPoint * m_drag_ratline_end_pt; // relative coords for ratline endpoints - int m_drag_ratline_width; - - // cursor parameters - int m_cross_hairs; // 0 = none, 1 = cross-hairs, 2 = diagonals - CPoint m_cross_left, m_cross_right, m_cross_top, m_cross_bottom; // end-points - CPoint m_cross_topleft, m_cross_topright, m_cross_botleft, m_cross_botright; - - // grid - int m_visual_grid_on; - double m_visual_grid_spacing; // in world units - -public: - CDisplayList( int pcbu_per_wu ); - ~CDisplayList(); - void SetVisibleGrid( BOOL on, double grid ); - void SetMapping( CRect *client_r, CRect *screen_r, int pane_org_x, int pane_bottom_h, double scale, int org_x, int org_y ); - void SetDCToWorldCoords( CDC * pDC, CDC * mDC, int pcbu_org_x, int pcbu_org_y ); - void SetLayerRGB( int layer, int r, int g, int b ); - void SetLayerVisible( int layer, BOOL vis ); - void SetLayerDrawOrder( int layer, int order ) - { m_layer_in_order[order] = layer; m_order_for_layer[layer] = order; }; - dl_element * Add( id id, void * ptr, int glayer, int gtype, int visible, - int w, int holew, int x, int y, int xf, int yf, int xo, int yo, - int radius=0, int orig_layer=LAY_SELECTION ); - dl_element * AddSelector( id id, void * ptr, int glayer, int gtype, int visible, - int w, int holew, int x, int y, int xf, int yf, int xo, int yo, int radius=0 ); - void RemoveAll(); - void RemoveAllFromLayer( int layer ); - id Remove( dl_element * element ); - void Draw( CDC * pDC ); - int HighLight( int gtype, int x, int y, int xf, int yf, int w, int orig_layer=LAY_SELECTION ); - int CancelHighLight(); - void * TestSelect( int x, int y, id * sel_id, int * layer, - id * exclude_id = NULL, void * exclude_ptr = NULL, id * include_id = NULL, - int n_include_ids=1 ); - int StartDraggingArray( CDC * pDC, int x, int y, int vert, int layer, int crosshair = 1 ); - int StartDraggingRatLine( CDC * pDC, int x, int y, int xf, int yf, int layer, - int w, int crosshair = 1 ); - int StartDraggingRectangle( CDC * pDC, int x, int y, int xi, int yi, - int xf, int yf, int vert, int layer ); - int StartDraggingLineVertex( CDC * pDC, int x, int y, int xi, int yi, - int xf, int yf, - int layer1, int layer2, int w1, int w2, - int style1, int style2, - int layer_no_via, int via_w, int via_holew, int dir, - int crosshair ); - int StartDraggingLine( CDC * pDC, int x, int y, int xi, int yi, int layer1, int w, - int layer_no_via, int via_w, int via_holew, - int crosshair, int style, int inflection_mode ); - int StartDraggingArc( CDC * pDC, int style, int x, int y, int xi, int yi, - int layer, int w, int crosshair ); - void SetDragArcStyle( int style ); - void Drag( CDC * pDC, int x, int y ); - int StopDragging(); - void ChangeRoutingLayer( CDC * pDC, int layer1, int layer2, int w ); - void IncrementDragAngle( CDC * pDC ); - int MakeDragLineArray( int num_lines ); - int MakeDragRatlineArray( int num_ratlines, int width ); - int AddDragLine( CPoint pi, CPoint pf ); - int AddDragRatline( CPoint pi, CPoint pf ); - int GetDragAngle(); - void FlipDragSide( CDC * pDC ); - int GetDragSide(); - void SetUpCrosshairs( int type, int x, int y ); - void SetInflectionMode( int mode ){ m_inflection_mode = mode; }; - CPoint ScreenToPCB( CPoint point ); - CPoint PCBToScreen( CPoint point ); - CPoint WindowToPCB( CPoint point ); - - // set element parameters - void Set_gtype( dl_element * el, int gtype ); - void Set_visible( dl_element * el, int visible ); - void Set_sel_vert( dl_element * el, int sel_vert ); - void Set_w( dl_element * el, int w ); - void Set_holew( dl_element * el, int holew ); - void Set_x_org( dl_element * el, int x_org ); - void Set_y_org( dl_element * el, int y_org ); - void Set_x( dl_element * el, int x ); - void Set_y( dl_element * el, int y ); - void Set_xf( dl_element * el, int xf ); - void Set_yf( dl_element * el, int yf ); - void Set_id( dl_element * el, id * id ); - void Set_layer( dl_element * el, int layer ); - void Set_radius( dl_element * el, int radius ); - void Move( dl_element * el, int dx, int dy ); - - // get element parameters - void * Get_ptr( dl_element * el ); - int Get_gtype( dl_element * el ); - int Get_visible( dl_element * el ); - int Get_sel_vert( dl_element * el ); - int Get_w( dl_element * el ); - int Get_holew( dl_element * el ); - int Get_x_org( dl_element * el ); - int Get_y_org( dl_element * el ); - int Get_x( dl_element * el ); - int Get_y( dl_element * el ); - int Get_xf( dl_element * el ); - int Get_yf( dl_element * el ); - int Get_radius( dl_element * el ); - int Get_layer( dl_element * el ); - id Get_id( dl_element * el ); -}; - #endif // #ifndef FP_DISPLAY_LIST_H diff --git a/polygon/makefile.include b/polygon/makefile.include index ce63f3c433..4b778a67d1 100644 --- a/polygon/makefile.include +++ b/polygon/makefile.include @@ -9,8 +9,7 @@ OBJECTS= \ php_polygon.o\ php_polygon_vertex.o\ PolyLine.o\ - math_for_graphics.o\ - cdisplaylist_stuff.o + math_for_graphics.o GenericPolygonClipperLibrary.o: GenericPolygonClipperLibrary.cpp GenericPolygonClipperLibrary.h