diff options
author | saurabhb17 | 2020-02-26 16:00:53 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:00:53 +0530 |
commit | 886d9cb772e81d2e5262284bc3082664f084337f (patch) | |
tree | 6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /pcbnew/zones_by_polygon_fill_functions.cpp | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | aa35045840b78d3f48212db45da59a2e5c69b223 (diff) | |
download | KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.tar.gz KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.tar.bz2 KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.zip |
Merge pull request #1 from saurabhb17/develop
Added main functions
Diffstat (limited to 'pcbnew/zones_by_polygon_fill_functions.cpp')
-rw-r--r-- | pcbnew/zones_by_polygon_fill_functions.cpp | 188 |
1 files changed, 188 insertions, 0 deletions
diff --git a/pcbnew/zones_by_polygon_fill_functions.cpp b/pcbnew/zones_by_polygon_fill_functions.cpp new file mode 100644 index 0000000..16e2088 --- /dev/null +++ b/pcbnew/zones_by_polygon_fill_functions.cpp @@ -0,0 +1,188 @@ +/* + * @file zones_by_polygon_fill_functions.cpp + */ + +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2009 Jean-Pierre Charras <jean-pierre.charras@gipsa-lab.inpg.fr> + * Copyright (C) 2007 KiCad Developers, see change_log.txt for contributors. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, you may find one here: + * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * or you may search the http://www.gnu.org website for the version 2 license, + * or you may write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + +#include <wx/progdlg.h> + +#include <fctsys.h> +#include <pgm_base.h> +#include <class_drawpanel.h> +#include <class_draw_panel_gal.h> +#include <ratsnest_data.h> +#include <wxPcbStruct.h> +#include <macros.h> + +#include <class_board.h> +#include <class_track.h> +#include <class_zone.h> + +#include <pcbnew.h> +#include <zones.h> + +#define FORMAT_STRING _( "Filling zone %d out of %d (net %s)..." ) + + +/** + * Function Delete_OldZone_Fill (obsolete) + * Used for compatibility with old boards + * Remove the zone filling which include the segment aZone, or the zone which have the + * given time stamp. + * A zone is a group of segments which have the same TimeStamp + * @param aZone = zone segment within the zone to delete. Can be NULL + * @param aTimestamp = Timestamp for the zone to delete, used if aZone == NULL + */ +void PCB_EDIT_FRAME::Delete_OldZone_Fill( SEGZONE* aZone, time_t aTimestamp ) +{ + bool modify = false; + time_t TimeStamp; + + if( aZone == NULL ) + TimeStamp = aTimestamp; + else + TimeStamp = aZone->GetTimeStamp(); // Save reference time stamp (aZone will be deleted) + + SEGZONE* next; + + for( SEGZONE* zone = GetBoard()->m_Zone; zone != NULL; zone = next ) + { + next = zone->Next(); + + if( zone->GetTimeStamp() == TimeStamp ) + { + modify = true; + // remove item from linked list and free memory + zone->DeleteStructure(); + } + } + + if( modify ) + { + OnModify(); + m_canvas->Refresh(); + } +} + + +int PCB_EDIT_FRAME::Fill_Zone( ZONE_CONTAINER* aZone ) +{ + aZone->ClearFilledPolysList(); + aZone->UnFill(); + + // Cannot fill keepout zones: + if( aZone->GetIsKeepout() ) + return 1; + + wxString msg; + + ClearMsgPanel(); + + // Shows the net + ZONE_SETTINGS zoneInfo = GetZoneSettings(); + zoneInfo.m_NetcodeSelection = aZone->GetNetCode(); + SetZoneSettings( zoneInfo ); + + msg = aZone->GetNetname(); + + if( msg.IsEmpty() ) + msg = wxT( "No net" ); + + AppendMsgPanel( _( "NetName" ), msg, RED ); + + wxBusyCursor dummy; // Shows an hourglass cursor (removed by its destructor) + + aZone->BuildFilledSolidAreasPolygons( GetBoard() ); + aZone->ViewUpdate( KIGFX::VIEW_ITEM::ALL ); + GetBoard()->GetRatsnest()->Update( aZone ); + + OnModify(); + + return 0; +} + + +int PCB_EDIT_FRAME::Fill_All_Zones( wxWindow * aActiveWindow, bool aVerbose ) +{ + int errorLevel = 0; + int areaCount = GetBoard()->GetAreaCount(); + wxBusyCursor dummyCursor; + wxString msg; + wxProgressDialog * progressDialog = NULL; + + // Create a message with a long net name, and build a wxProgressDialog + // with a correct size to show this long net name + msg.Printf( FORMAT_STRING, 000, areaCount, wxT("XXXXXXXXXXXXXXXXX" ) ); + + if( aActiveWindow ) + progressDialog = new wxProgressDialog( _( "Fill All Zones" ), msg, + areaCount+2, aActiveWindow, + wxPD_AUTO_HIDE | wxPD_CAN_ABORT | + wxPD_APP_MODAL | wxPD_ELAPSED_TIME ); + // Display the actual message + if( progressDialog ) + progressDialog->Update( 0, _( "Starting zone fill..." ) ); + + // Remove segment zones + GetBoard()->m_Zone.DeleteAll(); + + int ii; + + for( ii = 0; ii < areaCount; ii++ ) + { + ZONE_CONTAINER* zoneContainer = GetBoard()->GetArea( ii ); + if( zoneContainer->GetIsKeepout() ) + continue; + + msg.Printf( FORMAT_STRING, ii + 1, areaCount, GetChars( zoneContainer->GetNetname() ) ); + + if( progressDialog ) + { + if( !progressDialog->Update( ii+1, msg ) ) + break; // Aborted by user + } + + errorLevel = Fill_Zone( zoneContainer ); + + if( errorLevel && !aVerbose ) + break; + } + + if( progressDialog ) + { + progressDialog->Update( ii+2, _( "Updating ratsnest..." ) ); +#ifdef __WXMAC__ + // Work around a dialog z-order issue on OS X + aActiveWindow->Raise(); +#endif + } + TestConnections(); + + // Recalculate the active ratsnest, i.e. the unconnected links + TestForActiveLinksInRatsnest( 0 ); + if( progressDialog ) + progressDialog->Destroy(); + return errorLevel; +} |