X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fjexer%2Fmenu%2FTMenuItem.java;h=bd149abb08b4ae8e6c65943b249832e954c4e78d;hb=0c28ec38449a59cf34cf5b3c13ea02add1ee57c5;hp=63a5355e348f0e553215a67c88d45c9979a856d5;hpb=d6ee0801333ff93dffd851f4c1a44519c96c371d;p=nikiroo-utils.git diff --git a/src/jexer/menu/TMenuItem.java b/src/jexer/menu/TMenuItem.java index 63a5355..bd149ab 100644 --- a/src/jexer/menu/TMenuItem.java +++ b/src/jexer/menu/TMenuItem.java @@ -3,7 +3,7 @@ * * The MIT License (MIT) * - * Copyright (C) 2017 Kevin Lamonte + * Copyright (C) 2019 Kevin Lamonte * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), @@ -220,23 +220,23 @@ public class TMenuItem extends TWidget { } char cVSide = GraphicsChars.WINDOW_SIDE; - getScreen().vLineXY(0, 0, 1, cVSide, background); - getScreen().vLineXY(getWidth() - 1, 0, 1, cVSide, background); + vLineXY(0, 0, 1, cVSide, background); + vLineXY(getWidth() - 1, 0, 1, cVSide, background); - getScreen().hLineXY(1, 0, getWidth() - 2, ' ', menuColor); - getScreen().putStringXY(2, 0, mnemonic.getRawLabel(), menuColor); + hLineXY(1, 0, getWidth() - 2, ' ', menuColor); + putStringXY(2, 0, mnemonic.getRawLabel(), menuColor); if (key != null) { String keyLabel = key.toString(); - getScreen().putStringXY((getWidth() - keyLabel.length() - 2), 0, - keyLabel, menuColor); + putStringXY((getWidth() - keyLabel.length() - 2), 0, keyLabel, + menuColor); } if (mnemonic.getShortcutIdx() >= 0) { - getScreen().putCharXY(2 + mnemonic.getShortcutIdx(), 0, - mnemonic.getShortcut(), menuMnemonicColor); + putCharXY(2 + mnemonic.getShortcutIdx(), 0, mnemonic.getShortcut(), + menuMnemonicColor); } if (checked) { assert (checkable); - getScreen().putCharXY(1, 0, GraphicsChars.CHECK, menuColor); + putCharXY(1, 0, GraphicsChars.CHECK, menuColor); } } @@ -263,6 +263,30 @@ public class TMenuItem extends TWidget { this.checkable = checkable; } + /** + * Get checkable flag. + * + * @return true if this menu item is both checkable and checked + */ + public final boolean getChecked() { + return ((checkable == true) && (checked == true)); + } + + /** + * Set checked flag. Note that setting checked on an item checkable will + * do nothing. + * + * @param checked if true, and if this menu item is checkable, then + * getChecked() will return true + */ + public final void setChecked(final boolean checked) { + if (checkable) { + this.checked = checked; + } else { + this.checked = false; + } + } + /** * Get the mnemonic string for this menu item. *