2007-08-04 04:40:07 +00:00
|
|
|
|
/*******************************/
|
|
|
|
|
/* Edition des pistes */
|
|
|
|
|
/* Routines de trace de pistes */
|
|
|
|
|
/*******************************/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
|
#include "gr_basic.h"
|
|
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
|
#include "pcbnew.h"
|
|
|
|
|
#include "autorout.h"
|
|
|
|
|
|
|
|
|
|
#include "protos.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Routines Locales */
|
|
|
|
|
|
|
|
|
|
/* variables locales */
|
|
|
|
|
|
|
|
|
|
/***********************************************/
|
2007-09-01 12:00:30 +00:00
|
|
|
|
void WinEDA_PcbFrame::DisplayTrackSettings()
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/***********************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/* Display the current track width and via diameter
|
2007-08-04 04:40:07 +00:00
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
wxString msg;
|
|
|
|
|
wxString buftrc, bufvia;
|
|
|
|
|
|
|
|
|
|
valeur_param( g_DesignSettings.m_CurrentTrackWidth, buftrc );
|
|
|
|
|
valeur_param( g_DesignSettings.m_CurrentViaSize, bufvia );
|
|
|
|
|
msg.Printf( _( "Track Width: %s Vias Size : %s" ),
|
|
|
|
|
buftrc.GetData(), bufvia.GetData() );
|
|
|
|
|
Affiche_Message( msg );
|
|
|
|
|
m_SelTrackWidthBox_Changed = TRUE;
|
|
|
|
|
m_SelViaSizeBox_Changed = TRUE;
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***********************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::Ratsnest_On_Off( wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/***********************************************/
|
|
|
|
|
|
|
|
|
|
/* Affiche ou efface le chevelu selon l'etat du bouton d'appel */
|
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
int ii;
|
|
|
|
|
CHEVELU* pt_chevelu;
|
|
|
|
|
|
|
|
|
|
if( (m_Pcb->m_Status_Pcb & LISTE_CHEVELU_OK) == 0 )
|
|
|
|
|
{
|
|
|
|
|
if( g_Show_Ratsnest )
|
|
|
|
|
Compile_Ratsnest( DC, TRUE );
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DrawGeneralRatsnest( DC, 0 ); /* effacement eventuel du chevelu affiche */
|
|
|
|
|
|
|
|
|
|
pt_chevelu = m_Pcb->m_Ratsnest;
|
|
|
|
|
if( pt_chevelu == NULL )
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
if( g_Show_Ratsnest )
|
|
|
|
|
{
|
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); ii > 0; pt_chevelu++, ii-- )
|
|
|
|
|
{
|
|
|
|
|
pt_chevelu->status |= CH_VISIBLE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DrawGeneralRatsnest( DC, 0 );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); ii > 0; pt_chevelu++, ii-- )
|
|
|
|
|
{
|
|
|
|
|
pt_chevelu->status &= ~CH_VISIBLE;
|
|
|
|
|
}
|
|
|
|
|
}
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::ExChange_Track_Layer( TRACK* pt_segm, wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/*************************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/*
|
2007-08-04 04:40:07 +00:00
|
|
|
|
* change de couche la piste pointee par la souris :
|
|
|
|
|
* la piste doit etre sur une des couches de travail,
|
|
|
|
|
* elle est mise sur l'autre couche de travail, si cela est possible
|
|
|
|
|
* (ou si DRC = Off ).
|
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
int ii;
|
|
|
|
|
TRACK* pt_track;
|
|
|
|
|
int l1, l2, nb_segm;
|
|
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( (pt_segm == NULL ) || ( pt_segm->Type() == TYPEZONE ) )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
l1 = Route_Layer_TOP; l2 = Route_Layer_BOTTOM;
|
|
|
|
|
|
|
|
|
|
pt_track = Marque_Une_Piste( this, DC, pt_segm, &nb_segm, GR_XOR );
|
|
|
|
|
|
|
|
|
|
/* effacement du flag BUSY et sauvegarde en membre .param de la couche
|
|
|
|
|
* initiale */
|
|
|
|
|
ii = nb_segm; pt_segm = pt_track;
|
|
|
|
|
for( ; ii > 0; ii--, pt_segm = (TRACK*) pt_segm->Pnext )
|
|
|
|
|
{
|
|
|
|
|
pt_segm->SetState( BUSY, OFF );
|
2007-08-23 04:28:46 +00:00
|
|
|
|
pt_segm->m_Param = pt_segm->GetLayer(); /* pour sauvegarde */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ii = 0; pt_segm = pt_track;
|
|
|
|
|
for( ; ii < nb_segm; ii++, pt_segm = (TRACK*) pt_segm->Pnext )
|
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( pt_segm->Type() == TYPEVIA )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
/* inversion des couches */
|
2007-08-23 04:28:46 +00:00
|
|
|
|
if( pt_segm->GetLayer() == l1 )
|
|
|
|
|
pt_segm->SetLayer( l2 );
|
|
|
|
|
else if( pt_segm->GetLayer() == l2 )
|
|
|
|
|
pt_segm->SetLayer( l1 );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
|
|
|
|
if( (Drc_On) && ( Drc( this, DC, pt_segm, m_Pcb->m_Track, 1 ) == BAD_DRC ) )
|
|
|
|
|
{ /* Annulation du changement */
|
|
|
|
|
ii = 0; pt_segm = pt_track;
|
|
|
|
|
for( ; ii < nb_segm; ii++, pt_segm = (TRACK*) pt_segm->Pnext )
|
|
|
|
|
{
|
2007-08-23 04:28:46 +00:00
|
|
|
|
pt_segm->SetLayer( pt_segm->m_Param );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Trace_Une_Piste( DrawPanel, DC, pt_track, nb_segm, GR_OR );
|
|
|
|
|
DisplayError( this, _( "Drc error, cancelled" ), 10 );
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Trace_Une_Piste( DrawPanel, DC, pt_track, nb_segm, GR_OR | GR_SURBRILL );
|
|
|
|
|
/* controle des extremites de segments: sont-ils sur un pad */
|
|
|
|
|
ii = 0; pt_segm = pt_track;
|
|
|
|
|
for( ; ii < nb_segm; pt_segm = (TRACK*) pt_segm->Pnext, ii++ )
|
|
|
|
|
{
|
|
|
|
|
pt_segm->start = Locate_Pad_Connecte( m_Pcb, pt_segm, START );
|
|
|
|
|
pt_segm->end = Locate_Pad_Connecte( m_Pcb, pt_segm, END );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
test_1_net_connexion( DC, pt_track->m_NetCode );
|
2007-08-20 19:33:15 +00:00
|
|
|
|
pt_track->Display_Infos( this );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
GetScreen()->SetModify();
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/****************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::Other_Layer_Route( TRACK* track, wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/****************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/*
|
2007-09-04 14:28:20 +00:00
|
|
|
|
* if no track in progress :
|
|
|
|
|
* swap the active layer between m_Route_Layer_TOP and m_Route_Layer_BOTTOM
|
|
|
|
|
* if a track is in progress :
|
|
|
|
|
* put (if possible, i.e. if no DRC problem) a Via on the end of the current
|
|
|
|
|
* track, swap the current active layer and start a new trac segment on the new layer
|
2007-09-20 06:45:17 +00:00
|
|
|
|
* @param track = track in progress, or NULL
|
|
|
|
|
* @param DC = current device context
|
2007-08-04 04:40:07 +00:00
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
TRACK* pt_segm;
|
|
|
|
|
SEGVIA* Via;
|
|
|
|
|
int ii;
|
|
|
|
|
int itmp;
|
|
|
|
|
|
|
|
|
|
if( track == NULL )
|
|
|
|
|
{
|
|
|
|
|
if( GetScreen()->m_Active_Layer != GetScreen()->m_Route_Layer_TOP )
|
|
|
|
|
GetScreen()->m_Active_Layer = GetScreen()->m_Route_Layer_TOP;
|
|
|
|
|
else
|
|
|
|
|
GetScreen()->m_Active_Layer = GetScreen()->m_Route_Layer_BOTTOM;
|
|
|
|
|
Affiche_Status_Box();
|
|
|
|
|
SetToolbars();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2007-09-04 14:28:20 +00:00
|
|
|
|
/* Avoid more than one via on the current location: */
|
2007-08-23 04:28:46 +00:00
|
|
|
|
if( Locate_Via( m_Pcb, g_CurrentTrackSegment->m_End, g_CurrentTrackSegment->GetLayer() ) )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
return;
|
2007-10-01 04:34:11 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
pt_segm = g_FirstTrackSegment;
|
|
|
|
|
for( ii = 0; ii < g_TrackSegmentCount - 1; ii++, pt_segm = (TRACK*) pt_segm->Pnext )
|
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( (pt_segm->Type() == TYPEVIA)
|
2007-08-04 04:40:07 +00:00
|
|
|
|
&& (g_CurrentTrackSegment->m_End == pt_segm->m_Start) )
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2007-09-20 06:45:17 +00:00
|
|
|
|
/* Is the current segment Ok (no DRC error) ? */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
if( Drc_On )
|
2007-09-20 06:45:17 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
if( Drc( this, DC, g_CurrentTrackSegment, m_Pcb->m_Track, 1 ) == BAD_DRC )
|
2007-09-20 06:45:17 +00:00
|
|
|
|
/* DRC error, the change layer is not made */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
return;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
if( g_TwoSegmentTrackBuild && g_CurrentTrackSegment->Back() ) // We must handle 2 segments
|
|
|
|
|
{
|
|
|
|
|
if( Drc( this, DC, g_CurrentTrackSegment->Back(), m_Pcb->m_Track, 1 ) == BAD_DRC )
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-09-04 14:28:20 +00:00
|
|
|
|
/* Saving current state before placing a via.
|
2007-09-20 06:45:17 +00:00
|
|
|
|
* If the via canot be placed this current state will be reused */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
itmp = g_TrackSegmentCount;
|
|
|
|
|
Begin_Route( g_CurrentTrackSegment, DC );
|
|
|
|
|
|
|
|
|
|
DrawPanel->ManageCurseur( DrawPanel, DC, FALSE );
|
|
|
|
|
|
2007-09-20 06:45:17 +00:00
|
|
|
|
/* create the via */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
Via = new SEGVIA( m_Pcb );
|
|
|
|
|
Via->m_Flags = IS_NEW;
|
|
|
|
|
Via->m_Width = g_DesignSettings.m_CurrentViaSize;
|
|
|
|
|
Via->m_Shape = g_DesignSettings.m_CurrentViaType;
|
|
|
|
|
Via->m_NetCode = g_HightLigth_NetCode;
|
|
|
|
|
Via->m_Start = Via->m_End = g_CurrentTrackSegment->m_End;
|
|
|
|
|
|
2007-09-04 14:32:06 +00:00
|
|
|
|
int old_layer = GetScreen()->m_Active_Layer;
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
|
|
|
|
//swap the layers.
|
|
|
|
|
if( GetScreen()->m_Active_Layer != GetScreen()->m_Route_Layer_TOP )
|
|
|
|
|
GetScreen()->m_Active_Layer = GetScreen()->m_Route_Layer_TOP;
|
|
|
|
|
else
|
|
|
|
|
GetScreen()->m_Active_Layer = GetScreen()->m_Route_Layer_BOTTOM;
|
|
|
|
|
|
2007-10-01 04:34:11 +00:00
|
|
|
|
|
2007-09-20 06:45:17 +00:00
|
|
|
|
/* Adjust the via layer pair */
|
2007-10-01 04:34:11 +00:00
|
|
|
|
if( Via->Shape() == VIA_ENTERREE )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-10-01 04:34:11 +00:00
|
|
|
|
Via->SetLayerPair( old_layer, GetScreen()->m_Active_Layer );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
2007-10-01 04:34:11 +00:00
|
|
|
|
|
|
|
|
|
else if( Via->Shape() == VIA_BORGNE ) //blind via
|
|
|
|
|
{
|
|
|
|
|
// A revoir! ( la via devrait deboucher sur 1 cote )
|
|
|
|
|
Via->SetLayerPair( old_layer, GetScreen()->m_Active_Layer );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
2007-10-01 04:34:11 +00:00
|
|
|
|
|
|
|
|
|
else // @todo: why have this override behaviour? why does the user even need to tell us what kind of via, when we know which two layers are in play?
|
|
|
|
|
{
|
|
|
|
|
// Usual via is from copper to component; layer pair is 0 and 0x0F.
|
|
|
|
|
Via->SetLayerPair( LAYER_CUIVRE_N, LAYER_CMP_N );
|
|
|
|
|
}
|
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
if( Drc_On &&( Drc( this, DC, Via, m_Pcb->m_Track, 1 ) == BAD_DRC ) )
|
2007-09-20 06:45:17 +00:00
|
|
|
|
{
|
2007-09-04 14:28:20 +00:00
|
|
|
|
/* DRC fault: the Via cannot be placed here ... */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
delete Via;
|
2007-09-04 14:28:20 +00:00
|
|
|
|
GetScreen()->m_Active_Layer = old_layer;
|
2007-08-04 04:40:07 +00:00
|
|
|
|
DrawPanel->ManageCurseur( DrawPanel, DC, FALSE );
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2007-09-04 14:28:20 +00:00
|
|
|
|
/* A new via was created. It was Ok.
|
2007-09-20 06:45:17 +00:00
|
|
|
|
* Put it in linked list, after the g_CurrentTrackSegment */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
Via->Pback = g_CurrentTrackSegment;
|
|
|
|
|
g_CurrentTrackSegment->Pnext = Via;
|
|
|
|
|
g_TrackSegmentCount++;
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
2007-09-20 06:45:17 +00:00
|
|
|
|
/* The g_CurrentTrackSegment is now in linked list and we need a new track segment
|
|
|
|
|
* after the via, starting at via location.
|
|
|
|
|
* it will become the new curren segment (from via to the mouse cursor)
|
|
|
|
|
*/
|
|
|
|
|
g_CurrentTrackSegment = g_CurrentTrackSegment->Copy(); /* create a new segment
|
|
|
|
|
* from the last entered segment, with the current width, flags, netcode, etc... values
|
|
|
|
|
* layer, start and end point are not correct, and will be modified next */
|
|
|
|
|
|
|
|
|
|
g_CurrentTrackSegment->SetLayer( GetScreen()->m_Active_Layer ); // set the layer to the new value
|
|
|
|
|
|
|
|
|
|
/* the start point is the via position,
|
|
|
|
|
* and the end point is the cursor which also is on the via (will change when moving mouse)
|
|
|
|
|
*/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
g_CurrentTrackSegment->m_Start = g_CurrentTrackSegment->m_End = Via->m_Start;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
g_TrackSegmentCount++;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
g_CurrentTrackSegment->Pback = Via;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
Via->Pnext = g_CurrentTrackSegment;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
if( g_TwoSegmentTrackBuild )
|
2007-09-20 06:45:17 +00:00
|
|
|
|
{
|
2007-08-30 22:20:52 +00:00
|
|
|
|
// Create a second segment (we must have 2 track segments to adjust)
|
2007-08-04 04:40:07 +00:00
|
|
|
|
TRACK* track = g_CurrentTrackSegment;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
|
g_CurrentTrackSegment = track->Copy();
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
g_TrackSegmentCount++;
|
|
|
|
|
g_CurrentTrackSegment->Pback = track;
|
|
|
|
|
track->Pnext = g_CurrentTrackSegment;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DrawPanel->ManageCurseur( DrawPanel, DC, FALSE );
|
2007-08-20 19:33:15 +00:00
|
|
|
|
Via->Display_Infos( this );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
|
|
|
|
Affiche_Status_Box();
|
|
|
|
|
SetToolbars();
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::Affiche_Status_Net( wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/*************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/* Affiche:
|
2007-08-04 04:40:07 +00:00
|
|
|
|
* le status du net en haut d'ecran du segment pointe par la souris
|
|
|
|
|
* ou le status PCB en bas d'ecran si pas de segment pointe
|
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
TRACK* pt_segm;
|
|
|
|
|
int masquelayer = g_TabOneLayerMask[GetScreen()->m_Active_Layer];
|
|
|
|
|
|
|
|
|
|
pt_segm = Locate_Pistes( m_Pcb->m_Track, masquelayer, CURSEUR_OFF_GRILLE );
|
|
|
|
|
if( pt_segm == NULL )
|
2007-08-20 19:33:15 +00:00
|
|
|
|
m_Pcb->Display_Infos( this );
|
2007-08-04 04:40:07 +00:00
|
|
|
|
else
|
|
|
|
|
test_1_net_connexion( DC, pt_segm->m_NetCode );
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::Show_1_Ratsnest( EDA_BaseStruct* item, wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/**********************************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/* Affiche le ratsnest relatif
|
2007-08-04 04:40:07 +00:00
|
|
|
|
* au net du pad pointe par la souris
|
|
|
|
|
* ou au module localise par la souris
|
|
|
|
|
* Efface le chevelu affiche si aucun module ou pad n'est selectionne
|
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
int ii;
|
|
|
|
|
CHEVELU* pt_chevelu;
|
|
|
|
|
D_PAD* pt_pad = NULL;
|
|
|
|
|
MODULE* Module = NULL;
|
|
|
|
|
|
|
|
|
|
if( g_Show_Ratsnest )
|
2007-09-20 06:45:17 +00:00
|
|
|
|
return; // Deja Affich<63>
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
|
|
|
|
if( (m_Pcb->m_Status_Pcb & LISTE_CHEVELU_OK) == 0 )
|
|
|
|
|
{
|
|
|
|
|
Compile_Ratsnest( DC, TRUE );
|
|
|
|
|
}
|
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
if( item )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( item->Type() == TYPEPAD )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-08-04 05:08:19 +00:00
|
|
|
|
pt_pad = (D_PAD*) item;
|
|
|
|
|
Module = (MODULE*) pt_pad->m_Parent;
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
if( pt_pad ) /* Affichage du chevelu du net correspondant */
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-08-04 05:08:19 +00:00
|
|
|
|
pt_pad->Display_Infos( this );
|
|
|
|
|
pt_chevelu = (CHEVELU*) m_Pcb->m_Ratsnest;
|
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); ii > 0; pt_chevelu++, ii-- )
|
|
|
|
|
{
|
|
|
|
|
if( pt_chevelu->m_NetCode == pt_pad->m_NetCode )
|
|
|
|
|
{
|
|
|
|
|
if( (pt_chevelu->status & CH_VISIBLE) != 0 )
|
|
|
|
|
continue;
|
|
|
|
|
pt_chevelu->status |= CH_VISIBLE;
|
|
|
|
|
if( (pt_chevelu->status & CH_ACTIF) == 0 )
|
|
|
|
|
continue;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
GRSetDrawMode( DC, GR_XOR );
|
|
|
|
|
GRLine( &DrawPanel->m_ClipBox, DC, pt_chevelu->pad_start->m_Pos.x,
|
|
|
|
|
pt_chevelu->pad_start->m_Pos.y,
|
|
|
|
|
pt_chevelu->pad_end->m_Pos.x,
|
|
|
|
|
pt_chevelu->pad_end->m_Pos.y,
|
|
|
|
|
0,
|
|
|
|
|
g_DesignSettings.m_RatsnestColor );
|
|
|
|
|
}
|
|
|
|
|
}
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
2007-08-04 05:08:19 +00:00
|
|
|
|
else
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( item->Type() == TYPETEXTEMODULE )
|
2007-08-04 05:08:19 +00:00
|
|
|
|
{
|
2007-09-01 12:00:30 +00:00
|
|
|
|
if( item->m_Parent && (item->m_Parent->Type() == TYPEMODULE) )
|
2007-08-08 03:50:44 +00:00
|
|
|
|
Module = (MODULE*) item->m_Parent;
|
2007-08-04 05:08:19 +00:00
|
|
|
|
}
|
2007-09-01 12:00:30 +00:00
|
|
|
|
else if( item->Type() == TYPEMODULE )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-08-04 05:08:19 +00:00
|
|
|
|
Module = (MODULE*) item;
|
|
|
|
|
}
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
if( Module )
|
|
|
|
|
{
|
|
|
|
|
Module->Display_Infos( this );
|
|
|
|
|
pt_pad = Module->m_Pads;
|
|
|
|
|
for( ; pt_pad != NULL; pt_pad = (D_PAD*) pt_pad->Pnext )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-08-04 05:08:19 +00:00
|
|
|
|
pt_chevelu = (CHEVELU*) m_Pcb->m_Ratsnest;
|
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); ii > 0; pt_chevelu++, ii-- )
|
2007-08-04 04:40:07 +00:00
|
|
|
|
{
|
2007-08-04 05:08:19 +00:00
|
|
|
|
if( (pt_chevelu->pad_start == pt_pad)
|
|
|
|
|
|| (pt_chevelu->pad_end == pt_pad) )
|
|
|
|
|
{
|
|
|
|
|
if( pt_chevelu->status & CH_VISIBLE )
|
|
|
|
|
continue;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
pt_chevelu->status |= CH_VISIBLE;
|
|
|
|
|
if( (pt_chevelu->status & CH_ACTIF) == 0 )
|
|
|
|
|
continue;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
GRSetDrawMode( DC, GR_XOR );
|
|
|
|
|
GRLine( &DrawPanel->m_ClipBox, DC, pt_chevelu->pad_start->m_Pos.x,
|
|
|
|
|
pt_chevelu->pad_start->m_Pos.y,
|
|
|
|
|
pt_chevelu->pad_end->m_Pos.x,
|
|
|
|
|
pt_chevelu->pad_end->m_Pos.y,
|
|
|
|
|
0,
|
|
|
|
|
g_DesignSettings.m_RatsnestColor );
|
|
|
|
|
}
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 05:08:19 +00:00
|
|
|
|
pt_pad = NULL;
|
2007-08-04 04:40:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Effacement complet des selections
|
|
|
|
|
* si aucun pad ou module n'a ete localise */
|
|
|
|
|
if( (pt_pad == NULL) && (Module == NULL) )
|
|
|
|
|
{
|
|
|
|
|
DrawGeneralRatsnest( DC );
|
|
|
|
|
pt_chevelu = (CHEVELU*) m_Pcb->m_Ratsnest;
|
2007-09-20 06:45:17 +00:00
|
|
|
|
|
2007-08-04 04:40:07 +00:00
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); (ii > 0) && pt_chevelu; pt_chevelu++, ii-- )
|
|
|
|
|
pt_chevelu->status &= ~CH_VISIBLE;
|
|
|
|
|
}
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
void WinEDA_PcbFrame::Affiche_PadsNoConnect( wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/*****************************************************/
|
2007-08-04 04:40:07 +00:00
|
|
|
|
|
2007-05-06 16:03:28 +00:00
|
|
|
|
/* Met en surbrillance les pads non encore connectes ( correspondants aux
|
2007-08-04 04:40:07 +00:00
|
|
|
|
* chevelus actifs
|
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
{
|
2007-08-04 04:40:07 +00:00
|
|
|
|
int ii;
|
|
|
|
|
CHEVELU* pt_chevelu;
|
|
|
|
|
D_PAD* pt_pad;
|
|
|
|
|
|
|
|
|
|
pt_chevelu = (CHEVELU*) m_Pcb->m_Ratsnest;
|
|
|
|
|
for( ii = m_Pcb->GetNumRatsnests(); ii > 0; pt_chevelu++, ii-- )
|
|
|
|
|
{
|
|
|
|
|
if( (pt_chevelu->status & CH_ACTIF) == 0 )
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
pt_pad = pt_chevelu->pad_start;
|
|
|
|
|
|
|
|
|
|
if( pt_pad )
|
|
|
|
|
pt_pad->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR | GR_SURBRILL );
|
|
|
|
|
|
|
|
|
|
pt_pad = pt_chevelu->pad_end;
|
|
|
|
|
if( pt_pad )
|
|
|
|
|
pt_pad->Draw( DrawPanel, DC, wxPoint( 0, 0 ), GR_OR | GR_SURBRILL );
|
|
|
|
|
}
|
2007-05-06 16:03:28 +00:00
|
|
|
|
}
|