/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2020 Ian McInerney * Copyright (C) 2020-2021 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation, either version 3 of the License, or (at your * option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ #include #include #include #include #include #include #include bool KIPLATFORM::UI::IsDarkTheme() { wxColour bg = wxSystemSettings::GetColour( wxSYS_COLOUR_WINDOW ); // Weighted W3C formula double brightness = ( bg.Red() / 255.0 ) * 0.299 + ( bg.Green() / 255.0 ) * 0.587 + ( bg.Blue() / 255.0 ) * 0.117; return brightness < 0.5; } void KIPLATFORM::UI::ForceFocus( wxWindow* aWindow ) { aWindow->SetFocus(); } bool KIPLATFORM::UI::IsWindowActive( wxWindow* aWindow ) { if( !aWindow ) return false; GtkWindow* window = GTK_WINDOW( aWindow->GetHandle() ); if( window ) return gtk_window_is_active( window ); // We shouldn't really ever reach this point return false; } void KIPLATFORM::UI::ReparentQuasiModal( wxNonOwnedWindow* aWindow ) { // Not needed on this platform } void KIPLATFORM::UI::FixupCancelButtonCmdKeyCollision( wxWindow *aWindow ) { // Not needed on this platform } bool KIPLATFORM::UI::IsStockCursorOk( wxStockCursor aCursor ) { switch( aCursor ) { case wxCURSOR_BULLSEYE: case wxCURSOR_HAND: case wxCURSOR_ARROW: case wxCURSOR_BLANK: return true; default: return false; } } void KIPLATFORM::UI::EllipsizeChoiceBox( wxChoice* aChoice ) { // This function is based on the code inside the function post_process_ui in // gtkfilechooserwidget.c GList* cells = gtk_cell_layout_get_cells( GTK_CELL_LAYOUT( aChoice->m_widget ) ); if( !cells ) return; GtkCellRenderer* cell = (GtkCellRenderer*) cells->data; if( !cell ) return; g_object_set( G_OBJECT( cell ), "ellipsize", PANGO_ELLIPSIZE_END, nullptr ); // Only the list of cells must be freed, the renderer isn't ours to free g_list_free( cells ); } double KIPLATFORM::UI::GetSystemScaleFactor( const wxWindow* aWindow ) { double val = 1.0; GtkWidget* widget = static_cast( aWindow->GetHandle() ); if( widget && gtk_check_version( 3, 10, 0 ) == nullptr ) val = gtk_widget_get_scale_factor( widget ); 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 ) ); } void KIPLATFORM::UI::SetOverlayScrolling( const wxWindow* aWindow, bool overlay ) { gtk_scrolled_window_set_overlay_scrolling( GTK_SCROLLED_WINDOW( aWindow->GetHandle() ), overlay ); } void KIPLATFORM::UI::WarpPointer( wxWindow* aWindow, int aX, int aY ) { if( !wxGetEnv( wxT( "WAYLAND_DISPLAY" ), nullptr ) ) { aWindow->WarpPointer( aX, aY ); } else { GdkDisplay* disp = gtk_widget_get_display( static_cast( aWindow->GetHandle() ) ); GdkWindow* win = gdk_display_get_window_at_pointer( disp, nullptr, nullptr ); GdkCursor* blank_cursor = gdk_cursor_new_for_display( disp, GDK_BLANK_CURSOR ); GdkCursor* cur_cursor = gdk_window_get_cursor( win ); if( cur_cursor ) g_object_ref( cur_cursor ); gdk_window_set_cursor( win, blank_cursor ); aWindow->WarpPointer( aX, aY ); gdk_window_set_cursor( win, cur_cursor ); } }