KiCad PCB EDA Suite
Loading...
Searching...
No Matches
wxmsw/ui.cpp
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2020 Ian McInerney <Ian.S.McInerney at ieee.org>
5 * Copyright (C) 2020 KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software: you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation, either version 3 of the License, or (at your
10 * option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#include <windows.h>
22
23#include <kiplatform/ui.h>
24
25#include <wx/cursor.h>
26#include <wx/nonownedwnd.h>
27#include <wx/window.h>
28#include <wx/msw/registry.h>
29
30
32{
33 // NOTE: Disabled for now because we can't yet react to dark mode in Windows reasonably:
34 // Windows 10 dark mode does not change the values returned by wxSystemSettings::GetColour()
35 // so our window backgrounds, text colors, etc will stay in "light mode" until either wxWidgets
36 // implements something or we apply a custom theme ourselves.
37#ifdef NOTYET
38 const wxString lightModeKey = wxT( "AppsUseLightTheme" );
39
40 // Note: registry used because there is not yet an official API for this yet.
41 // This may stop working on future Windows versions
42 wxRegKey themeKey( wxRegKey::HKCU,
43 wxT( "SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Themes\\Personalize" ) );
44
45 if( !themeKey.Exists() )
46 return false;
47
48 if( !themeKey.HasValue( lightModeKey ) )
49 return false;
50
51 long val = 0;
52
53 if( !themeKey.QueryValue( lightModeKey, &val ) )
54 return false;
55
56 return ( val == 0 );
57#else
58 wxColour bg = wxSystemSettings::GetColour( wxSYS_COLOUR_WINDOW );
59
60 // Weighted W3C formula
61 double brightness = ( bg.Red() / 255.0 ) * 0.299 +
62 ( bg.Green() / 255.0 ) * 0.587 +
63 ( bg.Blue() / 255.0 ) * 0.117;
64
65 return brightness < 0.5;
66#endif
67}
68
69
71{
72 return wxSystemSettings::GetColour( wxSYS_COLOUR_BTNFACE );
73}
74
75
76void KIPLATFORM::UI::ForceFocus( wxWindow* aWindow )
77{
78 aWindow->SetFocus();
79}
80
81
82bool KIPLATFORM::UI::IsWindowActive( wxWindow* aWindow )
83{
84 if(! aWindow )
85 {
86 return false;
87 }
88
89 return ( aWindow->GetHWND() == GetForegroundWindow() );
90}
91
92
93void KIPLATFORM::UI::ReparentModal( wxNonOwnedWindow* aWindow )
94{
95 // Not needed on this platform
96}
97
98
100{
101 // Not needed on this platform
102}
103
104
105bool KIPLATFORM::UI::IsStockCursorOk( wxStockCursor aCursor )
106{
107 switch( aCursor )
108 {
109 case wxCURSOR_BULLSEYE:
110 case wxCURSOR_HAND:
111 case wxCURSOR_ARROW:
112 return true;
113 default:
114 return false;
115 }
116}
117
118
119void KIPLATFORM::UI::LargeChoiceBoxHack( wxChoice* aChoice )
120{
121 // Not implemented
122}
123
124
125void KIPLATFORM::UI::EllipsizeChoiceBox( wxChoice* aChoice )
126{
127 // Not implemented
128}
129
130
131double KIPLATFORM::UI::GetPixelScaleFactor( const wxWindow* aWindow )
132{
133 return aWindow->GetContentScaleFactor();
134}
135
136
137double KIPLATFORM::UI::GetContentScaleFactor( const wxWindow* aWindow )
138{
139 return aWindow->GetDPIScaleFactor();
140}
141
142
143wxSize KIPLATFORM::UI::GetUnobscuredSize( const wxWindow* aWindow )
144{
145 return aWindow->GetClientSize();
146}
147
148
149void KIPLATFORM::UI::SetOverlayScrolling( const wxWindow* aWindow, bool overlay )
150{
151 // Not implemented
152}
153
154
156{
157 return true;
158}
159
160
162{
163 return wxGetMousePosition();
164}
165
166
167bool KIPLATFORM::UI::WarpPointer( wxWindow* aWindow, int aX, int aY )
168{
169 aWindow->WarpPointer( aX, aY );
170 return true;
171}
172
173
174void KIPLATFORM::UI::ImmControl( wxWindow* aWindow, bool aEnable )
175{
176 if ( !aEnable )
177 {
178 ImmAssociateContext( aWindow->GetHWND(), NULL );
179 }
180 else
181 {
182 ImmAssociateContextEx( aWindow->GetHWND(), 0, IACE_DEFAULT );
183 }
184}
185
186
187void KIPLATFORM::UI::ImeNotifyCancelComposition( wxWindow* aWindow )
188{
189 const HIMC himc = ImmGetContext( aWindow->GetHWND() );
190 ImmNotifyIME( himc, NI_COMPOSITIONSTR, CPS_CANCEL, 0 );
191 ImmReleaseContext( aWindow->GetHWND(), himc );
192}
193
194
195bool KIPLATFORM::UI::InfiniteDragPrepareWindow( wxWindow* aWindow )
196{
197 return true;
198}
199
200
202{
203 // Not needed on this platform
204}
205
206
207void KIPLATFORM::UI::SetFloatLevel( wxWindow* aWindow )
208{
209}
bool AllowIconsInMenus()
If the user has disabled icons system-wide, we check that here.
Definition: wxgtk/ui.cpp:209
void SetFloatLevel(wxWindow *aWindow)
Intended to set the floating window level in macOS on a window.
Definition: wxgtk/ui.cpp:338
void EllipsizeChoiceBox(wxChoice *aChoice)
Configure a wxChoice control to ellipsize the shown text in the button with the ellipses placed at th...
Definition: wxgtk/ui.cpp:154
void FixupCancelButtonCmdKeyCollision(wxWindow *aWindow)
Definition: wxgtk/ui.cpp:94
void SetOverlayScrolling(const wxWindow *aWindow, bool overlay)
Used to set overlay/non-overlay scrolling mode in a window.
Definition: wxgtk/ui.cpp:202
wxPoint GetMousePosition()
Returns the mouse position in screen coordinates.
Definition: wxgtk/ui.cpp:620
void ImmControl(wxWindow *aWindow, bool aEnable)
Configures the IME mode of a given control handle.
Definition: wxgtk/ui.cpp:319
double GetPixelScaleFactor(const wxWindow *aWindow)
Tries to determine the pixel scaling factor currently in use for the window.
Definition: wxgtk/ui.cpp:175
void InfiniteDragReleaseWindow()
On Wayland, allows the cursor to freely move again after a drag (see InfiniteDragPrepareWindow).
Definition: wxgtk/ui.cpp:614
bool IsStockCursorOk(wxStockCursor aCursor)
Checks if we designated a stock cursor for this OS as "OK" or else we may need to load a custom one.
Definition: wxgtk/ui.cpp:100
double GetContentScaleFactor(const wxWindow *aWindow)
Tries to determine the content scaling factor currently in use for the window.
Definition: wxgtk/ui.cpp:188
void ImeNotifyCancelComposition(wxWindow *aWindow)
Asks the IME to cancel.
Definition: wxgtk/ui.cpp:324
void LargeChoiceBoxHack(wxChoice *aChoice)
Configure a wxChoice control to support a lot of entries by disabling functionality that makes adding...
Definition: wxgtk/ui.cpp:136
bool WarpPointer(wxWindow *aWindow, int aX, int aY)
Move the mouse cursor to a specific position relative to the window.
Definition: wxgtk/ui.cpp:253
wxColour GetDialogBGColour()
Definition: wxgtk/ui.cpp:61
bool IsWindowActive(wxWindow *aWindow)
Check to see if the given window is the currently active window (e.g.
Definition: wxgtk/ui.cpp:73
wxSize GetUnobscuredSize(const wxWindow *aWindow)
Tries to determine the size of the viewport of a scrollable widget (wxDataViewCtrl,...
Definition: wxgtk/ui.cpp:195
void ForceFocus(wxWindow *aWindow)
Pass the current focus to the window.
Definition: wxgtk/ui.cpp:67
bool InfiniteDragPrepareWindow(wxWindow *aWindow)
On Wayland, restricts the pointer movement to a rectangle slightly bigger than the given wxWindow.
Definition: wxgtk/ui.cpp:607
void ReparentModal(wxNonOwnedWindow *aWindow)
Move a window's parent to be the top-level window and force the window to be on top.
Definition: wxgtk/ui.cpp:88
bool IsDarkTheme()
Determine if the desktop interface is currently using a dark theme or a light theme.
Definition: wxgtk/ui.cpp:48
std::shared_ptr< PNS_LOG_VIEWER_OVERLAY > overlay
Definition: playground.cpp:46