You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

92 lines
2.5 KiB

  1. /*
  2. * This program source code file is part of KiCad, a free EDA CAD application.
  3. *
  4. * Copyright (C) 2007, 2008, 2012 Alexander Lunev <al.lunev@yahoo.com>
  5. * Copyright (C) 2012 KiCad Developers, see CHANGELOG.TXT for contributors.
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License
  9. * as published by the Free Software Foundation; either version 2
  10. * of the License, or (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, you may find one here:
  19. * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
  20. * or you may search the http://www.gnu.org website for the version 2 license,
  21. * or you may write to the Free Software Foundation, Inc.,
  22. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
  23. */
  24. /**
  25. * @file pcb_plane.cpp
  26. */
  27. #include <wx/wx.h>
  28. #include <wx/config.h>
  29. #include <common.h>
  30. #include <pcb_plane.h>
  31. namespace PCAD2KICAD {
  32. PCB_PLANE::PCB_PLANE( PCB_CALLBACKS* aCallbacks,
  33. BOARD* aBoard,
  34. int aPCadLayer ) :
  35. PCB_POLYGON( aCallbacks, aBoard, aPCadLayer )
  36. {
  37. m_priority = 1;
  38. }
  39. PCB_PLANE::~PCB_PLANE()
  40. {
  41. }
  42. bool PCB_PLANE::Parse( XNODE* aNode,
  43. const wxString& aDefaultMeasurementUnit,
  44. const wxString& aActualConversion )
  45. {
  46. XNODE* lNode;
  47. wxString pourType, str, propValue;
  48. lNode = FindNode( aNode, wxT( "netNameRef" ) );
  49. if( lNode )
  50. {
  51. lNode->GetAttribute( wxT( "Name" ), &propValue );
  52. propValue.Trim( false );
  53. propValue.Trim( true );
  54. m_net = propValue;
  55. m_netCode = GetNetCode( m_net );
  56. }
  57. if( FindNode( aNode, wxT( "width" ) ) )
  58. SetWidth( FindNode( aNode, wxT( "width" ) )->GetNodeContent(),
  59. aDefaultMeasurementUnit, &m_width, aActualConversion );
  60. lNode = FindNode( aNode, wxT( "pcbPoly" ) );
  61. if( lNode )
  62. {
  63. // retrieve plane outline
  64. FormPolygon( lNode, &m_outline, aDefaultMeasurementUnit, aActualConversion );
  65. m_positionX = m_outline[0]->x;
  66. m_positionY = m_outline[0]->y;
  67. }
  68. else
  69. {
  70. return false;
  71. }
  72. return true;
  73. }
  74. } // namespace PCAD2KICAD