Commit 5c3b480a authored by dickelbeck's avatar dickelbeck

center PCBNEW parts on screen when tracking clicks and parts from EESCHEMA

parent 6acce67a
...@@ -20,7 +20,11 @@ email address. ...@@ -20,7 +20,11 @@ email address.
in PCBNEW when there is more than one click candidate at the same mouse in PCBNEW when there is more than one click candidate at the same mouse
or cursor coordinates. COLLECTOR not committed yet. or cursor coordinates. COLLECTOR not committed yet.
* More beautification. * More beautification.
* The mouse click and part synchronization from EESCHEMA to PCBNEW would
track fine but would not always position the PCBNEW part on screen. Now
we center it unconditionally. No change was made in the reverse direction
since that code uses the long established Find support.
2007-Aug-14 UPDATE Dick Hollenbeck <dick@softplc.com> 2007-Aug-14 UPDATE Dick Hollenbeck <dick@softplc.com>
================================================================================ ================================================================================
......
...@@ -31,8 +31,10 @@ void RemoteCommand( const char* cmdline ) ...@@ -31,8 +31,10 @@ void RemoteCommand( const char* cmdline )
{ {
char line[1024]; char line[1024];
wxString msg; wxString msg;
char* idcmd, * text; char* idcmd;
char* text;
WinEDA_PcbFrame* frame = EDA_Appl->m_PcbFrame; WinEDA_PcbFrame* frame = EDA_Appl->m_PcbFrame;
MODULE* module;
strncpy( line, cmdline, sizeof(line) - 1 ); strncpy( line, cmdline, sizeof(line) - 1 );
msg = CONV_FROM_UTF8( line ); msg = CONV_FROM_UTF8( line );
...@@ -48,7 +50,7 @@ void RemoteCommand( const char* cmdline ) ...@@ -48,7 +50,7 @@ void RemoteCommand( const char* cmdline )
{ {
msg = CONV_FROM_UTF8( text ); msg = CONV_FROM_UTF8( text );
MODULE* module = ReturnModule( frame->m_Pcb, msg ); module = ReturnModule( frame->m_Pcb, msg );
msg.Printf( _( "Locate module %s %s" ), msg.GetData(), msg.Printf( _( "Locate module %s %s" ), msg.GetData(),
module ? wxT( "Ok" ) : wxT( "not found" ) ); module ? wxT( "Ok" ) : wxT( "not found" ) );
...@@ -68,7 +70,6 @@ void RemoteCommand( const char* cmdline ) ...@@ -68,7 +70,6 @@ void RemoteCommand( const char* cmdline )
if( idcmd && strcmp( idcmd, "$PIN:" ) == 0 ) if( idcmd && strcmp( idcmd, "$PIN:" ) == 0 )
{ {
wxString pinName, modName; wxString pinName, modName;
MODULE* module;
D_PAD* pad = NULL; D_PAD* pad = NULL;
int netcode = -1; int netcode = -1;
...@@ -112,6 +113,9 @@ void RemoteCommand( const char* cmdline ) ...@@ -112,6 +113,9 @@ void RemoteCommand( const char* cmdline )
msg.Printf( _( "Locate Pin %s (module %s)" ), pinName.GetData(), modName.GetData() ); msg.Printf( _( "Locate Pin %s (module %s)" ), pinName.GetData(), modName.GetData() );
frame->Affiche_Message( msg ); frame->Affiche_Message( msg );
} }
if( module ) // center the module on screen.
frame->Recadre_Trace( false );
} }
......
/************/ /************/
/* zoom.cpp */ /* zoom.cpp */
/************/ /************/
/* /*
Fonctions de gestion du zoom, du pas de grille et du * Fonctions de gestion du zoom, du pas de grille et du
recadrage automatique * recadrage automatique
*/ */
#include "fctsys.h" #include "fctsys.h"
#include "gr_basic.h" #include "gr_basic.h"
...@@ -38,404 +38,423 @@ ...@@ -38,404 +38,423 @@
/**************************************************/ /**************************************************/
void WinEDA_DrawFrame::Recadre_Trace(bool ToMouse) void WinEDA_DrawFrame::Recadre_Trace( bool ToMouse )
/**************************************************/ /**************************************************/
/* Calcule les offsets de trace. /* Calcule les offsets de trace.
Les offsets sont ajusts a un multiple du pas de grille * Les offsets sont ajusts a un multiple du pas de grille
si ToMouse == TRUE, le curseur souris (curseur "systeme") est replace * si ToMouse == TRUE, le curseur souris (curseur "systeme") est replace
en position curseur graphique (curseur kicad) * en position curseur graphique (curseur kicad)
*
Note: Mac OS ** does not ** allow moving mouse cursor by program. * Note: Mac OS ** does not ** allow moving mouse cursor by program.
*/ */
{ {
/* decalages a apporter au trace en coordonnees ecran */
PutOnGrid( &m_CurrentScreen->m_Curseur );
AdjustScrollBars();
/* decalages a apporter au trace en coordonnees ecran */ ReDrawPanel();
PutOnGrid(& m_CurrentScreen->m_Curseur) ;
AdjustScrollBars();
ReDrawPanel();
/* Place le curseur souris sur le curseur SCHEMA*/ /* Place le curseur souris sur le curseur SCHEMA*/
if ( ToMouse == TRUE ) if( ToMouse == TRUE )
DrawPanel->MouseToCursorSchema(); DrawPanel->MouseToCursorSchema();
} }
/************************************************/ /************************************************/
void WinEDA_DrawFrame::PutOnGrid(wxPoint * coord) void WinEDA_DrawFrame::PutOnGrid( wxPoint* coord )
/************************************************/ /************************************************/
/* retourne la valeur de la coordonnee coord sur le point de grille le plus proche */ /* retourne la valeur de la coordonnee coord sur le point de grille le plus proche */
{ {
double ftmp; double ftmp;
if ( ! m_CurrentScreen->m_UserGridIsON )
{ if( !m_CurrentScreen->m_UserGridIsON )
wxSize grid_size = m_CurrentScreen->GetGrid(); {
ftmp = (double)coord->x / grid_size.x; wxSize grid_size = m_CurrentScreen->GetGrid();
coord->x = ((int)round(ftmp)) * grid_size.x;
ftmp = (double) coord->x / grid_size.x;
ftmp = (double)coord->y / grid_size.y; coord->x = ( (int) round( ftmp ) ) * grid_size.x;
coord->y = ((int)round(ftmp)) * grid_size.y;
} ftmp = (double) coord->y / grid_size.y;
else coord->y = ( (int) round( ftmp ) ) * grid_size.y;
{ }
double pasx = m_CurrentScreen->m_UserGrid.x * m_InternalUnits; else
double pasy = m_CurrentScreen->m_UserGrid.y * m_InternalUnits; {
if ( m_CurrentScreen->m_UserGridUnit != INCHES ) double pasx = m_CurrentScreen->m_UserGrid.x * m_InternalUnits;
{ double pasy = m_CurrentScreen->m_UserGrid.y * m_InternalUnits;
pasx /= 25.4; pasy /= 25.4;
} if( m_CurrentScreen->m_UserGridUnit != INCHES )
int nn = (int) round( coord->x /pasx); {
coord->x = (int) round( pasx * nn); pasx /= 25.4;
nn = (int) round( coord->y /pasy); pasy /= 25.4;
coord->y = (int) round( pasy * nn); }
}
int nn = (int) round( coord->x / pasx );
coord->x = (int) round( pasx * nn );
nn = (int) round( coord->y / pasy );
coord->y = (int) round( pasy * nn );
}
} }
/**************************************************************/ /**************************************************************/
void WinEDA_DrawFrame::Zoom_Automatique(bool move_mouse_cursor) void WinEDA_DrawFrame::Zoom_Automatique( bool move_mouse_cursor )
/**************************************************************/ /**************************************************************/
/* Affiche le Schema au meilleur zoom au meilleur centrage pour le dessin /* Affiche le Schema au meilleur zoom au meilleur centrage pour le dessin
de facon a avoir toute la feuille affichee a l'ecran * de facon a avoir toute la feuille affichee a l'ecran
*/ */
{ {
int bestzoom; int bestzoom;
bestzoom = BestZoom(); bestzoom = BestZoom();
m_CurrentScreen->SetZoom(bestzoom); m_CurrentScreen->SetZoom( bestzoom );
Recadre_Trace(move_mouse_cursor); Recadre_Trace( move_mouse_cursor );
} }
/*************************************************/ /*************************************************/
void WinEDA_DrawFrame::Window_Zoom(EDA_Rect &Rect) void WinEDA_DrawFrame::Window_Zoom( EDA_Rect& Rect )
/*************************************************/ /*************************************************/
/* Compute the zoom factor and the new draw offset to draw the /* Compute the zoom factor and the new draw offset to draw the
selected area (Rect) in full window screen * selected area (Rect) in full window screen
*/ */
{ {
int ii, jj; int ii, jj;
int bestzoom; int bestzoom;
wxSize size; wxSize size;
/* Compute the best zoom */ /* Compute the best zoom */
Rect.Normalize(); Rect.Normalize();
size = DrawPanel->GetClientSize(); size = DrawPanel->GetClientSize();
ii = Rect.GetSize().x / size.x; ii = Rect.GetSize().x / size.x;
jj = Rect.GetSize().y / size.y; jj = Rect.GetSize().y / size.y;
bestzoom = MAX(ii, jj); bestzoom = MAX( ii, jj );
if ( bestzoom <= 0 ) bestzoom = 1; if( bestzoom <= 0 )
bestzoom = 1;
m_CurrentScreen->SetZoom(bestzoom);
m_CurrentScreen->SetZoom( bestzoom );
m_CurrentScreen->m_Curseur = Rect.Centre();
Recadre_Trace(TRUE); m_CurrentScreen->m_Curseur = Rect.Centre();
Recadre_Trace( TRUE );
} }
/*****************************************************************/ /*****************************************************************/
void WinEDA_DrawPanel::Process_Popup_Zoom( wxCommandEvent &event ) void WinEDA_DrawPanel::Process_Popup_Zoom( wxCommandEvent& event )
/*****************************************************************/ /*****************************************************************/
/* Gere les commandes de zoom appeles par le menu Popup /* Gere les commandes de zoom appeles par le menu Popup
Toute autre commande est transmise a Parent->Process_Special_Functions(event) * Toute autre commande est transmise a Parent->Process_Special_Functions(event)
*/ */
{ {
int id = event.GetId(); int id = event.GetId();
wxClientDC dc(this); wxClientDC dc( this );
switch (id) switch( id )
{ {
case ID_POPUP_ZOOM_PLUS : case ID_POPUP_ZOOM_PLUS:
case ID_POPUP_ZOOM_MOINS : case ID_POPUP_ZOOM_MOINS:
case ID_POPUP_ZOOM_CENTER : case ID_POPUP_ZOOM_CENTER:
case ID_POPUP_ZOOM_AUTO : case ID_POPUP_ZOOM_AUTO:
case ID_POPUP_ZOOM_REDRAW : case ID_POPUP_ZOOM_REDRAW:
m_Parent->OnZoom(id); m_Parent->OnZoom( id );
break; break;
case ID_POPUP_ZOOM_SELECT : case ID_POPUP_ZOOM_SELECT:
break; break;
case ID_POPUP_CANCEL : case ID_POPUP_CANCEL:
MouseToCursorSchema(); MouseToCursorSchema();
break; break;
case ID_POPUP_ZOOM_LEVEL_1 : case ID_POPUP_ZOOM_LEVEL_1:
m_Parent->m_CurrentScreen->SetZoom(1); m_Parent->m_CurrentScreen->SetZoom( 1 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_2 : case ID_POPUP_ZOOM_LEVEL_2:
m_Parent->m_CurrentScreen->SetZoom(2); m_Parent->m_CurrentScreen->SetZoom( 2 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_4 : case ID_POPUP_ZOOM_LEVEL_4:
m_Parent->m_CurrentScreen->SetZoom(4); m_Parent->m_CurrentScreen->SetZoom( 4 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_8 : case ID_POPUP_ZOOM_LEVEL_8:
m_Parent->m_CurrentScreen->SetZoom(8); m_Parent->m_CurrentScreen->SetZoom( 8 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_16 : case ID_POPUP_ZOOM_LEVEL_16:
m_Parent->m_CurrentScreen->SetZoom(16); m_Parent->m_CurrentScreen->SetZoom( 16 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_32 : case ID_POPUP_ZOOM_LEVEL_32:
m_Parent->m_CurrentScreen->SetZoom(32); m_Parent->m_CurrentScreen->SetZoom( 32 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_64 : case ID_POPUP_ZOOM_LEVEL_64:
m_Parent->m_CurrentScreen->SetZoom(64); m_Parent->m_CurrentScreen->SetZoom( 64 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_128 : case ID_POPUP_ZOOM_LEVEL_128:
m_Parent->m_CurrentScreen->SetZoom(128); m_Parent->m_CurrentScreen->SetZoom( 128 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_256 : case ID_POPUP_ZOOM_LEVEL_256:
m_Parent->m_CurrentScreen->SetZoom(256); m_Parent->m_CurrentScreen->SetZoom( 256 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_512 : case ID_POPUP_ZOOM_LEVEL_512:
m_Parent->m_CurrentScreen->SetZoom(512); m_Parent->m_CurrentScreen->SetZoom( 512 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_1024 : case ID_POPUP_ZOOM_LEVEL_1024:
m_Parent->m_CurrentScreen->SetZoom(1024); m_Parent->m_CurrentScreen->SetZoom( 1024 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_ZOOM_LEVEL_2048 : case ID_POPUP_ZOOM_LEVEL_2048:
m_Parent->m_CurrentScreen->SetZoom(2048); m_Parent->m_CurrentScreen->SetZoom( 2048 );
m_Parent->Recadre_Trace(TRUE); m_Parent->Recadre_Trace( TRUE );
break; break;
case ID_POPUP_GRID_LEVEL_1 : case ID_POPUP_GRID_LEVEL_1:
m_Parent->m_CurrentScreen->SetGrid(wxSize(1,1)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 1, 1 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_2 : case ID_POPUP_GRID_LEVEL_2:
m_Parent->m_CurrentScreen->SetGrid(wxSize(2,2)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 2, 2 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_5 : case ID_POPUP_GRID_LEVEL_5:
m_Parent->m_CurrentScreen->SetGrid(wxSize(5,5)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 5, 5 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_10 : case ID_POPUP_GRID_LEVEL_10:
m_Parent->m_CurrentScreen->SetGrid(wxSize(10,10)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 10, 10 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_20 : case ID_POPUP_GRID_LEVEL_20:
m_Parent->m_CurrentScreen->SetGrid(wxSize(20,20)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 20, 20 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_25 : case ID_POPUP_GRID_LEVEL_25:
m_Parent->m_CurrentScreen->SetGrid(wxSize(25,25)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 25, 25 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_50 : case ID_POPUP_GRID_LEVEL_50:
m_Parent->m_CurrentScreen->SetGrid(wxSize(50,50)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 50, 50 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_100 : case ID_POPUP_GRID_LEVEL_100:
m_Parent->m_CurrentScreen->SetGrid(wxSize(100,100)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 100, 100 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_200 : case ID_POPUP_GRID_LEVEL_200:
m_Parent->m_CurrentScreen->SetGrid(wxSize(200,200)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 200, 200 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_250 : case ID_POPUP_GRID_LEVEL_250:
m_Parent->m_CurrentScreen->SetGrid(wxSize(250,250)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 250, 250 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_500 : case ID_POPUP_GRID_LEVEL_500:
m_Parent->m_CurrentScreen->SetGrid(wxSize(500,500)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 500, 500 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_LEVEL_1000 : case ID_POPUP_GRID_LEVEL_1000:
m_Parent->m_CurrentScreen->SetGrid(wxSize(1000,1000)); m_Parent->m_CurrentScreen->SetGrid( wxSize( 1000, 1000 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
case ID_POPUP_GRID_USER : case ID_POPUP_GRID_USER:
m_Parent->m_CurrentScreen->SetGrid(wxSize(-1,-1)); m_Parent->m_CurrentScreen->SetGrid( wxSize( -1, -1 ) );
m_Parent->ReDrawPanel(); m_Parent->ReDrawPanel();
break; break;
default: default:
DisplayError(this, wxT("WinEDA_DrawPanel::Process_Popup_Zoom() ID error") ); DisplayError( this, wxT( "WinEDA_DrawPanel::Process_Popup_Zoom() ID error" ) );
break; break;
} }
m_Parent->Affiche_Status_Box(); m_Parent->Affiche_Status_Box();
} }
class grid_list_struct class grid_list_struct
{ {
public: public:
int m_value; int m_value;
int m_id; int m_id;
const wxChar * m_msg; const wxChar* m_msg;
}; };
/*************************************************************/ /*************************************************************/
void WinEDA_DrawPanel::AddMenuZoom( wxMenu * MasterMenu ) void WinEDA_DrawPanel::AddMenuZoom( wxMenu* MasterMenu )
/*************************************************************/ /*************************************************************/
/* add the zoom list menu the the MasterMenu.
used in OnRightClick(wxMouseEvent& event)
*/
{
int zoom;
wxSize grid;
int zoom_value;
wxString zoom_msg = _("Zoom: ");
wxString grid_msg = _("Grid:"), msg;
int ii;
wxString line;
grid_list_struct grid_list_pcb[] =
{
{ 1000, ID_POPUP_GRID_LEVEL_1000, wxT(" 100") },
{ 500, ID_POPUP_GRID_LEVEL_500, wxT(" 50") },
{ 250, ID_POPUP_GRID_LEVEL_250, wxT(" 25") },
{ 200, ID_POPUP_GRID_LEVEL_200, wxT(" 20") },
{ 100, ID_POPUP_GRID_LEVEL_100, wxT(" 10") },
{ 50, ID_POPUP_GRID_LEVEL_50, wxT(" 5") },
{ 25, ID_POPUP_GRID_LEVEL_25, wxT(" 2.5") },
{ 20, ID_POPUP_GRID_LEVEL_20, wxT(" 2") },
{ 10, ID_POPUP_GRID_LEVEL_10, wxT(" 1") },
{ 5, ID_POPUP_GRID_LEVEL_5, wxT(" 0.5") },
{ 2, ID_POPUP_GRID_LEVEL_2, wxT(" 0.2") },
{ 1, ID_POPUP_GRID_LEVEL_1, wxT(" 0.1") },
{ 0, ID_POPUP_GRID_USER, _("grid user") }
};
grid_list_struct grid_list_schematic[] = /* add the zoom list menu the the MasterMenu.
* used in OnRightClick(wxMouseEvent& event)
*/
{ {
{ 50, ID_POPUP_GRID_LEVEL_50, wxT(" 50") }, int zoom;
{ 25, ID_POPUP_GRID_LEVEL_25, wxT(" 25") }, wxSize grid;
{ 10, ID_POPUP_GRID_LEVEL_10, wxT(" 10") }, int zoom_value;
{ 5, ID_POPUP_GRID_LEVEL_5, wxT(" 5") }, wxString zoom_msg = _( "Zoom: " );
{ 2, ID_POPUP_GRID_LEVEL_2, wxT(" 2") }, wxString grid_msg = _( "Grid:" ), msg;
{ 1, ID_POPUP_GRID_LEVEL_1, wxT(" 1") }, int ii;
{ 0, ID_POPUP_GRID_USER, _("grid user") } wxString line;
};
grid_list_struct grid_list_pcb[] =
{
ADD_MENUITEM(MasterMenu, ID_POPUP_ZOOM_CENTER, _("Center"), zoom_center_xpm); { 1000, ID_POPUP_GRID_LEVEL_1000, wxT( " 100" ) },
ADD_MENUITEM(MasterMenu, ID_POPUP_ZOOM_PLUS, _("Zoom +"), zoom_in_xpm); { 500, ID_POPUP_GRID_LEVEL_500, wxT( " 50" ) },
ADD_MENUITEM(MasterMenu, ID_POPUP_ZOOM_MOINS, _("Zoom -"), zoom_out_xpm); { 250, ID_POPUP_GRID_LEVEL_250, wxT( " 25" ) },
{ 200, ID_POPUP_GRID_LEVEL_200, wxT( " 20" ) },
wxMenu * zoom_choice = new wxMenu; { 100, ID_POPUP_GRID_LEVEL_100, wxT( " 10" ) },
ADD_MENUITEM_WITH_SUBMENU(MasterMenu, zoom_choice, { 50, ID_POPUP_GRID_LEVEL_50, wxT( " 5" ) },
ID_POPUP_ZOOM_SELECT, _("Zoom Select"), zoom_select_xpm); { 25, ID_POPUP_GRID_LEVEL_25, wxT( " 2.5" ) },
{ 20, ID_POPUP_GRID_LEVEL_20, wxT( " 2" ) },
ADD_MENUITEM(MasterMenu, ID_POPUP_ZOOM_AUTO, _("Auto"), zoom_optimal_xpm); { 10, ID_POPUP_GRID_LEVEL_10, wxT( " 1" ) },
ADD_MENUITEM(MasterMenu, ID_POPUP_ZOOM_REDRAW, _("Redraw"), repaint_xpm); { 5, ID_POPUP_GRID_LEVEL_5, wxT( " 0.5" ) },
{ 2, ID_POPUP_GRID_LEVEL_2, wxT( " 0.2" ) },
/* Create the basic zoom list: */ { 1, ID_POPUP_GRID_LEVEL_1, wxT( " 0.1" ) },
zoom = m_Parent->m_CurrentScreen->GetZoom(); { 0, ID_POPUP_GRID_USER, _( "grid user" ) }
zoom_value = 1; };
for ( ii = 0; zoom_value <= m_Parent->m_ZoomMaxValue; zoom_value <<= 1, ii ++ ) // Create zoom choice 1 .. zoom max
{ grid_list_struct grid_list_schematic[] =
line.Printf( wxT("%u"), zoom_value); {
zoom_choice->Append(ID_POPUP_ZOOM_LEVEL_1 + ii, { 50, ID_POPUP_GRID_LEVEL_50, wxT( " 50" ) },
zoom_msg + line, wxEmptyString,TRUE); { 25, ID_POPUP_GRID_LEVEL_25, wxT( " 25" ) },
if( zoom == zoom_value ) { 10, ID_POPUP_GRID_LEVEL_10, wxT( " 10" ) },
zoom_choice->Check(ID_POPUP_ZOOM_LEVEL_1 + ii, TRUE); { 5, ID_POPUP_GRID_LEVEL_5, wxT( " 5" ) },
} { 2, ID_POPUP_GRID_LEVEL_2, wxT( " 2" ) },
{ 1, ID_POPUP_GRID_LEVEL_1, wxT( " 1" ) },
wxMenu * grid_choice = new wxMenu; { 0, ID_POPUP_GRID_USER, _( "grid user" ) }
ADD_MENUITEM_WITH_SUBMENU(MasterMenu, grid_choice, };
ID_POPUP_GRID_SELECT, _("Grid Select"), grid_select_xpm);
grid = m_Parent->m_CurrentScreen->GetGrid(); ADD_MENUITEM( MasterMenu, ID_POPUP_ZOOM_CENTER, _( "Center" ), zoom_center_xpm );
switch(m_Parent->m_Ident ) ADD_MENUITEM( MasterMenu, ID_POPUP_ZOOM_PLUS, _( "Zoom +" ), zoom_in_xpm );
{ ADD_MENUITEM( MasterMenu, ID_POPUP_ZOOM_MOINS, _( "Zoom -" ), zoom_out_xpm );
case MODULE_EDITOR_FRAME:
case GERBER_FRAME: wxMenu* zoom_choice = new wxMenu;
case PCB_FRAME: ADD_MENUITEM_WITH_SUBMENU( MasterMenu, zoom_choice,
case CVPCB_DISPLAY_FRAME: ID_POPUP_ZOOM_SELECT, _( "Zoom Select" ), zoom_select_xpm );
for ( ii = 0; ; ii ++ ) // Create grid list
{ ADD_MENUITEM( MasterMenu, ID_POPUP_ZOOM_AUTO, _( "Auto" ), zoom_optimal_xpm );
msg = grid_msg + grid_list_pcb[ii].m_msg; ADD_MENUITEM( MasterMenu, ID_POPUP_ZOOM_REDRAW, _( "Redraw" ), repaint_xpm );
grid_choice->Append(grid_list_pcb[ii].m_id, msg, wxEmptyString, TRUE);
if( grid_list_pcb[ii].m_value <= 0 ) /* Create the basic zoom list: */
{ zoom = m_Parent->m_CurrentScreen->GetZoom();
if ( m_Parent->m_CurrentScreen->m_UserGridIsON ) zoom_value = 1;
grid_choice->Check(grid_list_pcb[ii].m_id, TRUE); for( ii = 0; zoom_value <= m_Parent->m_ZoomMaxValue; zoom_value <<= 1, ii++ ) // Create zoom choice 1 .. zoom max
break; {
} line.Printf( wxT( "%u" ), zoom_value );
if( grid.x == grid_list_pcb[ii].m_value ) zoom_choice->Append( ID_POPUP_ZOOM_LEVEL_1 + ii,
grid_choice->Check(grid_list_pcb[ii].m_id, TRUE); zoom_msg + line, wxEmptyString, TRUE );
} if( zoom == zoom_value )
break; zoom_choice->Check( ID_POPUP_ZOOM_LEVEL_1 + ii, TRUE );
}
case SCHEMATIC_FRAME:
case LIBEDITOR_FRAME: wxMenu* grid_choice = new wxMenu;
for ( ii = 0; ; ii ++ ) // Create zoom choice 256 .. 1024 ADD_MENUITEM_WITH_SUBMENU( MasterMenu, grid_choice,
{ ID_POPUP_GRID_SELECT, _( "Grid Select" ), grid_select_xpm );
if ( grid_list_schematic[ii].m_value <= 0)
break; grid = m_Parent->m_CurrentScreen->GetGrid();
msg = grid_msg + grid_list_schematic[ii].m_msg;
grid_choice->Append(grid_list_schematic[ii].m_id, switch( m_Parent->m_Ident )
msg, wxEmptyString, TRUE); {
if( grid.x == grid_list_schematic[ii].m_value ) case MODULE_EDITOR_FRAME:
grid_choice->Check(grid_list_schematic[ii].m_id, TRUE); case GERBER_FRAME:
} case PCB_FRAME:
break; case CVPCB_DISPLAY_FRAME:
for( ii = 0; ; ii++ ) // Create grid list
case VIEWER_FRAME: {
break; msg = grid_msg + grid_list_pcb[ii].m_msg;
} grid_choice->Append( grid_list_pcb[ii].m_id, msg, wxEmptyString, TRUE );
if( grid_list_pcb[ii].m_value <= 0 )
MasterMenu->AppendSeparator(); {
ADD_MENUITEM(MasterMenu, ID_POPUP_CANCEL, _("Close"), cancel_xpm); if( m_Parent->m_CurrentScreen->m_UserGridIsON )
grid_choice->Check( grid_list_pcb[ii].m_id, TRUE );
break;
}
if( grid.x == grid_list_pcb[ii].m_value )
grid_choice->Check( grid_list_pcb[ii].m_id, TRUE );
}
break;
case SCHEMATIC_FRAME:
case LIBEDITOR_FRAME:
for( ii = 0; ; ii++ ) // Create zoom choice 256 .. 1024
{
if( grid_list_schematic[ii].m_value <= 0 )
break;
msg = grid_msg + grid_list_schematic[ii].m_msg;
grid_choice->Append( grid_list_schematic[ii].m_id,
msg, wxEmptyString, TRUE );
if( grid.x == grid_list_schematic[ii].m_value )
grid_choice->Check( grid_list_schematic[ii].m_id, TRUE );
}
break;
case VIEWER_FRAME:
break;
}
MasterMenu->AppendSeparator();
ADD_MENUITEM( MasterMenu, ID_POPUP_CANCEL, _( "Close" ), cancel_xpm );
} }
/**********************************************************/ /**********************************************************/
void WinEDA_DrawFrame::Process_Zoom(wxCommandEvent& event) void WinEDA_DrawFrame::Process_Zoom( wxCommandEvent& event )
/**********************************************************/ /**********************************************************/
/* fonction de traitement des boutons de Zoom. /* fonction de traitement des boutons de Zoom.
Appelle simplement la fonction de traitement du Zoom de la * Appelle simplement la fonction de traitement du Zoom de la
fenetre active. * fenetre active.
*/ */
{ {
int id = event.GetId(); int id = event.GetId();
switch (id) switch( id )
{ {
case ID_ZOOM_PLUS_BUTT: case ID_ZOOM_PLUS_BUTT:
case ID_ZOOM_MOINS_BUTT: case ID_ZOOM_MOINS_BUTT:
case ID_ZOOM_REDRAW_BUTT: case ID_ZOOM_REDRAW_BUTT:
case ID_ZOOM_PAGE_BUTT: case ID_ZOOM_PAGE_BUTT:
OnZoom(id); OnZoom( id );
break; break;
default: default:
DisplayError(this, wxT("WinEDA_DrawFrame::Process_Zoom id Error") ); DisplayError( this, wxT( "WinEDA_DrawFrame::Process_Zoom id Error" ) );
break; break;
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment