/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2007-2014 Jean-Pierre Charras, jp.charras at wanadoo.fr * Copyright (C) 1992-2019 KiCad Developers, see AUTHORS.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 */ /** * @file pcb_display_options.h * @brief Definition of PCB_DISPLAY_OPTIONS class */ #ifndef PCB_DISPLAY_OPTIONS_H_ #define PCB_DISPLAY_OPTIONS_H_ /** * Class PCB_DISPLAY_OPTIONS * handles display options like enable/disable some optional drawings. */ class PCB_DISPLAY_OPTIONS { public: /** * Enum TRACE_CLEARANCE_DISPLAY_MODE_T * is the set of values for DISPLAY_OPTIONS.ShowTrackClearanceMode parameter option. * This parameter controls how to show tracks and vias clearance area. */ enum TRACE_CLEARANCE_DISPLAY_MODE_T { DO_NOT_SHOW_CLEARANCE = 0, // Do not show clearance areas SHOW_CLEARANCE_NEW_TRACKS, /* Show clearance areas only for new track * during track creation. */ SHOW_CLEARANCE_NEW_TRACKS_AND_VIA_AREAS, /* Show clearance areas only for new track * during track creation, and shows a via * clearance area at end of current new * segment (guide to place a new via */ SHOW_CLEARANCE_NEW_AND_EDITED_TRACKS_AND_VIA_AREAS, /* Show clearance for new, moving and * dragging tracks and vias */ SHOW_CLEARANCE_ALWAYS /* Show Always clearance areas * for track and vias */ }; bool m_DisplayPadFill; bool m_DisplayViaFill; bool m_DisplayPadNum; // show pads numbers bool m_DisplayPadIsol; bool m_DisplayModEdgeFill; // How to display module drawings ( sketch/ filled ) bool m_DisplayModTextFill; // How to display module texts ( sketch/ filled ) bool m_DisplayPcbTrackFill; // false : tracks are show in sketch mode, true = filled. /// How trace clearances are displayed. @see TRACE_CLEARANCE_DISPLAY_MODE_T. TRACE_CLEARANCE_DISPLAY_MODE_T m_ShowTrackClearanceMode; int m_DisplayZonesMode; int m_DisplayNetNamesMode; /* 0 do not show netnames, * 1 show netnames on pads * 2 show netnames on tracks * 3 show netnames on tracks and pads */ bool m_DisplayDrawItemsFill; // How to display graphic items on board ( sketch/ filled ) bool m_ContrastModeDisplay; int m_MaxLinksShowed; // in track creation: number of hairwires shown bool m_Show_Module_Ratsnest; // When moving a footprint: allows displaying a ratsnest bool m_DisplayRatsnestLinesCurved; // Airwires can be drawn as straight lines (false) // or curved lines (true) public: PCB_DISPLAY_OPTIONS(); }; #endif // PCBSTRUCT_H_