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 562 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().

564 {
565  PCB_TYPE_COLLECTOR items;
566 
567  // Get all the DRAWSEGMENTS and module graphics into 'items',
568  // then keep only those on layer == Edge_Cuts.
569  static const KICAD_T scan_graphics[] = { PCB_LINE_T, PCB_MODULE_EDGE_T, EOT };
570  items.Collect( aBoard, scan_graphics );
571 
572  // Make a working copy of aSegList, because the list is modified during calculations
573  std::vector< DRAWSEGMENT* > segList;
574 
575  for( int ii = 0; ii < items.GetCount(); ii++ )
576  {
577  if( items[ii]->GetLayer() == Edge_Cuts )
578  segList.push_back( static_cast< DRAWSEGMENT* >( items[ii] ) );
579  }
580 
581  bool success = ConvertOutlineToPolygon( segList, aOutlines, aErrorText, aTolerance );
582 
583  if( !success || !aOutlines.OutlineCount() )
584  {
585  // Creates a valid polygon outline is not possible.
586  // So uses the board edge cuts bounding box to create a
587  // rectangular outline
588  // When no edge cuts items, build a contour
589  // from global bounding box
590 
591  EDA_RECT bbbox = aBoard->GetBoardEdgesBoundingBox();
592 
593  // If null area, uses the global bounding box.
594  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
595  bbbox = aBoard->ComputeBoundingBox();
596 
597  // Ensure non null area. If happen, gives a minimal size.
598  if( ( bbbox.GetWidth() ) == 0 || ( bbbox.GetHeight() == 0 ) )
599  bbbox.Inflate( Millimeter2iu( 1.0 ) );
600 
601  aOutlines.RemoveAllContours();
602  aOutlines.NewOutline();
603 
604  wxPoint corner;
605  aOutlines.Append( bbbox.GetOrigin() );
606 
607  corner.x = bbbox.GetOrigin().x;
608  corner.y = bbbox.GetEnd().y;
609  aOutlines.Append( corner );
610 
611  aOutlines.Append( bbbox.GetEnd() );
612 
613  corner.x = bbbox.GetEnd().x;
614  corner.y = bbbox.GetOrigin().y;
615  aOutlines.Append( corner );
616  }
617 
618  return success;
619 }
int GetCount() const
Function GetCount returns the number of objects in the list.
Definition: collector.h:106
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:801
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:498
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:590
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) ...