diff options
author | saurabhb17 | 2020-02-26 16:01:28 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:01:28 +0530 |
commit | d51317f0193609fb43e932730d78aa86a4984083 (patch) | |
tree | 6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /eeschema/sch_marker.cpp | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | 886d9cb772e81d2e5262284bc3082664f084337f (diff) | |
download | KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.gz KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.bz2 KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.zip |
Merge pull request #2 from FOSSEE/develop
Develop
Diffstat (limited to 'eeschema/sch_marker.cpp')
-rw-r--r-- | eeschema/sch_marker.cpp | 186 |
1 files changed, 186 insertions, 0 deletions
diff --git a/eeschema/sch_marker.cpp b/eeschema/sch_marker.cpp new file mode 100644 index 0000000..334d277 --- /dev/null +++ b/eeschema/sch_marker.cpp @@ -0,0 +1,186 @@ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2009 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com + * Copyright (C) 1992-2011 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 sch_marker.cpp + * @brief Class SCH_MARKER implementation + */ + +#include <fctsys.h> +#include <wxstruct.h> +#include <class_drawpanel.h> +#include <trigo.h> +#include <msgpanel.h> + +#include <general.h> +#include <sch_marker.h> +#include <erc.h> + + +/********************/ +/* class SCH_MARKER */ +/********************/ + +SCH_MARKER::SCH_MARKER() : SCH_ITEM( NULL, SCH_MARKER_T ), MARKER_BASE() +{ +} + + +SCH_MARKER::SCH_MARKER( const wxPoint& pos, const wxString& text ) : + SCH_ITEM( NULL, SCH_MARKER_T ), + MARKER_BASE( 0, pos, text, pos ) +{ +} + + +EDA_ITEM* SCH_MARKER::Clone() const +{ + return new SCH_MARKER( *this ); +} + + +#if defined(DEBUG) + +void SCH_MARKER::Show( int nestLevel, std::ostream& os ) const +{ + // for now, make it look like XML: + NestedSpace( nestLevel, os ) << '<' << GetClass().Lower().mb_str() + << GetPos() << "/>\n"; +} + +#endif + +/** + * Function Save (do nothing : markers are no more saved in files ) + * writes the data structures for this object out to a FILE in "*.brd" format. + * @param aFile The FILE to write to. + * @return bool - true if success writing else false. + */ +bool SCH_MARKER::Save( FILE* aFile ) const +{ + return true; +} + + +void SCH_MARKER::Draw( EDA_DRAW_PANEL* aPanel, wxDC* aDC, + const wxPoint& aOffset, GR_DRAWMODE aDrawMode, EDA_COLOR_T aColor ) +{ + EDA_COLOR_T color = m_Color; + EDA_COLOR_T tmp = color; + + if( GetMarkerType() == MARKER_BASE::MARKER_ERC ) + { + color = ( GetErrorLevel() == MARKER_BASE::MARKER_SEVERITY_ERROR ) ? + GetLayerColor( LAYER_ERC_ERR ) : GetLayerColor( LAYER_ERC_WARN ); + } + + if( aColor < 0 ) + m_Color = color; + else + m_Color = aColor; + + DrawMarker( aPanel, aDC, aDrawMode, aOffset ); + m_Color = tmp; +} + + +bool SCH_MARKER::Matches( wxFindReplaceData& aSearchData, void* aAuxData, + wxPoint * aFindLocation ) +{ + if( SCH_ITEM::Matches( m_drc.GetErrorText(), aSearchData ) || + SCH_ITEM::Matches( m_drc.GetMainText(), aSearchData ) || + SCH_ITEM::Matches( m_drc.GetAuxiliaryText(), aSearchData ) ) + { + if( aFindLocation ) + *aFindLocation = m_Pos; + + return true; + } + + return false; +} + + +/** + * Function GetBoundingBox + * returns the orthogonal, bounding box of this object for display purposes. + * This box should be an enclosing perimeter for visible components of this + * object, and the units should be in the pcb or schematic coordinate system. + * It is OK to overestimate the size by a few counts. + */ +const EDA_RECT SCH_MARKER::GetBoundingBox() const +{ + return GetBoundingBoxMarker(); +} + + +void SCH_MARKER::GetMsgPanelInfo( MSG_PANEL_ITEMS& aList ) +{ + wxString msg; + + aList.push_back( MSG_PANEL_ITEM( _( "Electronics Rule Check Error" ), + GetReporter().GetErrorText(), DARKRED ) ); +} + + +void SCH_MARKER::Rotate( wxPoint aPosition ) +{ + RotatePoint( &m_Pos, aPosition, 900 ); +} + + +void SCH_MARKER::MirrorX( int aXaxis_position ) +{ + m_Pos.y -= aXaxis_position; + m_Pos.y = -m_Pos.y; + m_Pos.y += aXaxis_position; +} + + +void SCH_MARKER::MirrorY( int aYaxis_position ) +{ + m_Pos.x -= aYaxis_position; + m_Pos.x = -m_Pos.x; + m_Pos.x += aYaxis_position; +} + + +bool SCH_MARKER::IsSelectStateChanged( const wxRect& aRect ) +{ + bool previousState = IsSelected(); + + if( aRect.Contains( m_Pos ) ) + SetFlags( SELECTED ); + else + ClearFlags( SELECTED ); + + return previousState != IsSelected(); +} + + +bool SCH_MARKER::HitTest( const wxPoint& aPosition, int aAccuracy ) const +{ + return HitTestMarker( aPosition ); +} + |