mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-06 12:00:04 +02:00
Merge remote-tracking branch 'origin/GP-4108-dragonmacher-menu-icons-when-disabled'
This commit is contained in:
commit
e99731c67d
7 changed files with 30 additions and 24 deletions
|
@ -303,7 +303,11 @@ public abstract class DockingAction implements DockingActionIf {
|
||||||
String text = menuData.getMenuItemName();
|
String text = menuData.getMenuItemName();
|
||||||
String trimmed = StringUtilities.trimMiddle(text, 50);
|
String trimmed = StringUtilities.trimMiddle(text, 50);
|
||||||
menuItem.setText(trimmed);
|
menuItem.setText(trimmed);
|
||||||
menuItem.setIcon(menuData.getMenuIcon());
|
Icon icon = menuData.getMenuIcon();
|
||||||
|
menuItem.setIcon(icon);
|
||||||
|
if (icon != null) {
|
||||||
|
menuItem.setDisabledIcon(ResourceManager.getDisabledIcon(icon));
|
||||||
|
}
|
||||||
menuItem.setMnemonic(menuData.getMnemonic());
|
menuItem.setMnemonic(menuData.getMnemonic());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -15,16 +15,15 @@
|
||||||
*/
|
*/
|
||||||
package docking.menu;
|
package docking.menu;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.JComponent;
|
||||||
import javax.swing.plaf.ComponentUI;
|
import javax.swing.UIManager;
|
||||||
import javax.swing.plaf.MenuItemUI;
|
import javax.swing.plaf.MenuItemUI;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Overrides the painting behavior of the BasicCheckBoxMenuItemUI
|
* Overrides the painting behavior of the BasicCheckBoxMenuItemUI
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class DockingCheckboxMenuItemUI extends DockingMenuItemUI {
|
public class DockingCheckboxMenuItemUI extends DockingMenuItemUI {
|
||||||
public static ComponentUI createUI(JComponent c) {
|
public static DockingCheckboxMenuItemUI createUI(JComponent c) {
|
||||||
DockingCheckboxMenuItemUI result = new DockingCheckboxMenuItemUI();
|
DockingCheckboxMenuItemUI result = new DockingCheckboxMenuItemUI();
|
||||||
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
||||||
return result;
|
return result;
|
||||||
|
|
|
@ -28,7 +28,6 @@ import java.util.Map;
|
||||||
|
|
||||||
import javax.accessibility.Accessible;
|
import javax.accessibility.Accessible;
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.plaf.ComponentUI;
|
|
||||||
import javax.swing.plaf.MenuItemUI;
|
import javax.swing.plaf.MenuItemUI;
|
||||||
|
|
||||||
import docking.util.GraphicsUtils;
|
import docking.util.GraphicsUtils;
|
||||||
|
@ -57,7 +56,7 @@ public class DockingMenuItemUI extends MenuItemUI {
|
||||||
|
|
||||||
protected MenuItemUI ui;
|
protected MenuItemUI ui;
|
||||||
|
|
||||||
public static ComponentUI createUI(JComponent c) {
|
public static DockingMenuItemUI createUI(JComponent c) {
|
||||||
DockingMenuItemUI result = new DockingMenuItemUI();
|
DockingMenuItemUI result = new DockingMenuItemUI();
|
||||||
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
||||||
return result;
|
return result;
|
||||||
|
@ -170,7 +169,7 @@ public class DockingMenuItemUI extends MenuItemUI {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class MenuTabulator {
|
public static class MenuTabulator {
|
||||||
private ArrayList<Integer> columns = new ArrayList<Integer>();
|
private ArrayList<Integer> columns = new ArrayList<>();
|
||||||
|
|
||||||
public static MenuTabulator tabulate(JMenuItem c) {
|
public static MenuTabulator tabulate(JMenuItem c) {
|
||||||
MenuTabulator tabulator = get(c);
|
MenuTabulator tabulator = get(c);
|
||||||
|
|
|
@ -15,12 +15,12 @@
|
||||||
*/
|
*/
|
||||||
package docking.menu;
|
package docking.menu;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.JComponent;
|
||||||
import javax.swing.plaf.ComponentUI;
|
import javax.swing.UIManager;
|
||||||
import javax.swing.plaf.MenuItemUI;
|
import javax.swing.plaf.MenuItemUI;
|
||||||
|
|
||||||
public class DockingMenuUI extends DockingMenuItemUI {
|
public class DockingMenuUI extends DockingMenuItemUI {
|
||||||
public static ComponentUI createUI(JComponent c) {
|
public static DockingMenuUI createUI(JComponent c) {
|
||||||
DockingMenuUI result = new DockingMenuUI();
|
DockingMenuUI result = new DockingMenuUI();
|
||||||
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
result.ui = (MenuItemUI) UIManager.getDefaults().getUI(c);
|
||||||
return result;
|
return result;
|
||||||
|
|
|
@ -20,8 +20,7 @@ import java.awt.event.*;
|
||||||
import java.beans.PropertyChangeEvent;
|
import java.beans.PropertyChangeEvent;
|
||||||
import java.beans.PropertyChangeListener;
|
import java.beans.PropertyChangeListener;
|
||||||
|
|
||||||
import javax.swing.ButtonModel;
|
import javax.swing.*;
|
||||||
import javax.swing.JMenuItem;
|
|
||||||
import javax.swing.event.ChangeListener;
|
import javax.swing.event.ChangeListener;
|
||||||
|
|
||||||
import docking.ActionContext;
|
import docking.ActionContext;
|
||||||
|
@ -29,6 +28,7 @@ import docking.DefaultActionContext;
|
||||||
import docking.action.*;
|
import docking.action.*;
|
||||||
import ghidra.util.Msg;
|
import ghidra.util.Msg;
|
||||||
import ghidra.util.StringUtilities;
|
import ghidra.util.StringUtilities;
|
||||||
|
import resources.ResourceManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class to manage a JMenuItem for an action. Handles property changes in the action
|
* Class to manage a JMenuItem for an action. Handles property changes in the action
|
||||||
|
@ -184,7 +184,11 @@ class MenuItemManager implements ManagedMenuItem, PropertyChangeListener, Action
|
||||||
String text = menuData.getMenuItemName();
|
String text = menuData.getMenuItemName();
|
||||||
String trimmed = StringUtilities.trimMiddle(text, 50);
|
String trimmed = StringUtilities.trimMiddle(text, 50);
|
||||||
menuItem.setText(trimmed);
|
menuItem.setText(trimmed);
|
||||||
menuItem.setIcon(menuData.getMenuIcon());
|
Icon menuIcon = menuData.getMenuIcon();
|
||||||
|
menuItem.setIcon(menuIcon);
|
||||||
|
if (menuIcon != null) {
|
||||||
|
menuItem.setDisabledIcon(ResourceManager.getDisabledIcon(menuIcon));
|
||||||
|
}
|
||||||
menuItem.setMnemonic(menuData.getMnemonic());
|
menuItem.setMnemonic(menuData.getMnemonic());
|
||||||
menuItem.revalidate();
|
menuItem.revalidate();
|
||||||
}
|
}
|
||||||
|
|
|
@ -197,7 +197,7 @@ public class MultipleActionDockingToolbarButton extends EmptyBorderButton {
|
||||||
}
|
}
|
||||||
|
|
||||||
// a custom Ghidra UI that handles alignment issues and allows for tabulating presentation
|
// a custom Ghidra UI that handles alignment issues and allows for tabulating presentation
|
||||||
item.setUI((DockingMenuItemUI) DockingMenuItemUI.createUI(item));
|
item.setUI(DockingMenuItemUI.createUI(item));
|
||||||
final DockingActionIf delegateAction = dockingAction;
|
final DockingActionIf delegateAction = dockingAction;
|
||||||
item.addActionListener(e -> {
|
item.addActionListener(e -> {
|
||||||
ActionContext context = getActionContext();
|
ActionContext context = getActionContext();
|
||||||
|
|
|
@ -1401,8 +1401,8 @@ public class ClipboardPluginTest extends AbstractGhidraHeadedIntegrationTest {
|
||||||
Point point = wrapper.getStartMouseDragLocation();
|
Point point = wrapper.getStartMouseDragLocation();
|
||||||
int startX = point.x;
|
int startX = point.x;
|
||||||
int startY = point.y;
|
int startY = point.y;
|
||||||
|
|
||||||
Point endPoint = wrapper.getEndMouseDragLocation();
|
Point endPoint = wrapper.getEndMouseDragLocation();
|
||||||
|
|
||||||
int endX = endPoint.x;
|
int endX = endPoint.x;
|
||||||
int endY = endPoint.y;
|
int endY = endPoint.y;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue