7124537: [macosx] Menu shortcuts for all menu items should be disabled if a menu itself is disabled
Reviewed-by: anthony, leonidr
This commit is contained in:
parent
fcb6d58798
commit
d8c5dcc1fc
@ -26,9 +26,11 @@
|
|||||||
package sun.lwawt.macosx;
|
package sun.lwawt.macosx;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
import java.awt.peer.MenuItemPeer;
|
||||||
import java.awt.peer.MenuPeer;
|
import java.awt.peer.MenuPeer;
|
||||||
|
|
||||||
public class CMenu extends CMenuItem implements MenuPeer {
|
public class CMenu extends CMenuItem implements MenuPeer {
|
||||||
|
|
||||||
public CMenu(Menu target) {
|
public CMenu(Menu target) {
|
||||||
super(target);
|
super(target);
|
||||||
}
|
}
|
||||||
@ -40,6 +42,20 @@ public class CMenu extends CMenuItem implements MenuPeer {
|
|||||||
setEnabled(target.isEnabled());
|
setEnabled(target.isEnabled());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final void setEnabled(final boolean b) {
|
||||||
|
super.setEnabled(b);
|
||||||
|
final Menu target = (Menu) getTarget();
|
||||||
|
final int count = target.getItemCount();
|
||||||
|
for (int i = 0; i < count; ++i) {
|
||||||
|
MenuItem item = target.getItem(i);
|
||||||
|
MenuItemPeer p = (MenuItemPeer) LWCToolkit.targetToPeer(item);
|
||||||
|
if (p != null) {
|
||||||
|
p.setEnabled(b && item.isEnabled());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected long createModel() {
|
protected long createModel() {
|
||||||
CMenuComponent parent = (CMenuComponent)
|
CMenuComponent parent = (CMenuComponent)
|
||||||
|
@ -28,17 +28,20 @@ package sun.lwawt.macosx;
|
|||||||
import sun.awt.SunToolkit;
|
import sun.awt.SunToolkit;
|
||||||
import sun.lwawt.LWToolkit;
|
import sun.lwawt.LWToolkit;
|
||||||
|
|
||||||
|
import java.awt.MenuContainer;
|
||||||
import java.awt.MenuItem;
|
import java.awt.MenuItem;
|
||||||
import java.awt.MenuShortcut;
|
import java.awt.MenuShortcut;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.awt.peer.MenuItemPeer;
|
import java.awt.peer.MenuItemPeer;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
public class CMenuItem extends CMenuComponent implements MenuItemPeer {
|
public class CMenuItem extends CMenuComponent implements MenuItemPeer {
|
||||||
|
|
||||||
|
private final AtomicBoolean enabled = new AtomicBoolean(true);
|
||||||
|
|
||||||
public CMenuItem(MenuItem target) {
|
public CMenuItem(MenuItem target) {
|
||||||
super(target);
|
super(target);
|
||||||
initialize(target);
|
initialize(target);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// This way we avoiding invocation of the setters twice
|
// This way we avoiding invocation of the setters twice
|
||||||
@ -124,9 +127,19 @@ public class CMenuItem extends CMenuComponent implements MenuItemPeer {
|
|||||||
setEnabled(false);
|
setEnabled(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public final boolean isEnabled() {
|
||||||
|
return enabled.get();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setEnabled(boolean b) {
|
public void setEnabled(boolean b) {
|
||||||
nativeSetEnabled(getModel(), b);
|
final Object parent = LWToolkit.targetToPeer(getTarget().getParent());
|
||||||
|
if (parent instanceof CMenuItem) {
|
||||||
|
b &= ((CMenuItem) parent).isEnabled();
|
||||||
|
}
|
||||||
|
if (enabled.compareAndSet(!b, b)) {
|
||||||
|
nativeSetEnabled(getModel(), b);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private native long nativeCreate(long parentMenu, boolean isSeparator);
|
private native long nativeCreate(long parentMenu, boolean isSeparator);
|
||||||
|
@ -207,9 +207,9 @@ public final class LWCToolkit extends LWToolkit {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MenuBarPeer createMenuBar(MenuBar target) {
|
public MenuBarPeer createMenuBar(MenuBar target) {
|
||||||
MenuBarPeer peer = new CMenuBar(target);
|
MenuBarPeer peer = new CMenuBar(target);
|
||||||
targetCreatedPeer(target, peer);
|
targetCreatedPeer(target, peer);
|
||||||
return peer;
|
return peer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user