|                                                                                          |  | /*
 * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2015 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com * Copyright (C) 2011 Wayne Stambaugh <stambaughw@gmail.com> * Copyright (C) 1992-2020 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 base_screen.h * @brief BASE_SCREEN class implementation. */
#ifndef  BASE_SCREEN_H
#define  BASE_SCREEN_H
#include <eda_item.h>
/**
 * Handles how to draw a screen (a board, a schematic ...) */class BASE_SCREEN : public EDA_ITEM{public:    BASE_SCREEN( EDA_ITEM* aParent, KICAD_T aType = SCREEN_T );
    BASE_SCREEN( const wxSize& aPageSizeIU, KICAD_T aType = SCREEN_T ) :            BASE_SCREEN( nullptr, aType )    {        InitDataPoints( aPageSizeIU );    }
    BASE_SCREEN( KICAD_T aType = SCREEN_T ) :            BASE_SCREEN( nullptr, aType )    {}
    ~BASE_SCREEN() override { }
    void InitDataPoints( const wxSize& aPageSizeInternalUnits );
    void SetContentModified( bool aModified = true )    { m_flagModified = aModified; }    bool IsContentModified() const                      { return m_flagModified; }
    /**
     * Return the class name.     *     * @return wxString     */    virtual wxString GetClass() const override    {        return wxT( "BASE_SCREEN" );    }
    int GetPageCount() const { return m_pageCount; }    void SetPageCount( int aPageCount );
    int GetVirtualPageNumber() const { return m_virtualPageNumber; }    void SetVirtualPageNumber( int aPageNumber ) { m_virtualPageNumber = aPageNumber; }
    const wxString& GetPageNumber() const;    void SetPageNumber( const wxString& aPageNumber ) { m_pageNumber = aPageNumber; }
#if defined(DEBUG)
    void Show( int nestLevel, std::ostream& os ) const override;#endif
    static wxString m_DrawingSheetFileName;  ///< the name of the drawing sheet file, or empty
                                             ///< to use the default drawing sheet
    VECTOR2I    m_DrawOrg;          ///< offsets for drawing the circuit on the screen
    VECTOR2D    m_LocalOrigin;      ///< Relative Screen cursor coordinate (on grid)
                                    ///< in user units. (coordinates from last reset position)
    VECTOR2I    m_StartVisu;        ///< Coordinates in drawing units of the current
                                    ///< view position (upper left corner of device)
    bool        m_Center;           ///< Center on screen.  If true (0.0) is centered on screen
                                    ///< coordinates can be < 0 and > 0 except for schematics.
                                    ///< false: when coordinates can only be >= 0 (schematics).
    VECTOR2D    m_ScrollCenter;     ///< Current scroll center point in logical units.
protected:    /**
     * The number of #BASE_SCREEN objects in this design.     *     * This currently only has meaning for #SCH_SCREEN objects because #PCB_SCREEN object     * are limited to a single file.  The count is virtual because #SCH_SCREEN objects can be     * used more than once so the screen (page) count can be more than the number of screen     * objects.     */    int         m_pageCount;
    /**
     * An integer based page number used for printing a range of pages.     *     * This page number is set before printing and plotting because page numbering does not     * reflect the actual page number in complex hiearachies in #SCH_SCREEN objects.     */    int         m_virtualPageNumber;
    /**
     * A user defined string page number used for printing and plotting.     *     * This currently only has meaning for #SCH_SCREEN objects because #PCB_SCREEN object     * are limited to a single file.  This must be set before displaying, printing, or     * plotting the current sheet.  If empty, the #m_virtualPageNumber value is converted     * to a string.     */    wxString    m_pageNumber;
private:    bool        m_flagModified;     ///< Indicates current drawing has been modified.
};
#endif  // BASE_SCREEN_H
 |