Try with KIPLATFORM
This commit is contained in:
parent
b0cca4a89e
commit
c4a4862e8f
|
@ -37,6 +37,7 @@
|
||||||
#include <sch_reference_list.h>
|
#include <sch_reference_list.h>
|
||||||
#include <schematic.h>
|
#include <schematic.h>
|
||||||
#include <tools/sch_editor_control.h>
|
#include <tools/sch_editor_control.h>
|
||||||
|
#include <kiplatform/ui.h>
|
||||||
#include <widgets/grid_text_button_helpers.h>
|
#include <widgets/grid_text_button_helpers.h>
|
||||||
#include <widgets/wx_grid.h>
|
#include <widgets/wx_grid.h>
|
||||||
#include <wx/grid.h>
|
#include <wx/grid.h>
|
||||||
|
@ -1170,14 +1171,8 @@ void DIALOG_SYMBOL_FIELDS_TABLE::OnTableItemContextMenu( wxGridEvent& event )
|
||||||
|
|
||||||
void DIALOG_SYMBOL_FIELDS_TABLE::OnSizeFieldList( wxSizeEvent& event )
|
void DIALOG_SYMBOL_FIELDS_TABLE::OnSizeFieldList( wxSizeEvent& event )
|
||||||
{
|
{
|
||||||
// GetClientSize subtracts scrollbars width on Windows.
|
int nameColWidth = KIPLATFORM::UI::GetUnobscuredSize( m_fieldsCtrl ).x - m_showColWidth
|
||||||
// On other platforms, the visible area must be computed manually.
|
- m_groupByColWidth;
|
||||||
#ifdef __WINDOWS__
|
|
||||||
int nameColWidth = m_fieldsCtrl->GetClientSize().x - m_showColWidth - m_groupByColWidth;
|
|
||||||
#else
|
|
||||||
int nameColWidth = event.GetSize().GetX() - m_showColWidth - m_groupByColWidth
|
|
||||||
- wxSystemSettings::GetMetric( wxSYS_VSCROLL_X );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// GTK loses its head and messes these up when resizing the splitter bar:
|
// GTK loses its head and messes these up when resizing the splitter bar:
|
||||||
m_fieldsCtrl->GetColumn( SHOW_FIELD_COLUMN )->SetWidth( m_showColWidth );
|
m_fieldsCtrl->GetColumn( SHOW_FIELD_COLUMN )->SetWidth( m_showColWidth );
|
||||||
|
|
|
@ -120,3 +120,10 @@ double KIPLATFORM::UI::GetSystemScaleFactor( const wxWindow* aWindow )
|
||||||
|
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wxSize KIPLATFORM::UI::GetUnobscuredSize( const wxWindow* aWindow )
|
||||||
|
{
|
||||||
|
return wxSize( aWindow->GetSize().GetX() - wxSystemSettings::GetMetric( wxSYS_VSCROLL_X ),
|
||||||
|
aWindow->GetSize().GetY() - wxSystemSettings::GetMetric( wxSYS_HSCROLL_Y ) );
|
||||||
|
}
|
||||||
|
|
|
@ -101,6 +101,14 @@ namespace KIPLATFORM
|
||||||
* @return System scale factor in use, defaulting to the wxWidgets method
|
* @return System scale factor in use, defaulting to the wxWidgets method
|
||||||
*/
|
*/
|
||||||
double GetSystemScaleFactor( const wxWindow* aWindow );
|
double GetSystemScaleFactor( const wxWindow* aWindow );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tries to determine the size of the viewport of a scrollable widget (wxDataViewCtrl, wxGrid)
|
||||||
|
* that won't be obscured by scrollbars.
|
||||||
|
* @param aWindow pointer to the scrollable widget to check
|
||||||
|
* @return Viewport size that won't be obscured by scrollbars
|
||||||
|
*/
|
||||||
|
wxSize GetUnobscuredSize( const wxWindow* aWindow );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -120,3 +120,9 @@ double KIPLATFORM::UI::GetSystemScaleFactor( const wxWindow* aWindow )
|
||||||
{
|
{
|
||||||
return aWindow->GetContentScaleFactor();
|
return aWindow->GetContentScaleFactor();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wxSize KIPLATFORM::UI::GetUnobscuredSize( const wxWindow* aWindow )
|
||||||
|
{
|
||||||
|
return aWindow->GetClientSize();
|
||||||
|
}
|
||||||
|
|
|
@ -119,3 +119,10 @@ double KIPLATFORM::UI::GetSystemScaleFactor( const wxWindow* aWindow )
|
||||||
{
|
{
|
||||||
return aWindow->GetContentScaleFactor();
|
return aWindow->GetContentScaleFactor();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wxSize KIPLATFORM::UI::GetUnobscuredSize( const wxWindow* aWindow )
|
||||||
|
{
|
||||||
|
return wxSize( aWindow->GetSize().GetX() - wxSystemSettings::GetMetric( wxSYS_VSCROLL_X ),
|
||||||
|
aWindow->GetSize().GetY() - wxSystemSettings::GetMetric( wxSYS_HSCROLL_Y ) );
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue