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)
 

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 
)

Definition at line 643 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, SHAPE_POLY_SET::RemoveAllContours(), wxPoint::x, and wxPoint::y.

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

645 {
646  PCB_TYPE_COLLECTOR items;
647 
648  // Get all the DRAWSEGMENTS and module graphics into 'items',
649  // then keep only those on layer == Edge_Cuts.
650  static const KICAD_T scan_graphics[] = { PCB_LINE_T, PCB_MODULE_EDGE_T, EOT };
651  items.Collect( aBoard, scan_graphics );
652 
653  // Make a working copy of aSegList, because the list is modified during calculations
654  std::vector< DRAWSEGMENT* > segList;
655 
656  for( int ii = 0; ii < items.GetCount(); ii++ )
657  {
658  if( items[ii]->GetLayer() == Edge_Cuts )
659  segList.push_back( static_cast< DRAWSEGMENT* >( items[ii] ) );
660  }
661 
662  bool success = ConvertOutlineToPolygon( segList, aOutlines, aErrorText, aTolerance );
663 
664  if( !success || !aOutlines.OutlineCount() )
665  {
666  // Creates a valid polygon outline is not possible.
667  // So uses the board edge cuts bounding box to create a
668  // rectangular outline
669  // When no edge cuts items, build a contour
670  // from global bounding box
671 
672  EDA_RECT bbbox = aBoard->GetBoardEdgesBoundingBox();
673 
674  // If null area, uses the global bounding box.
675  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
676  bbbox = aBoard->ComputeBoundingBox();
677 
678  // Ensure non null area. If happen, gives a minimal size.
679  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
680  bbbox.Inflate( Millimeter2iu( 1.0 ) );
681 
682  aOutlines.RemoveAllContours();
683  aOutlines.NewOutline();
684 
685  wxPoint corner;
686  aOutlines.Append( bbbox.GetOrigin() );
687 
688  corner.x = bbbox.GetOrigin().x;
689  corner.y = bbbox.GetEnd().y;
690  aOutlines.Append( corner );
691 
692  aOutlines.Append( bbbox.GetEnd() );
693 
694  corner.x = bbbox.GetEnd().x;
695  corner.y = bbbox.GetOrigin().y;
696  aOutlines.Append( corner );
697  }
698 
699  return success;
700 }
int GetCount() const
Function GetCount returns the number of objects in the list.
Definition: collector.h:114
bool ConvertOutlineToPolygon(std::vector< DRAWSEGMENT * > &aSegList, SHAPE_POLY_SET &aPolygons, wxString *aErrorText, unsigned int aTolerance)
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.
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
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:804
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) ...