mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2024-11-10 06:02:09 +00:00
Merge remote-tracking branch 'origin/GP-4896-dragonmacher-listing-popup-fix'
This commit is contained in:
commit
fbed72146b
@ -43,6 +43,7 @@ import ghidra.util.Swing;
|
||||
import ghidra.util.layout.PairLayout;
|
||||
import ghidra.util.layout.VerticalLayout;
|
||||
import ghidra.util.timer.GTimer;
|
||||
import ghidra.util.timer.GTimerMonitor;
|
||||
|
||||
/**
|
||||
* Internal panel of the memory search window that manages the controls for the search feature. This
|
||||
@ -62,8 +63,10 @@ class MemorySearchControlPanel extends JPanel {
|
||||
private List<ButtonState<Combiner>> initialSearchButtonStates;
|
||||
private List<ButtonState<Combiner>> combinerSearchButtonStates;
|
||||
private JComboBox<SearchFormat> formatComboBox;
|
||||
|
||||
private PopupWindow popup;
|
||||
private String errorMessage;
|
||||
private GTimerMonitor clearInputMonitor;
|
||||
|
||||
MemorySearchControlPanel(MemorySearchProvider provider, SearchGuiModel model,
|
||||
SearchHistory history) {
|
||||
@ -296,7 +299,7 @@ class MemorySearchControlPanel extends JPanel {
|
||||
if (errorMessage == null) {
|
||||
return;
|
||||
}
|
||||
errorMessage = null;
|
||||
|
||||
DockingUtils.setTipWindowEnabled(false);
|
||||
|
||||
Point location = searchInputField.getLocation();
|
||||
@ -305,13 +308,15 @@ class MemorySearchControlPanel extends JPanel {
|
||||
|
||||
JToolTip tip = new JToolTip();
|
||||
tip.setTipText(errorMessage);
|
||||
errorMessage = null;
|
||||
|
||||
if (popup != null) {
|
||||
popup.dispose();
|
||||
clearInputMonitor.cancel();
|
||||
}
|
||||
popup = new PopupWindow(tip);
|
||||
popup.showPopup(searchInputField, location, true);
|
||||
GTimer.scheduleRunnable(1500, this::clearInputError);
|
||||
popup.showPopup(searchInputField.getParent(), location, true);
|
||||
clearInputMonitor = GTimer.scheduleRunnable(2000, this::clearInputError);
|
||||
Toolkit.getDefaultToolkit().beep();
|
||||
}
|
||||
|
||||
@ -321,6 +326,9 @@ class MemorySearchControlPanel extends JPanel {
|
||||
PopupWindow.hideAllWindows();
|
||||
if (popup != null) {
|
||||
popup.dispose();
|
||||
popup = null;
|
||||
clearInputMonitor.cancel();
|
||||
clearInputMonitor = null;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -4,9 +4,9 @@
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
@ -264,7 +264,18 @@ public class PopupWindow {
|
||||
* Shows this popup window unless popups are disabled as reported by
|
||||
* {@link DockingUtils#isTipWindowEnabled()}. If {@code forceShow} is true, then the popup
|
||||
* will be shown regardless of the state returned by {@link DockingUtils#isTipWindowEnabled()}.
|
||||
* @param component the component for the popup
|
||||
* <P>
|
||||
* Note: the component passed in is the component to which the {@code location} the location
|
||||
* belongs. In the example below, the component used to get the location is to the component
|
||||
* passed to this method. This is because the location is relative to the parent's coordinate
|
||||
* space. Thus, when calling this method, make sure to use the correct component.
|
||||
* <PRE>
|
||||
* Point location = textField.getLocation(); // this is relative to the text field's parent
|
||||
* Component parent = textField.getParent();
|
||||
* PopupWindow.showPopup(parent, location, true);
|
||||
* </PRE>
|
||||
*
|
||||
* @param component the component whose coordinate space the location belongs
|
||||
* @param location the location to show the popup
|
||||
* @param forceShow true to show the popup even popups are disabled application-wide
|
||||
*/
|
||||
@ -395,14 +406,14 @@ public class PopupWindow {
|
||||
|
||||
Rectangle newArea = new Rectangle(keepVisibleAea);
|
||||
Point point = newArea.getLocation();
|
||||
SwingUtilities.convertPointToScreen(point, source.getParent());
|
||||
SwingUtilities.convertPointToScreen(point, source);
|
||||
newArea.setLocation(point);
|
||||
return newArea;
|
||||
}
|
||||
|
||||
// for debug
|
||||
private void installDebugPainter(Rectangle keepVisibleArea) {
|
||||
//
|
||||
|
||||
// GGlassPane glassPane = GGlassPane.getGlassPane(source);
|
||||
// for (GGlassPanePainter p : painters) {
|
||||
// glassPane.removePainter(p);
|
||||
@ -439,7 +450,8 @@ public class PopupWindow {
|
||||
// show where the user hovered
|
||||
if (location != null) {
|
||||
Point p = new Point(location);
|
||||
p = SwingUtilities.convertPoint(source.getParent(), p.x, p.y, glassPane);
|
||||
p = SwingUtilities.convertPoint(source, p.x, p.y, glassPane);
|
||||
|
||||
g.setColor(Palette.RED.withAlpha(alpha));
|
||||
int offset = 10;
|
||||
g.fillRect(p.x - offset, p.y - offset, (offset * 2), (offset * 2));
|
||||
|
Loading…
Reference in New Issue
Block a user