From 4b85c0110123dc334c2e4b48828534031f72b8e2 Mon Sep 17 00:00:00 2001 From: charras Date: Thu, 25 Mar 2010 07:39:53 +0000 Subject: [PATCH] Libedit: fixed incorrect undo/redo after moving a field --- common/CMakeLists.txt | 1 - eeschema/libfield.cpp | 51 +++++++++++++++++++++++++------------------ 2 files changed, 30 insertions(+), 22 deletions(-) diff --git a/common/CMakeLists.txt b/common/CMakeLists.txt index 6783731288..d1bfb28988 100644 --- a/common/CMakeLists.txt +++ b/common/CMakeLists.txt @@ -45,7 +45,6 @@ set(COMMON_SRCS msgpanel.cpp newstroke_font.cpp projet_config.cpp -# pyhandler.cpp richio.cpp selcolor.cpp string.cpp diff --git a/eeschema/libfield.cpp b/eeschema/libfield.cpp index 797142bd63..b256174cf4 100644 --- a/eeschema/libfield.cpp +++ b/eeschema/libfield.cpp @@ -19,10 +19,10 @@ static void ShowMoveField( WinEDA_DrawPanel* panel, wxDC* DC, bool erase ); extern int m_unit; -static wxPoint StartCursor, LastTextPosition; +static wxPoint s_InitialPosition, s_LastPosition; -static void ExitMoveField( WinEDA_DrawPanel* Panel, wxDC* DC ) +static void AbortMoveField( WinEDA_DrawPanel* Panel, wxDC* DC ) { Panel->ManageCurseur = NULL; Panel->ForceCloseManageCurseur = NULL; @@ -39,8 +39,8 @@ static void ExitMoveField( WinEDA_DrawPanel* Panel, wxDC* DC ) wxPoint curpos = Panel->GetScreen()->m_Curseur; - Panel->GetScreen()->m_Curseur = StartCursor; - ShowMoveField( Panel, DC, TRUE ); + Panel->GetScreen()->m_Curseur = s_InitialPosition; + ShowMoveField( Panel, DC, true ); Panel->GetScreen()->m_Curseur = curpos; item->m_Flags = 0; parent->SetDrawItem( NULL ); @@ -55,19 +55,19 @@ void WinEDA_LibeditFrame::StartMoveField( wxDC* DC, LIB_FIELD* field ) return; m_drawItem = field; - LastTextPosition = field->m_Pos; + s_InitialPosition = field->m_Pos; + NEGATE(s_InitialPosition.y); m_drawItem->m_Flags |= IS_MOVED; - startPos.x = LastTextPosition.x; - startPos.y = -LastTextPosition.y; DrawPanel->CursorOff( DC ); - GetScreen()->m_Curseur = startPos; + s_LastPosition = s_InitialPosition; + GetScreen()->m_Curseur = s_InitialPosition; DrawPanel->MouseToCursorSchema(); DrawPanel->ManageCurseur = ShowMoveField; - DrawPanel->ForceCloseManageCurseur = ExitMoveField; - DrawPanel->ManageCurseur( DrawPanel, DC, TRUE ); - StartCursor = GetScreen()->m_Curseur; + DrawPanel->ForceCloseManageCurseur = AbortMoveField; + DrawPanel->ManageCurseur( DrawPanel, DC, true ); + s_InitialPosition = GetScreen()->m_Curseur; DrawPanel->CursorOn( DC ); } @@ -90,16 +90,19 @@ static void ShowMoveField( WinEDA_DrawPanel* panel, wxDC* DC, bool erase ) return; wxString text = Field->GetFullText( parent->GetUnit() ); + wxPoint offset ; + offset.x = s_LastPosition.x - Field->m_Pos.x; + offset.y = s_LastPosition.y + Field->m_Pos.y; if( erase ) - Field->Draw( panel, DC, wxPoint( 0, 0 ), -1, g_XorMode, &text, + Field->Draw( panel, DC, offset, -1, g_XorMode, &text, DefaultTransformMatrix ); - LastTextPosition.x = panel->GetScreen()->m_Curseur.x; - LastTextPosition.y = -panel->GetScreen()->m_Curseur.y; + s_LastPosition = panel->GetScreen()->m_Curseur; + offset.x = s_LastPosition.x - Field->m_Pos.x; + offset.y = s_LastPosition.y + Field->m_Pos.y; - Field->m_Pos = LastTextPosition; - Field->Draw( panel, DC, wxPoint( 0, 0 ), -1, g_XorMode, &text, + Field->Draw( panel, DC, offset, -1, g_XorMode, &text, DefaultTransformMatrix ); } @@ -240,20 +243,26 @@ void WinEDA_LibeditFrame::RotateField( wxDC* DC, LIB_FIELD* Field ) wxString fieldText = Field->GetFullText( m_unit ); - Field->Draw( DrawPanel, DC, wxPoint( 0, 0 ), -1, g_XorMode, &fieldText, + if( (Field->m_Flags & IS_MOVED) ) + ShowMoveField( DrawPanel, DC, false ); + else + Field->Draw( DrawPanel, DC, wxPoint( 0, 0 ), -1, g_XorMode, &fieldText, DefaultTransformMatrix ); - if( Field->m_Orient ) - Field->m_Orient = 0; + if( Field->m_Orient == TEXT_ORIENT_VERT) + Field->m_Orient = TEXT_ORIENT_HORIZ; else - Field->m_Orient = 900; + Field->m_Orient = TEXT_ORIENT_VERT; int drawMode = g_XorMode; if( Field->m_Flags == 0 ) drawMode = GR_DEFAULT_DRAWMODE; - Field->Draw( DrawPanel, DC, wxPoint( 0, 0 ), -1, drawMode, &fieldText, + if( (Field->m_Flags & IS_MOVED) ) + ShowMoveField( DrawPanel, DC, false ); + else + Field->Draw( DrawPanel, DC, wxPoint( 0, 0 ), -1, drawMode, &fieldText, DefaultTransformMatrix ); DrawPanel->CursorOn( DC );