Implement multi-layer stitching via logic.

This commit is contained in:
Jeff Young 2022-02-24 21:09:47 +00:00
parent 369f53bb19
commit d65f9ad2d8
1 changed files with 18 additions and 23 deletions

View File

@ -2617,36 +2617,31 @@ int DRAWING_TOOL::DrawVia( const TOOL_EVENT& aEvent )
const VECTOR2I position = aVia->GetPosition(); const VECTOR2I position = aVia->GetPosition();
const LSET lset = aVia->GetLayerSet(); const LSET lset = aVia->GetLayerSet();
std::vector<ZONE*> foundZones;
for( ZONE* zone : m_board->Zones() )
{
for( PCB_LAYER_ID layer : LSET( zone->GetLayerSet() & lset ).Seq() )
{
if( zone->HitTestFilledArea( layer, position ) )
foundZones.push_back( zone );
}
}
std::sort( foundZones.begin(), foundZones.end(),
[] ( const ZONE* a, const ZONE* b )
{
return a->GetFirstLayer() < b->GetFirstLayer();
} );
// first take the net of the active layer // first take the net of the active layer
for( ZONE* z : foundZones ) if( lset.test( m_frame->GetActiveLayer() ) )
{ {
if( m_frame->GetActiveLayer() == z->GetLayer() ) for( ZONE* z : m_board->Zones() )
{
if( z->IsOnLayer( m_frame->GetActiveLayer() ) )
{
if( z->HitTestFilledArea( m_frame->GetActiveLayer(), position ) )
return z->GetNetCode(); return z->GetNetCode();
} }
}
}
// none? take the topmost visible layer // none? take the topmost visible layer
for( ZONE* z : foundZones ) for( PCB_LAYER_ID layer : LSET( m_board->GetVisibleLayers() & lset ).Seq() )
{ {
if( m_board->IsLayerVisible( z->GetLayer() ) ) for( ZONE* z : m_board->Zones() )
{
if( z->IsOnLayer( m_frame->GetActiveLayer() ) )
{
if( z->HitTestFilledArea( layer, position ) )
return z->GetNetCode(); return z->GetNetCode();
} }
}
}
return -1; return -1;
} }