Pcbnew, Altium import: Fix issues with hatched zones.
- Filled zones using the hatch pattern cannot use the primitives from Altium. the filled shapes must be rebuilt. _ Filled zones using the hatch pattern with a very small gap are now converted to a polygon pattern. Otherwise the calculation time can be very big. From master branch. Fixes https://gitlab.com/kicad/code/kicad/-/issues/18156
This commit is contained in:
parent
9f9fa0dd8d
commit
2a1ef2d09d
|
@ -556,12 +556,43 @@ void ALTIUM_PCB::Parse( const ALTIUM_COMPOUND_FILE& altiumPcbFi
|
||||||
for( std::pair<const ALTIUM_LAYER, ZONE*>& zone : m_outer_plane )
|
for( std::pair<const ALTIUM_LAYER, ZONE*>& zone : m_outer_plane )
|
||||||
zone.second->SetAssignedPriority( 0 );
|
zone.second->SetAssignedPriority( 0 );
|
||||||
|
|
||||||
// Simplify and fracture zone fills in case we constructed them from tracks (hatched fill)
|
// Change zone fills in case we constructed them from tracks (hatched fill)
|
||||||
|
int zone_to_refill = 0;
|
||||||
|
int zone_converted = 0;
|
||||||
|
|
||||||
for( ZONE* zone : m_polygons )
|
for( ZONE* zone : m_polygons )
|
||||||
{
|
{
|
||||||
if( !zone )
|
if( !zone )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if( zone->GetFillMode() == ZONE_FILL_MODE::HATCH_PATTERN )
|
||||||
|
{
|
||||||
|
// Keep the hatch fill pattern only if the thickness and gap have a not too
|
||||||
|
// small value, especially if zone->GetHatchGap() is very small or null.
|
||||||
|
// Otherwise the refill calculation time can be **really big**
|
||||||
|
const int hatch_thickness_min_value = zone->GetMinThickness();
|
||||||
|
|
||||||
|
// If the gap is too small, the Hatch is similar to a solid filled area
|
||||||
|
// and trying to rebuild the hatch can look like hanging.
|
||||||
|
const int hatch_gap_min_value = pcbIUScale.mmToIU( 0.1 ); //arbitrary small value
|
||||||
|
|
||||||
|
if( zone->GetHatchGap() < hatch_gap_min_value )
|
||||||
|
{
|
||||||
|
zone->SetFillMode( ZONE_FILL_MODE::POLYGONS );
|
||||||
|
zone_converted++;
|
||||||
|
}
|
||||||
|
|
||||||
|
//if( zone->GetHatchThickness() < hatch_thickness_min_value )
|
||||||
|
|
||||||
|
// Remove the Altium fill solid areas, they are very different from Pcbnew
|
||||||
|
// that does not have a "painted" fill mode since a long time,
|
||||||
|
// and cannot be used as this. They must be rebuilt
|
||||||
|
zone->UnFill();
|
||||||
|
zone_to_refill++;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
// Probably this section of code makes no sense.
|
||||||
for( PCB_LAYER_ID layer : zone->GetLayerSet().Seq() )
|
for( PCB_LAYER_ID layer : zone->GetLayerSet().Seq() )
|
||||||
{
|
{
|
||||||
if( !zone->HasFilledPolysForLayer( layer ) )
|
if( !zone->HasFilledPolysForLayer( layer ) )
|
||||||
|
@ -569,6 +600,22 @@ void ALTIUM_PCB::Parse( const ALTIUM_COMPOUND_FILE& altiumPcbFi
|
||||||
|
|
||||||
zone->GetFilledPolysList( layer )->Fracture( SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
zone->GetFilledPolysList( layer )->Fracture( SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
if( m_reporter && zone_converted )
|
||||||
|
{
|
||||||
|
m_reporter->Report( wxString::Format(
|
||||||
|
_( "%d hatched zones with very small gap converted to solid" ),
|
||||||
|
zone_converted ),
|
||||||
|
RPT_SEVERITY_INFO );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( m_reporter && zone_to_refill )
|
||||||
|
{
|
||||||
|
m_reporter->Report( wxString::Format( _( "%d hatched or converted zones found. They need refill" ),
|
||||||
|
zone_to_refill ),
|
||||||
|
RPT_SEVERITY_INFO );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Altium doesn't appear to store either the dimension value nor the dimensioned object in
|
// Altium doesn't appear to store either the dimension value nor the dimensioned object in
|
||||||
|
@ -1967,6 +2014,10 @@ void ALTIUM_PCB::ParsePolygons6Data( const ALTIUM_COMPOUND_FILE& aAltiumPcbF
|
||||||
if( elem.hatchstyle != ALTIUM_POLYGON_HATCHSTYLE::SOLID
|
if( elem.hatchstyle != ALTIUM_POLYGON_HATCHSTYLE::SOLID
|
||||||
&& elem.hatchstyle != ALTIUM_POLYGON_HATCHSTYLE::UNKNOWN )
|
&& elem.hatchstyle != ALTIUM_POLYGON_HATCHSTYLE::UNKNOWN )
|
||||||
{
|
{
|
||||||
|
// We can set the hach fill pattern only if the thickness and gap have a
|
||||||
|
// not too small value. Otherwise the refill calculation time can be
|
||||||
|
// **really big**
|
||||||
|
// The hatch option validity will be checked later, after all zones are built
|
||||||
zone->SetFillMode( ZONE_FILL_MODE::HATCH_PATTERN );
|
zone->SetFillMode( ZONE_FILL_MODE::HATCH_PATTERN );
|
||||||
zone->SetHatchThickness( elem.trackwidth );
|
zone->SetHatchThickness( elem.trackwidth );
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue