129 lines
2.9 KiB
C++
129 lines
2.9 KiB
C++
/*******************************************/
|
|
/* Schematic marker object implementation. */
|
|
/*******************************************/
|
|
|
|
#include "fctsys.h"
|
|
#include "class_drawpanel.h"
|
|
|
|
#include "common.h"
|
|
#include "program.h"
|
|
#include "general.h"
|
|
|
|
#include "class_marker_sch.h"
|
|
#include "erc.h"
|
|
|
|
/* Marker are mainly used to show an ERC error
|
|
* but they could be used to give a specific info
|
|
*/
|
|
|
|
|
|
const wxChar* NameMarqueurType[] =
|
|
{
|
|
wxT( "" ),
|
|
wxT( "ERC" ),
|
|
wxT( "PCB" ),
|
|
wxT( "SIMUL" ),
|
|
wxT( "?????" )
|
|
};
|
|
|
|
|
|
/**************************/
|
|
/* class SCH_MARKER */
|
|
/**************************/
|
|
|
|
SCH_MARKER::SCH_MARKER() : SCH_ITEM( NULL, TYPE_SCH_MARKER ), MARKER_BASE()
|
|
{
|
|
}
|
|
|
|
|
|
SCH_MARKER::SCH_MARKER( const wxPoint& pos, const wxString& text ) :
|
|
SCH_ITEM( NULL, TYPE_SCH_MARKER ),
|
|
MARKER_BASE( 0, pos, text, pos )
|
|
{
|
|
}
|
|
|
|
|
|
SCH_MARKER::~SCH_MARKER()
|
|
{
|
|
}
|
|
|
|
|
|
SCH_MARKER* SCH_MARKER::GenCopy()
|
|
{
|
|
SCH_MARKER* newitem = new SCH_MARKER( GetPos(),
|
|
GetReporter().GetMainText() );
|
|
|
|
newitem->SetMarkerType( GetMarkerType() );
|
|
newitem->SetErrorLevel( GetErrorLevel() );
|
|
|
|
return newitem;
|
|
}
|
|
|
|
|
|
#if defined(DEBUG)
|
|
|
|
/**
|
|
* Function Show
|
|
* is used to output the object tree, currently for debugging only.
|
|
* @param nestLevel An aid to prettier tree indenting, and is the level
|
|
* of nesting of this object within the overall tree.
|
|
* @param os The ostream& to output to.
|
|
*/
|
|
void SCH_MARKER::Show( int nestLevel, std::ostream& os )
|
|
{
|
|
// 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( WinEDA_DrawPanel* aPanel, wxDC* aDC,
|
|
const wxPoint& aOffset, int aDrawMode, int aColor )
|
|
{
|
|
EDA_Colors color = (EDA_Colors) m_Color;
|
|
EDA_Colors tmp = color;
|
|
|
|
if( GetMarkerType() == MARK_ERC )
|
|
{
|
|
color = ( GetErrorLevel() == WAR ) ?
|
|
(EDA_Colors) g_LayerDescr.LayerColor[LAYER_ERC_WARN] :
|
|
(EDA_Colors) g_LayerDescr.LayerColor[LAYER_ERC_ERR];
|
|
}
|
|
|
|
if( aColor < 0 )
|
|
m_Color = color;
|
|
else
|
|
m_Color = (EDA_Colors) aColor;
|
|
|
|
DrawMarker( aPanel, aDC, aDrawMode, aOffset );
|
|
m_Color = tmp;
|
|
}
|
|
|
|
|
|
/**
|
|
* 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.
|
|
*/
|
|
EDA_Rect SCH_MARKER::GetBoundingBox()
|
|
{
|
|
return GetBoundingBoxMarker();
|
|
}
|
|
|