/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2007, 2008 Lubo Racko * Copyright (C) 2007, 2008, 2012 Alexander Lunev * Copyright (C) 2012 KiCad Developers, see CHANGELOG.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_arc.cpp */ #include #include #include #include #include namespace PCAD2KICAD { PCB_ARC::PCB_ARC( PCB_CALLBACKS* aCallbacks, BOARD* aBoard ) : PCB_COMPONENT( aCallbacks, aBoard ) { m_objType = wxT( 'A' ); m_startX = 0; m_startY = 0; m_angle = 0; m_width = 0; } PCB_ARC::~PCB_ARC() { } void PCB_ARC::Parse( XNODE* aNode, int aLayer, wxString aDefaultMeasurementUnit, wxString aActualConversion ) { XNODE* lNode; double r = 0.0, a = 0.0; int endPointX, endPointY; m_PCadLayer = aLayer; m_KiCadLayer = GetKiCadLayer(); if( FindNode( aNode, wxT( "width" ) ) ) SetWidth( FindNode( aNode, wxT( "width" ) )->GetNodeContent(), aDefaultMeasurementUnit, &m_width, aActualConversion ); if( aNode->GetName() == wxT( "triplePointArc" ) ) { // center point lNode = FindNode( aNode, wxT( "pt" ) ); if( lNode ) SetPosition( lNode->GetNodeContent(), aDefaultMeasurementUnit, &m_positionX, &m_positionY, aActualConversion ); // start point lNode = lNode->GetNext(); if( lNode ) SetPosition( lNode->GetNodeContent(), aDefaultMeasurementUnit, &m_startX, &m_startY, aActualConversion ); // end point lNode = lNode->GetNext(); if( lNode ) SetPosition( lNode->GetNodeContent(), aDefaultMeasurementUnit, &endPointX, &endPointY, aActualConversion ); int alpha1 = ArcTangente( m_startY - m_positionY, m_startX - m_positionX ); int alpha2 = ArcTangente( endPointY - m_positionY, endPointX - m_positionX ); m_angle = alpha1 - alpha2; if( m_angle < 0 ) m_angle = 3600 + m_angle; } if( aNode->GetName() == wxT( "arc" ) ) { lNode = FindNode( aNode, wxT( "pt" ) ); if( lNode ) SetPosition( lNode->GetNodeContent(), aDefaultMeasurementUnit, &m_positionX, &m_positionY, aActualConversion ); lNode = FindNode( aNode, wxT( "radius" ) ); if( lNode) r = StrToIntUnits( lNode->GetNodeContent(), wxT( ' ' ), aActualConversion ); lNode = FindNode( aNode, wxT( "startAngle" ) ); if( lNode ) a = StrToInt1Units( lNode->GetNodeContent() ); m_startX = KiROUND( m_positionX + r * sin( (a - 900.0) * M_PI / 1800.0 ) ); m_startY = KiROUND( m_positionY - r * cos( (a - 900.0) * M_PI / 1800.0 ) ); lNode = FindNode( aNode, wxT( "sweepAngle" ) ); if( lNode ) m_angle = StrToInt1Units( lNode->GetNodeContent() ); } } void PCB_ARC::WriteToFile( wxFile* aFile, char aFileType ) { /* * DC ox oy fx fy w DC is a Draw Circle DC Xcentre Ycentre Xpoint Ypoint Width Layer * DA x0 y0 x1 y1 angle width layer DA is a Draw ArcX0,y0 = Start point x1,y1 = end point */ if( aFileType == wxT( 'L' ) ) // Library component { aFile->Write( wxString::Format( wxT( "DA %d %d %d %d %d %d %d\n" ), m_positionX, m_positionY, m_startX, m_startY, m_angle, m_width, m_KiCadLayer ) ); // ValueString } } void PCB_ARC::SetPosOffset( int aX_offs, int aY_offs ) { PCB_COMPONENT::SetPosOffset( aX_offs, aY_offs ); m_startX += aX_offs; m_startY += aY_offs; } void PCB_ARC::AddToModule( MODULE* aModule ) { if( IsValidNonCopperLayerIndex( m_KiCadLayer ) ) { EDGE_MODULE* arc = new EDGE_MODULE( aModule, S_ARC ); aModule->m_Drawings.PushBack( arc ); arc->SetAngle( -m_angle ); arc->m_Start0 = wxPoint( m_positionX, m_positionY ); arc->m_End0 = wxPoint( m_startX, m_startY ); arc->SetWidth( m_width ); arc->SetLayer( m_KiCadLayer ); arc->SetDrawCoord(); } } void PCB_ARC::AddToBoard() { DRAWSEGMENT* dseg = new DRAWSEGMENT( m_board ); m_board->Add( dseg, ADD_APPEND ); dseg->SetShape( S_ARC ); dseg->SetTimeStamp( m_timestamp ); dseg->SetLayer( m_KiCadLayer ); dseg->SetStart( wxPoint( m_positionX, m_positionY ) ); dseg->SetEnd( wxPoint( m_startX, m_startY ) ); dseg->SetAngle( -m_angle ); dseg->SetWidth( m_width ); } } // namespace PCAD2KICAD