KiCad PCB EDA Suite
edit_component_in_schematic.cpp
Go to the documentation of this file.
1 /*
2  * This program source code file is part of KiCad, a free EDA CAD application.
3  *
4  * Copyright (C) 2016 Jean-Pierre Charras, jp.charras at wanadoo.fr
5  * Copyright (C) 2008 Wayne Stambaugh <stambaughw@gmail.com>
6  * Copyright (C) 2004-2018 KiCad Developers, see AUTHORS.txt for contributors.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License
10  * as published by the Free Software Foundation; either version 2
11  * of the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, you may find one here:
20  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
21  * or you may search the http://www.gnu.org website for the version 2 license,
22  * or you may write to the Free Software Foundation, Inc.,
23  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
24  */
25 
31 #include <fctsys.h>
32 #include <gr_basic.h>
33 #include <sch_draw_panel.h>
34 #include <confirm.h>
35 #include <sch_edit_frame.h>
36 #include <msgpanel.h>
37 
38 #include <general.h>
39 #include <class_library.h>
40 #include <sch_component.h>
41 #include <symbol_lib_table.h>
42 
43 #include <dialog_edit_one_field.h>
44 
45 
47 {
48  wxCHECK_RET( aField != NULL && aField->Type() == SCH_FIELD_T,
49  wxT( "Cannot edit invalid schematic field." ) );
50 
51  SCH_COMPONENT* component = (SCH_COMPONENT*) aField->GetParent();
52 
53  wxCHECK_RET( component != NULL && component->Type() == SCH_COMPONENT_T,
54  wxT( "Invalid schematic field parent item." ) );
55 
56  // Save old component in undo list if not already in edit, or moving.
58  if( ( aField->GetFlags() & mask ) == 0 ) // i.e. not edited, or moved
59  SaveCopyInUndoList( component, UR_CHANGED );
60 
61  // Don't use GetText() here. If the field is the reference designator and it's parent
62  // component has multiple parts, we don't want the part suffix added to the field.
64 
65  wxString title;
66  title.Printf( _( "Edit %s Field" ), GetChars( aField->GetName() ) );
67 
68  DIALOG_SCH_EDIT_ONE_FIELD dlg( this, title, aField );
69 
70  // The dialog may invoke a kiway player for footprint fields
71  // so we must use a quasimodal
72  if( dlg.ShowQuasiModal() != wxID_OK )
73  {
76  return;
77  }
78 
79  dlg.UpdateField( aField, m_CurrentSheet );
82 
83  if( m_autoplaceFields )
84  component->AutoAutoplaceFields( GetScreen() );
85 
86  RefreshItem( aField );
87  OnModify();
88 
89  MSG_PANEL_ITEMS items;
90  component->SetCurrentSheetPath( &GetCurrentSheet() );
91  component->GetMsgPanelInfo( m_UserUnits, items );
92  SetMsgPanel( items );
93 }
94 
95 
97 {
98  wxCHECK_RET( aField != NULL && aField->Type() == SCH_FIELD_T && !aField->GetText().IsEmpty(),
99  wxT( "Cannot rotate invalid schematic field." ) );
100 
101  SCH_COMPONENT* component = (SCH_COMPONENT*) aField->GetParent();
102 
103  // Save old component in undo list if not already in edit, or moving.
104  int mask = EDA_ITEM_ALL_FLAGS - ( SELECTED | HIGHLIGHTED | BRIGHTENED );
105  if( ( aField->GetFlags() & mask ) == 0 )
106  SaveCopyInUndoList( component, UR_CHANGED );
107 
108  if( aField->GetTextAngle() == TEXT_ANGLE_HORIZ )
109  aField->SetTextAngle( TEXT_ANGLE_VERT );
110  else
111  aField->SetTextAngle( TEXT_ANGLE_HORIZ );
112 
113  RefreshItem( aField );
114  OnModify();
115 }
void SetTextAngle(double aAngle)
Definition: eda_text.h:169
#define TEXT_ANGLE_HORIZ
KICAD_T Type() const
Function Type()
Definition: base_struct.h:201
Class SCH_FIELD instances are attached to a component and provide a place for the component&#39;s value...
Definition: sch_field.h:56
void RotateField(SCH_FIELD *aField)
STATUS_FLAGS GetFlags() const
Definition: base_struct.h:258
wxString GetName(bool aUseDefaultName=true) const
Function GetName returns the field name.
Definition: sch_field.cpp:435
#define TEXT_ANGLE_VERT
This file is part of the common library.
void OnModify()
Must be called after a schematic change in order to set the "modify" flag of the current screen* and ...
EDA_ITEM * GetParent() const
Definition: base_struct.h:211
void UpdateField(SCH_FIELD *aField, SCH_SHEET_PATH *aSheetPath)
virtual void MoveCursorToCrossHair()
Function MoveCursorToCrossHair warps the cursor to the current cross hair position.
void EditComponentFieldText(SCH_FIELD *aField)
Display the edit field dialog to edit the parameters of aField.
#define EDA_ITEM_ALL_FLAGS
Definition: base_struct.h:145
double GetTextAngle() const
Definition: eda_text.h:177
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
SCH_SHEET_PATH * m_CurrentSheet
which sheet we are presently working on.
#define SELECTED
Definition: base_struct.h:121
void SetMsgPanel(const std::vector< MSG_PANEL_ITEM > &aList)
Clear the message panel and populates it with the contents of aList.
int ShowQuasiModal()
const wxString & GetText() const
Function GetText returns the string associated with the text object.
Definition: eda_text.h:143
SCH_SHEET_PATH & GetCurrentSheet()
void SaveCopyInUndoList(SCH_ITEM *aItemToCopy, UNDO_REDO_T aTypeCommand, bool aAppend=false, const wxPoint &aTransformPoint=wxPoint(0, 0))
Create a copy of the current schematic item, and put it in the undo list.
#define BRIGHTENED
item is drawn with a bright contour
Definition: base_struct.h:138
Class DIALOG_SCH_EDIT_ONE_FIELD is a the class to handle editing a single component field in the sche...
bool m_autoplaceFields
automatically place component fields
EDA_DRAW_PANEL * m_canvas
The area to draw on.
Definition: draw_frame.h:123
Definition the SCH_COMPONENT class for Eeschema.
static const wxChar * GetChars(const wxString &s)
Function GetChars returns a wxChar* to the actual wxChar* data within a wxString, and is helpful for ...
Definition: macros.h:92
#define HIGHLIGHTED
item is drawn in normal colors, when the rest is darkened
Definition: base_struct.h:137
void RefreshItem(SCH_ITEM *aItem, bool isAddOrDelete=false)
Mark an item for refresh.
void SetIgnoreMouseEvents(bool aIgnore)
Class SCH_COMPONENT describes a real schematic component.
Definition: sch_component.h:69
std::vector< MSG_PANEL_ITEM > MSG_PANEL_ITEMS
Definition: msgpanel.h:102
Definition for part library class.
Message panel definition file.
EDA_UNITS_T m_UserUnits
Definition: draw_frame.h:120