GTK: Fix popup positioning on monitors not positioned at 0,0
Fixes #1422. X-Scintilla-Bug-URL: https://sourceforge.net/p/scintilla/bugs/1920/ X-Scintilla-Commit-ID: 8e0cb37c4972cd66b33293b88031acf453685cfd
This commit is contained in:
parent
2a2b8d11b8
commit
7514212d32
@ -1059,25 +1059,21 @@ void Window::SetPositionRelative(PRectangle rc, Window relativeTo) {
|
|||||||
GdkWindow *wndRelativeTo = WindowFromWidget(PWidget(relativeTo.wid));
|
GdkWindow *wndRelativeTo = WindowFromWidget(PWidget(relativeTo.wid));
|
||||||
gdk_window_get_origin(wndRelativeTo, &ox, &oy);
|
gdk_window_get_origin(wndRelativeTo, &ox, &oy);
|
||||||
ox += rc.left;
|
ox += rc.left;
|
||||||
if (ox < 0)
|
|
||||||
ox = 0;
|
|
||||||
oy += rc.top;
|
oy += rc.top;
|
||||||
if (oy < 0)
|
|
||||||
oy = 0;
|
|
||||||
|
|
||||||
GdkRectangle rcScreen = MonitorRectangleForWidget(PWidget(relativeTo.wid));
|
GdkRectangle rcMonitor = MonitorRectangleForWidget(PWidget(relativeTo.wid));
|
||||||
|
|
||||||
/* do some corrections to fit into screen */
|
/* do some corrections to fit into screen */
|
||||||
int sizex = rc.right - rc.left;
|
int sizex = rc.right - rc.left;
|
||||||
int sizey = rc.bottom - rc.top;
|
int sizey = rc.bottom - rc.top;
|
||||||
const int screenWidth = rcScreen.width;
|
if (sizex > rcMonitor.width || ox < rcMonitor.x)
|
||||||
const int screenHeight = rcScreen.height;
|
ox = rcMonitor.x; /* the best we can do */
|
||||||
if (sizex > screenWidth)
|
else if (ox + sizex > rcMonitor.x + rcMonitor.width)
|
||||||
ox = 0; /* the best we can do */
|
ox = rcMonitor.x + rcMonitor.width - sizex;
|
||||||
else if (ox + sizex > screenWidth)
|
if (sizey > rcMonitor.height || oy < rcMonitor.y)
|
||||||
ox = screenWidth - sizex;
|
oy = rcMonitor.y;
|
||||||
if (oy + sizey > screenHeight)
|
else if (oy + sizey > rcMonitor.y + rcMonitor.height)
|
||||||
oy = screenHeight - sizey;
|
oy = rcMonitor.y + rcMonitor.height - sizey;
|
||||||
|
|
||||||
gtk_window_move(GTK_WINDOW(PWidget(wid)), ox, oy);
|
gtk_window_move(GTK_WINDOW(PWidget(wid)), ox, oy);
|
||||||
|
|
||||||
@ -1929,20 +1925,18 @@ void Menu::Show(Point pt, Window &wnd) {
|
|||||||
// Rely on GTK+ to do the right thing with positioning
|
// Rely on GTK+ to do the right thing with positioning
|
||||||
gtk_menu_popup_at_pointer(widget, NULL);
|
gtk_menu_popup_at_pointer(widget, NULL);
|
||||||
#else
|
#else
|
||||||
GdkRectangle rcScreen = MonitorRectangleForWidget(PWidget(wnd.GetID()));
|
GdkRectangle rcMonitor = MonitorRectangleForWidget(PWidget(wnd.GetID()));
|
||||||
const int screenWidth = rcScreen.width;
|
|
||||||
const int screenHeight = rcScreen.height;
|
|
||||||
GtkRequisition requisition;
|
GtkRequisition requisition;
|
||||||
#if GTK_CHECK_VERSION(3,0,0)
|
#if GTK_CHECK_VERSION(3,0,0)
|
||||||
gtk_widget_get_preferred_size(GTK_WIDGET(widget), NULL, &requisition);
|
gtk_widget_get_preferred_size(GTK_WIDGET(widget), NULL, &requisition);
|
||||||
#else
|
#else
|
||||||
gtk_widget_size_request(GTK_WIDGET(widget), &requisition);
|
gtk_widget_size_request(GTK_WIDGET(widget), &requisition);
|
||||||
#endif
|
#endif
|
||||||
if ((pt.x + requisition.width) > screenWidth) {
|
if ((pt.x + requisition.width) > rcMonitor.x + rcMonitor.width) {
|
||||||
pt.x = screenWidth - requisition.width;
|
pt.x = rcMonitor.x + rcMonitor.width - requisition.width;
|
||||||
}
|
}
|
||||||
if ((pt.y + requisition.height) > screenHeight) {
|
if ((pt.y + requisition.height) > rcMonitor.y + rcMonitor.height) {
|
||||||
pt.y = screenHeight - requisition.height;
|
pt.y = rcMonitor.y + rcMonitor.height - requisition.height;
|
||||||
}
|
}
|
||||||
gtk_menu_popup(widget, NULL, NULL, MenuPositionFunc,
|
gtk_menu_popup(widget, NULL, NULL, MenuPositionFunc,
|
||||||
GINT_TO_POINTER((static_cast<int>(pt.y) << 16) | static_cast<int>(pt.x)), 0,
|
GINT_TO_POINTER((static_cast<int>(pt.y) << 16) | static_cast<int>(pt.x)), 0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user