KiCad PCB EDA Suite
dialog_export_step.cpp File Reference
#include <wx/choicdlg.h>
#include <wx/stdpaths.h>
#include "pcb_edit_frame.h"
#include "kiface_i.h"
#include "confirm.h"
#include "reporter.h"
#include "pcbnew.h"
#include "class_board.h"
#include "dialog_export_step_base.h"
#include <widgets/text_ctrl_eval.h>
#include <wx_html_report_panel.h>

Go to the source code of this file.

Classes

class  DIALOG_EXPORT_STEP
 

Macros

#define OPTKEY_STEP_ORIGIN_OPT   "STEP_Origin_Opt"
 
#define OPTKEY_STEP_UORG_UNITS   "STEP_UserOriginUnits"
 
#define OPTKEY_STEP_UORG_X   "STEP_UserOriginX"
 
#define OPTKEY_STEP_UORG_Y   "STEP_UserOriginY"
 
#define OPTKEY_STEP_NOVIRT   "STEP_NoVirtual"
 

Functions

bool BuildBoardPolygonOutlines (BOARD *aBoard, SHAPE_POLY_SET &aOutlines, wxString *aErrorText, unsigned int aTolerance, wxPoint *aErrorLocation=nullptr)
 

Macro Definition Documentation

#define OPTKEY_STEP_NOVIRT   "STEP_NoVirtual"
#define OPTKEY_STEP_ORIGIN_OPT   "STEP_Origin_Opt"
#define OPTKEY_STEP_UORG_UNITS   "STEP_UserOriginUnits"
#define OPTKEY_STEP_UORG_X   "STEP_UserOriginX"
#define OPTKEY_STEP_UORG_Y   "STEP_UserOriginY"

Function Documentation

bool BuildBoardPolygonOutlines ( BOARD aBoard,
SHAPE_POLY_SET aOutlines,
wxString *  aErrorText,
unsigned int  aTolerance,
wxPoint *  aErrorLocation = nullptr 
)

Definition at line 712 of file convert_drawsegment_list_to_polygon.cpp.

References SHAPE_POLY_SET::Append(), PCB_TYPE_COLLECTOR::Collect(), BOARD::ComputeBoundingBox(), ConvertOutlineToPolygon(), Edge_Cuts, EOT, BOARD::GetBoardEdgesBoundingBox(), COLLECTOR::GetCount(), EDA_RECT::GetEnd(), EDA_RECT::GetHeight(), GetLayer(), EDA_RECT::GetOrigin(), EDA_RECT::GetWidth(), EDA_RECT::Inflate(), SHAPE_POLY_SET::NewOutline(), SHAPE_POLY_SET::OutlineCount(), PCB_LINE_T, PCB_MODULE_EDGE_T, and SHAPE_POLY_SET::RemoveAllContours().

Referenced by DIALOG_EXPORT_STEP::onExportButton(), and DIALOG_EXPORT_STEP::onUpdateYPos().

714 {
715  PCB_TYPE_COLLECTOR items;
716 
717  // Get all the DRAWSEGMENTS and module graphics into 'items',
718  // then keep only those on layer == Edge_Cuts.
719  static const KICAD_T scan_graphics[] = { PCB_LINE_T, PCB_MODULE_EDGE_T, EOT };
720  items.Collect( aBoard, scan_graphics );
721 
722  // Make a working copy of aSegList, because the list is modified during calculations
723  std::vector< DRAWSEGMENT* > segList;
724 
725  for( int ii = 0; ii < items.GetCount(); ii++ )
726  {
727  if( items[ii]->GetLayer() == Edge_Cuts )
728  segList.push_back( static_cast< DRAWSEGMENT* >( items[ii] ) );
729  }
730 
731  bool success = ConvertOutlineToPolygon( segList, aOutlines, aErrorText, aTolerance, aErrorLocation );
732 
733  if( !success || !aOutlines.OutlineCount() )
734  {
735  // Creates a valid polygon outline is not possible.
736  // So uses the board edge cuts bounding box to create a
737  // rectangular outline
738  // When no edge cuts items, build a contour
739  // from global bounding box
740 
741  EDA_RECT bbbox = aBoard->GetBoardEdgesBoundingBox();
742 
743  // If null area, uses the global bounding box.
744  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
745  bbbox = aBoard->ComputeBoundingBox();
746 
747  // Ensure non null area. If happen, gives a minimal size.
748  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
749  bbbox.Inflate( Millimeter2iu( 1.0 ) );
750 
751  aOutlines.RemoveAllContours();
752  aOutlines.NewOutline();
753 
754  wxPoint corner;
755  aOutlines.Append( bbbox.GetOrigin() );
756 
757  corner.x = bbbox.GetOrigin().x;
758  corner.y = bbbox.GetEnd().y;
759  aOutlines.Append( corner );
760 
761  aOutlines.Append( bbbox.GetEnd() );
762 
763  corner.x = bbbox.GetEnd().x;
764  corner.y = bbbox.GetOrigin().y;
765  aOutlines.Append( corner );
766  }
767 
768  return success;
769 }
int GetCount() const
Function GetCount returns the number of objects in the list.
Definition: collector.h:114
const wxPoint GetOrigin() const
Definition: eda_rect.h:112
EDA_RECT ComputeBoundingBox(bool aBoardEdgesOnly=false) const
Function ComputeBoundingBox calculates the bounding box containing all board items (or board edge seg...
int GetHeight() const
Definition: eda_rect.h:118
int OutlineCount() const
Returns the number of outlines in the set
bool ConvertOutlineToPolygon(std::vector< DRAWSEGMENT * > &aSegList, SHAPE_POLY_SET &aPolygons, wxString *aErrorText, unsigned int aTolerance, wxPoint *aErrorLocation)
Function ConvertOutlineToPolygon build a polygon (with holes) from a DRAWSEGMENT list, which is expected to be a outline, therefore a closed main outline with perhaps closed inner outlines.
class EDGE_MODULE, a footprint edge
Definition: typeinfo.h:94
search types array terminator (End Of Types)
Definition: typeinfo.h:82
KICAD_T
Enum KICAD_T is the set of class identification values, stored in EDA_ITEM::m_StructType.
Definition: typeinfo.h:78
const EDA_RECT GetBoardEdgesBoundingBox() const
Function GetBoardEdgesBoundingBox Returns the board bounding box calculated using exclusively the boa...
Definition: class_board.h:810
int NewOutline()
Creates a new empty polygon in the set and returns its index
void Collect(BOARD_ITEM *aBoard, const KICAD_T aScanList[])
Collect BOARD_ITEM objects using this class&#39;s Inspector method, which does the collection.
Definition: collectors.cpp:522
const wxPoint GetEnd() const
Definition: eda_rect.h:114
void RemoveAllContours()
Removes all outlines & holes (clears) the polygon set.
Class EDA_RECT handles the component boundary box.
Definition: eda_rect.h:44
int GetWidth() const
Definition: eda_rect.h:117
static bool GetLayer(MODEL_VRML &aModel, LAYER_NUM layer, VRML_LAYER **vlayer)
Collect all BOARD_ITEM objects of a given set of KICAD_T type(s).
Definition: collectors.h:627
class DRAWSEGMENT, a segment not on copper layers
Definition: typeinfo.h:91
EDA_RECT & Inflate(wxCoord dx, wxCoord dy)
Function Inflate inflates the rectangle horizontally by dx and vertically by dy.
int Append(int x, int y, int aOutline=-1, int aHole=-1, bool aAllowDuplication=false)
Appends a vertex at the end of the given outline/hole (default: the last outline) ...