/***********************************************************************/ /* Methodes de base de gestion des classes des elements de schematique */ /***********************************************************************/ #include "fctsys.h" #include "gr_basic.h" #include "common.h" #include "program.h" #include "libcmp.h" #include "general.h" #include "id.h" #include "protos.h" /****************************/ /* class DrawBusEntryStruct */ /***************************/ /*******************************************************************/ DrawBusEntryStruct::DrawBusEntryStruct( const wxPoint& pos, int shape, int id ) : SCH_ITEM( NULL, DRAW_BUSENTRY_STRUCT_TYPE ) /*******************************************************************/ { m_Pos = pos; m_Size.x = 100; m_Size.y = 100; m_Layer = LAYER_WIRE; m_Width = 0; if( id == BUS_TO_BUS ) { m_Layer = LAYER_BUS; m_Width = 1; } if( shape == '/' ) m_Size.y = -100; } /****************************************/ wxPoint DrawBusEntryStruct::m_End() const /****************************************/ // retourne la coord de fin du raccord { return wxPoint( m_Pos.x + m_Size.x, m_Pos.y + m_Size.y ); } /***************************************************/ DrawBusEntryStruct* DrawBusEntryStruct::GenCopy() /***************************************************/ { DrawBusEntryStruct* newitem = new DrawBusEntryStruct( m_Pos, 0, 0 ); newitem->m_Layer = m_Layer; newitem->m_Width = m_Width; newitem->m_Size = m_Size; newitem->m_Flags = m_Flags; return newitem; } /** * Function Save * 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 DrawBusEntryStruct::Save( FILE* aFile ) const { bool success = true; const char* layer = "Wire"; const char* width = "Line"; if( GetLayer() == LAYER_BUS ) { layer = "Bus"; width = "Bus"; } if( fprintf( aFile, "Entry %s %s\n", layer, width ) == EOF ) { success = false; } if( fprintf( aFile, "\t%-4d %-4d %-4d %-4d\n", m_Pos.x, m_Pos.y, m_End().x, m_End().y ) == EOF ) { success = false; } return success; } /*********************************************/ EDA_Rect DrawBusEntryStruct::GetBoundingBox() /*********************************************/ { int dx = m_Pos.x - m_End().x; int dy = m_Pos.y - m_End().y; EDA_Rect box( wxPoint( m_Pos.x, m_Pos.y ), wxSize( dx, dy ) ); box.Normalize(); int width = MAX( m_Width, g_DrawMinimunLineWidth ); box.Inflate(width/2, width/2); return box; } /****************************/ /* class DrawJunctionStruct */ /***************************/ /************************************************************/ DrawJunctionStruct::DrawJunctionStruct( const wxPoint& pos ) : SCH_ITEM( NULL, DRAW_JUNCTION_STRUCT_TYPE ) /************************************************************/ { m_Pos = pos; m_Layer = LAYER_JUNCTION; } DrawJunctionStruct* DrawJunctionStruct::GenCopy() { DrawJunctionStruct* newitem = new DrawJunctionStruct( m_Pos ); newitem->m_Layer = m_Layer; newitem->m_Flags = m_Flags; return newitem; } /** * Function Save * 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 DrawJunctionStruct::Save( FILE* aFile ) const { bool success = true; if( fprintf( aFile, "Connection ~ %-4d %-4d\n", m_Pos.x, m_Pos.y ) == EOF ) { success = false; } return success; } EDA_Rect DrawJunctionStruct::GetBoundingBox() // return a bounding box { int width = DRAWJUNCTION_SIZE * 2; int xmin = m_Pos.x - DRAWJUNCTION_SIZE; int ymin = m_Pos.y - DRAWJUNCTION_SIZE; EDA_Rect ret( wxPoint( xmin, ymin ), wxSize( width, width ) ); return ret; }; /*********************************************************/ bool DrawJunctionStruct::HitTest( const wxPoint& aPosRef ) /*********************************************************/ /** Function HitTest * @return true if the point aPosRef is within item area * @param aPosRef = a wxPoint to test */ { wxPoint dist = aPosRef - m_Pos; if( sqrt( ((double) dist.x * dist.x) + ((double) dist.y * dist.y) ) < DRAWJUNCTION_SIZE ) return true; return false; } #if defined(DEBUG) void DrawJunctionStruct::Show( int nestLevel, std::ostream& os ) { // XML output: wxString s = GetClass(); NestedSpace( nestLevel, os ) << '<' << s.Lower().mb_str() << m_Pos << "/>\n"; } #endif /*****************************/ /* class DrawNoConnectStruct */ /*****************************/ DrawNoConnectStruct::DrawNoConnectStruct( const wxPoint& pos ) : SCH_ITEM( NULL, DRAW_NOCONNECT_STRUCT_TYPE ) { m_Pos = pos; } DrawNoConnectStruct* DrawNoConnectStruct::GenCopy() { DrawNoConnectStruct* newitem = new DrawNoConnectStruct( m_Pos ); newitem->m_Flags = m_Flags; return newitem; } /*********************************************/ EDA_Rect DrawNoConnectStruct::GetBoundingBox() /*********************************************/ { const int DELTA = DRAWNOCONNECT_SIZE / 2; EDA_Rect box( wxPoint( m_Pos.x - DELTA, m_Pos.y - DELTA ), wxSize( 2 * DELTA, 2 * DELTA ) ); box.Normalize(); return box; } /*********************************************************/ bool DrawNoConnectStruct::HitTest( const wxPoint& aPosRef ) /*********************************************************/ /** Function HitTest * @return true if the point aPosRef is within item area * @param aPosRef = a wxPoint to test */ { int width = g_DrawMinimunLineWidth; int delta = ( DRAWNOCONNECT_SIZE + width) / 2; wxPoint dist = aPosRef - m_Pos; if( (ABS(dist.x) <= delta) && (ABS(dist.y) <= delta) ) return true; return false; } /** * Function Save * 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 DrawNoConnectStruct::Save( FILE* aFile ) const { bool success = true; if( fprintf( aFile, "NoConn ~ %-4d %-4d\n", m_Pos.x, m_Pos.y ) == EOF ) { success = false; } return success; } /**************************/ /* class DrawMarkerStruct */ /**************************/ DrawMarkerStruct::DrawMarkerStruct( const wxPoint& pos, const wxString& text ) : SCH_ITEM( NULL, DRAW_MARKER_STRUCT_TYPE ) { m_Pos = pos; /* XY coordinates of marker. */ m_Type = MARQ_UNSPEC; m_MarkFlags = 0; // complements d'information m_Comment = text; } DrawMarkerStruct::~DrawMarkerStruct() { } DrawMarkerStruct* DrawMarkerStruct::GenCopy() { DrawMarkerStruct* newitem = new DrawMarkerStruct( m_Pos, m_Comment ); newitem->m_Type = m_Type; newitem->m_MarkFlags = m_MarkFlags; return newitem; } wxString DrawMarkerStruct::GetComment() { return m_Comment; } #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 DrawMarkerStruct::Show( int nestLevel, std::ostream& os ) { // for now, make it look like XML: NestedSpace( nestLevel, os ) << '<' << GetClass().Lower().mb_str() << m_Pos << "/>\n"; } #endif /** * Function Save * 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 DrawMarkerStruct::Save( FILE* aFile ) const { bool success = true; if( fprintf( aFile, "Kmarq %c %-4d %-4d \"%s\" F=%X\n", int( m_Type ) + 'A', m_Pos.x, m_Pos.y, CONV_TO_UTF8( m_Comment ), m_MarkFlags ) == EOF ) { success = false; } return success; } /***************************/ /* Class EDA_DrawLineStruct */ /***************************/ EDA_DrawLineStruct::EDA_DrawLineStruct( const wxPoint& pos, int layer ) : SCH_ITEM( NULL, DRAW_SEGMENT_STRUCT_TYPE ) { m_Start = pos; m_End = pos; m_StartIsDangling = m_EndIsDangling = FALSE; switch( layer ) { default: m_Layer = LAYER_NOTES; /* Mettre ds Notes */ m_Width = GR_NORM_WIDTH; break; case LAYER_WIRE: m_Layer = LAYER_WIRE; m_Width = GR_NORM_WIDTH; break; case LAYER_BUS: m_Layer = LAYER_BUS; m_Width = GR_THICK_WIDTH; break; } } /***************************************************/ EDA_DrawLineStruct* EDA_DrawLineStruct::GenCopy() /***************************************************/ { EDA_DrawLineStruct* newitem = new EDA_DrawLineStruct( m_Start, m_Layer ); newitem->m_End = m_End; return newitem; } /************************************************************/ bool EDA_DrawLineStruct::IsOneEndPointAt( const wxPoint& pos ) /************************************************************/ /* Return TRUE if the start or the end point is in position pos */ { if( (pos.x == m_Start.x) && (pos.y == m_Start.y) ) return TRUE; if( (pos.x == m_End.x) && (pos.y == m_End.y) ) return TRUE; return FALSE; } #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 EDA_DrawLineStruct::Show( int nestLevel, std::ostream& os ) { NestedSpace( nestLevel, os ) << '<' << GetClass().Lower().mb_str() << " layer=\"" << m_Layer << '"' << " width=\"" << m_Width << '"' << " startIsDangling=\"" << m_StartIsDangling << '"' << " endIsDangling=\"" << m_EndIsDangling << '"' << ">" << " " << " " << "\n"; } #endif EDA_Rect EDA_DrawLineStruct::GetBoundingBox() { int width = 25; int xmin = MIN( m_Start.x, m_End.x ) - width; int ymin = MIN( m_Start.y, m_End.y ) - width; int xmax = MAX( m_Start.x, m_End.x ) + width; int ymax = MAX( m_Start.y, m_End.y ) + width; // return a rectangle which is [pos,dim) in nature. therefore the +1 EDA_Rect ret( wxPoint( xmin, ymin ), wxSize( xmax - xmin + 1, ymax - ymin + 1 ) ); return ret; } /** * Function Save * 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 EDA_DrawLineStruct::Save( FILE* aFile ) const { bool success = true; const char* layer = "Notes"; const char* width = "Line"; if( GetLayer() == LAYER_WIRE ) layer = "Wire"; if( GetLayer() == LAYER_BUS ) layer = "Bus"; if( m_Width != GR_NORM_WIDTH ) layer = "Bus"; if( fprintf( aFile, "Wire %s %s\n", layer, width ) == EOF ) { success = false; } if (fprintf( aFile, "\t%-4d %-4d %-4d %-4d\n", m_Start.x,m_Start.y, m_End.x,m_End.y) == EOF) { success = false; } return success; } /****************************/ /* Class DrawPolylineStruct */ /****************************/ /***********************************************************/ DrawPolylineStruct::DrawPolylineStruct( int layer ) : SCH_ITEM( NULL, DRAW_POLYLINE_STRUCT_TYPE ) /***********************************************************/ { m_Width = GR_NORM_WIDTH; switch( layer ) { default: m_Layer = LAYER_NOTES; break; case LAYER_WIRE: case LAYER_NOTES: m_Layer = layer; break; case LAYER_BUS: m_Layer = layer; m_Width = GR_THICK_WIDTH; break; } } /********************************************/ DrawPolylineStruct::~DrawPolylineStruct() /*********************************************/ { } /*****************************************************/ DrawPolylineStruct* DrawPolylineStruct::GenCopy() /*****************************************************/ { DrawPolylineStruct* newitem = new DrawPolylineStruct( m_Layer ); newitem->m_PolyPoints = m_PolyPoints; // std::vector copy return newitem; } /** * Function Save * 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 DrawPolylineStruct::Save( FILE* aFile ) const { bool success = true; const char* layer = "Notes"; const char* width = "Line"; if( GetLayer() == LAYER_WIRE ) layer = "Wire"; if( GetLayer() == LAYER_BUS ) layer = "Bus"; if( m_Width != GR_NORM_WIDTH ) width = "Bus"; if( fprintf( aFile, "Poly %s %s %d\n", width, layer, GetCornerCount() ) == EOF ) { success = false; return success; } for( unsigned ii = 0; ii < GetCornerCount(); ii++ ) { if( fprintf( aFile, "\t%-4d %-4d\n", m_PolyPoints[ii ].x, m_PolyPoints[ii].y ) == EOF ) { success = false; break; } } return success; }