From db49e2a50592677179f18b198d7ef9d506f2b03d Mon Sep 17 00:00:00 2001 From: charras Date: Tue, 27 Oct 2009 10:55:46 +0000 Subject: [PATCH] some minor bug fixes and enhancements --- eeschema/class_sch_component.cpp | 3 +- eeschema/find.cpp | 1 + eeschema/getpart.cpp | 6 +- pcbnew/class_track.cpp | 95 +++++++++++++++++--------------- 4 files changed, 59 insertions(+), 46 deletions(-) diff --git a/eeschema/class_sch_component.cpp b/eeschema/class_sch_component.cpp index d7e78837ae..a0ccd9ab69 100644 --- a/eeschema/class_sch_component.cpp +++ b/eeschema/class_sch_component.cpp @@ -110,9 +110,10 @@ SCH_COMPONENT::SCH_COMPONENT( LIB_COMPONENT& libComponent, DrawSheetPath* sheet, if( msg.IsEmpty() ) msg = wxT( "U" ); - msg += wxT( "?" ); + m_PrefixString = msg; // update the reference -- just the prefix for now. + msg += wxT( "?" ); SetRef( sheet, msg ); /* Use the schematic component name instead of the library value field diff --git a/eeschema/find.cpp b/eeschema/find.cpp index 9f4411b584..6228698b3a 100644 --- a/eeschema/find.cpp +++ b/eeschema/find.cpp @@ -656,6 +656,7 @@ void WinEDA_FindFrame::LocatePartInLibs( wxCommandEvent& event ) BOOST_FOREACH( CMP_LIBRARY& lib, CMP_LIBRARY::GetLibraryList() ) { + nameList.Clear(); lib.SearchEntryNames( nameList, Text ); if( nameList.IsEmpty() ) diff --git a/eeschema/getpart.cpp b/eeschema/getpart.cpp index 4ae1802532..d94fffc2d0 100644 --- a/eeschema/getpart.cpp +++ b/eeschema/getpart.cpp @@ -200,10 +200,12 @@ SCH_COMPONENT* WinEDA_SchematicFrame::Load_Component( wxDC* DC, Component = new SCH_COMPONENT( *Entry, GetSheet(), unit, convert, GetScreen()->m_Curseur, true ); - DrawStructsInGhost( DrawPanel, DC, Component, wxPoint( 0, 0 ) ); - + // Set the component value (that can differ from component name in lib, for aliases) + Component->GetField( VALUE )->m_Text = Name; Component->DisplayInfo( this ); + DrawStructsInGhost( DrawPanel, DC, Component, wxPoint( 0, 0 ) ); + return Component; } diff --git a/pcbnew/class_track.cpp b/pcbnew/class_track.cpp index 9ba74f4865..ffb35b0f30 100644 --- a/pcbnew/class_track.cpp +++ b/pcbnew/class_track.cpp @@ -558,7 +558,8 @@ void TRACK::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin { color = g_DesignSettings.m_LayerColor[m_Layer]; - if( g_DesignSettings.IsLayerVisible( m_Layer ) == false && ( color & HIGHT_LIGHT_FLAG ) != HIGHT_LIGHT_FLAG ) + if( g_DesignSettings.IsLayerVisible( m_Layer ) == false && ( color & HIGHT_LIGHT_FLAG ) != + HIGHT_LIGHT_FLAG ) return; if( DisplayOpt.ContrastModeDisplay ) @@ -708,13 +709,13 @@ void TRACK::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoin void SEGVIA::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoint& notUsed ) /*******************************************************************************************/ { - int color; - int rayon; - int curr_layer = ( (PCB_SCREEN*) panel->GetScreen() )->m_Active_Layer; + int color; + int rayon; + int curr_layer = ( (PCB_SCREEN*) panel->GetScreen() )->m_Active_Layer; - int fillvia = 0; - WinEDA_BasePcbFrame* frame = (WinEDA_BasePcbFrame*) panel->m_Parent; - PCB_SCREEN* screen = frame->GetScreen(); + int fillvia = 0; + WinEDA_BasePcbFrame* frame = (WinEDA_BasePcbFrame*) panel->m_Parent; + PCB_SCREEN* screen = frame->GetScreen(); if( frame->m_DisplayViaFill == FILLED ) fillvia = 1; @@ -723,7 +724,8 @@ void SEGVIA::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoi color = g_DesignSettings.m_ViaColor[m_Shape]; - if( g_DesignSettings.IsElementVisible( VIAS_VISIBLE + m_Shape ) == false && ( color & HIGHT_LIGHT_FLAG ) != HIGHT_LIGHT_FLAG ) + if( g_DesignSettings.IsElementVisible( VIAS_VISIBLE + m_Shape ) == false + && ( color & HIGHT_LIGHT_FLAG ) != HIGHT_LIGHT_FLAG ) return; if( DisplayOpt.ContrastModeDisplay ) @@ -750,22 +752,30 @@ void SEGVIA::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoi rayon = m_Width >> 1; - if( panel->GetScreen()->Scale( rayon ) <= 4 ) + // for small via size on screen (rayon < 4 pixels) draw a simplified shape + int radius_in_pixels = panel->GetScreen()->Scale( rayon ); + bool fast_draw = false; + + // Vias are drawn as a filled circle or a double circle. The hole will be drawn later + int drill_rayon = GetDrillValue() / 2; + int inner_rayon = rayon - panel->GetScreen()->Unscale( 2 ); + if( radius_in_pixels < 3 ) { - GRCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, rayon, color ); - return; + fast_draw = true; + fillvia = false; } if( fillvia ) GRFilledCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, rayon, 0, color, color ); + else + { GRCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, rayon, color ); - - int drill_rayon = GetDrillValue() / 2; - int inner_rayon = rayon - panel->GetScreen()->Unscale( 2 ); - - GRCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, - inner_rayon, color ); + if ( fast_draw ) + return; + GRCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, + inner_rayon, color ); + } // Draw the via hole if the display option allows it if( DisplayOpt.m_DisplayViaMode != VIA_HOLE_NOT_SHOW ) @@ -773,37 +783,35 @@ void SEGVIA::Draw( WinEDA_DrawPanel* panel, wxDC* DC, int draw_mode, const wxPoi if( (DisplayOpt.m_DisplayViaMode == ALL_VIA_HOLE_SHOW) // Display all drill holes requested || ( (drill_rayon > 0 ) && !IsDrillDefault() ) ) // Or Display non default holes requested { - if( drill_rayon < inner_rayon ) // We can show the via hole + if( fillvia ) { - if( fillvia ) + bool blackpenstate = false; + if( screen->m_IsPrinting ) { - bool blackpenstate = false; - if( screen->m_IsPrinting ) - { - blackpenstate = GetGRForceBlackPenState(); - GRForceBlackPen( false ); - color = g_DrawBgColor; - } - else - color = BLACK; // or DARKGRAY; - - if( draw_mode != GR_XOR ) - GRSetDrawMode( DC, GR_COPY ); - else - GRSetDrawMode( DC, GR_XOR ); - - if( screen->Scale( drill_rayon ) > 1 ) /* draw hole if its size is enought */ - GRFilledCircle( &panel->m_ClipBox, DC, m_Start.x, - m_Start.y, drill_rayon, 0, color, color ); - - if( screen->m_IsPrinting ) - GRForceBlackPen( blackpenstate ); + blackpenstate = GetGRForceBlackPenState(); + GRForceBlackPen( false ); + color = g_DrawBgColor; } else - { + color = BLACK; // or DARKGRAY; + + if( draw_mode != GR_XOR ) + GRSetDrawMode( DC, GR_COPY ); + else + GRSetDrawMode( DC, GR_XOR ); + + if( screen->Scale( drill_rayon ) > 1 ) /* draw hole if its size is enought */ + GRFilledCircle( &panel->m_ClipBox, DC, m_Start.x, + m_Start.y, drill_rayon, 0, color, color ); + + if( screen->m_IsPrinting ) + GRForceBlackPen( blackpenstate ); + } + else + { + if( drill_rayon < inner_rayon ) // We can show the via hole GRCircle( &panel->m_ClipBox, DC, m_Start.x, m_Start.y, drill_rayon, color ); - } } } } @@ -905,13 +913,14 @@ void TRACK::DisplayInfo( WinEDA_DrawFrame* frame ) // Display full track length (in pcbnew) if( frame->m_Ident == PCB_FRAME ) { - int trackLen = 0; + int trackLen = 0; Marque_Une_Piste( board, this, NULL, &trackLen, false ); valeur_param( trackLen, msg ); frame->AppendMsgPanel( _( "Track Length" ), msg, DARKCYAN ); } } + /* * Function DisplayInfoBase * has knowledge about the frame and how and where to put status information