Selection tool fix to enable selecting overlapping items
Fixes: lp:1499022 * https://bugs.launchpad.net/kicad/+bug/1499022
This commit is contained in:
parent
83ed3c933e
commit
8590809c7a
|
@ -1142,8 +1142,9 @@ double calcRatio( double a, double b )
|
|||
{
|
||||
if( a == 0.0 && b == 0.0 )
|
||||
return 1.0;
|
||||
|
||||
if( b == 0.0 )
|
||||
return 10000000.0; // something arbitrarily big for the moment
|
||||
return std::numeric_limits<double>::max();
|
||||
|
||||
return a / b;
|
||||
}
|
||||
|
@ -1317,6 +1318,7 @@ void SELECTION_TOOL::guessSelectionCandidates( GENERAL_COLLECTOR& aCollector ) c
|
|||
double maxLength = 0.0;
|
||||
double minLength = std::numeric_limits<double>::max();
|
||||
double maxArea = 0.0;
|
||||
const TRACK* maxTrack = nullptr;
|
||||
|
||||
for( int i = 0; i < aCollector.GetCount(); ++i )
|
||||
{
|
||||
|
@ -1327,8 +1329,13 @@ void SELECTION_TOOL::guessSelectionCandidates( GENERAL_COLLECTOR& aCollector ) c
|
|||
|
||||
minLength = std::min( std::max( track->GetLength(), (double) track->GetWidth() ), minLength );
|
||||
|
||||
double area = ( track->GetLength() + track->GetWidth() * track->GetWidth() );
|
||||
maxArea = std::max(area, maxArea);
|
||||
double area = track->GetLength() * track->GetWidth();
|
||||
|
||||
if( area > maxArea )
|
||||
{
|
||||
maxArea = area;
|
||||
maxTrack = track;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1350,9 +1357,9 @@ void SELECTION_TOOL::guessSelectionCandidates( GENERAL_COLLECTOR& aCollector ) c
|
|||
{
|
||||
if( MODULE* mod = dyn_cast<MODULE*>( aCollector[j] ) )
|
||||
{
|
||||
double ratio = maxArea / mod->GetFootprintRect().GetArea();
|
||||
double ratio = calcRatio( maxArea, mod->GetFootprintRect().GetArea() );
|
||||
|
||||
if( ratio < modulePadMinCoverRatio )
|
||||
if( ratio < modulePadMinCoverRatio && calcCommonArea( maxTrack, mod ) < commonAreaRatio )
|
||||
rejected.insert( mod );
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue