覆盖菜单项自动关闭事件
Override menuitem auto close event
我只有一个菜单。单击它我将打开一个菜单项,其中包含 "search items"。所以有文本框、组合框、按钮等等很多东西都在 vbox 之下。
当我在 vobx 中单击任何项目时,菜单项正在关闭。如何阻止它?如果我在菜单项外部单击,它应该关闭但不会在内部关闭。
这是我的 fxml 代码:
<MenuButton fx:id="searchCriteriaMenu" mnemonicParsing="false"
nodeOrientation="LEFT_TO_RIGHT" onAction="#searchCriteriaMenu"
styleClass="redButton" text="Search Criteria" textFill="WHITE"
wrapText="true">
<items>
<MenuItem fx:id="scMenuItem" mnemonicParsing="false"
style="-fx-background-color: transparent; -fx-padding: 0; -fx-margin: 0;">
<graphic>
<VBox fx:id="advancedSearchVbox" prefHeight="406.0" prefWidth="359.0"
style="-fx-font-weight: bold;">
<children>
<AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="615.0"
prefWidth="200.0" styleClass="noborder">
<children>
<HBox layoutY="76.0" minHeight="168.0" minWidth="345.0"
prefHeight="168.0" prefWidth="357.0">
<children>
<ScrollPane hbarPolicy="NEVER" maxHeight="230.0"
minWidth="355.0" prefHeight="216.0" prefWidth="355.0"
vbarPolicy="AS_NEEDED">
<content>
<VBox fx:id="userSelectedValues" fillWidth="true"
layoutY="5.0" maxWidth="355.0">
</VBox>
</content>
</ScrollPane>
</children>
</HBox>
<Group layoutY="-100.0">
<children>
<HBox layoutX="7.0" layoutY="350.0" prefHeight="35.0"
prefWidth="348.0">
<children>
<Text layoutX="7.0" layoutY="335.0" strokeType="OUTSIDE"
strokeWidth="0.0" text="Template Name">
<HBox.margin>
<Insets right="5.0" top="9.0" />
</HBox.margin>
</Text>
<ComboBox fx:id="templateNameComboBox" layoutX="94.0"
layoutY="330.0" prefWidth="248.0" promptText="Select Template Name">
<HBox.margin>
<Insets left="7.0" />
</HBox.margin>
</ComboBox>
</children>
</HBox>
<HBox layoutX="7.0" layoutY="385.0" prefHeight="35.0"
prefWidth="348.0">
<children>
<Text strokeType="OUTSIDE" strokeWidth="0.0"
text="Type of template">
<HBox.margin>
<Insets top="9.0" />
</HBox.margin>
</Text>
<ComboBox fx:id="templateTypeComboBox" prefWidth="248.0"
promptText="Select Template Type">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="Private" />
<String fx:value="Public" />
</FXCollections>
</items>
<HBox.margin>
<Insets left="5.0" />
</HBox.margin>
</ComboBox>
</children>
</HBox>
<HBox alignment="TOP_CENTER" layoutX="-8.0" layoutY="422.0"
prefHeight="100.0" prefWidth="360.0">
<children>
<CheckBox fx:id="defaultTemplate" mnemonicParsing="false" />
<Text strokeType="OUTSIDE" strokeWidth="0.0"
text="Set as a default template">
<HBox.margin>
<Insets top="3.0" />
</HBox.margin>
</Text>
</children>
</HBox>
<HBox layoutX="5.0" layoutY="450.0" prefHeight="45.0"
prefWidth="352.0">
<children>
<Button mnemonicParsing="false" onAction="#onSaveTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Save Template" textAlignment="CENTER" wrapText="true" />
<Button mnemonicParsing="false" onAction="#onEditTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Edit Template" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#onDeleteTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Delete Template" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#onClearTemplate"
prefHeight="45.0" prefWidth="55.0" styleClass="advancedRedButton"
text="Clear" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#advancedSearch"
prefHeight="45.0" prefWidth="55.0" styleClass="advancedRedButton"
text="Search">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
</children>
</HBox>
</children>
</Group>
<HBox layoutX="5.0" layoutY="5.0" prefHeight="73.0"
prefWidth="348.0">
<children>
<GridPane fx:id="gridPane" hgap="3.0" layoutX="6.6"
layoutY="60.6" prefHeight="43.0" prefWidth="348.0" vgap="1.0"
AnchorPane.bottomAnchor="30.0" AnchorPane.leftAnchor="-3.0"
AnchorPane.rightAnchor="-10.0" AnchorPane.topAnchor="51.0">
<columnConstraints>
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="132.99999237060547" minWidth="10.0" prefWidth="126.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="102.0" minWidth="10.0" prefWidth="102.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="115.0" minWidth="10.0" prefWidth="86.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="76.0" minWidth="10.0" prefWidth="28.0" />
<ColumnConstraints />
</columnConstraints>
<rowConstraints>
<RowConstraints maxHeight="140.0" minHeight="10.0"
prefHeight="24.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="275.0" minHeight="10.0"
prefHeight="48.0" vgrow="SOMETIMES" />
</rowConstraints>
<children>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Field"
textAlignment="CENTER" wrappingWidth="35.9765625"
GridPane.halignment="CENTER" GridPane.valignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Operator"
GridPane.columnIndex="1" GridPane.halignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Value"
GridPane.columnIndex="2" GridPane.halignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<ComboBox fx:id="fieldName" prefWidth="150.0"
promptText="Select Field" GridPane.rowIndex="1">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="CLSMESSAGEID" />
<String fx:value="PAYMENTTYPE" />
<String fx:value="REQUESTTYPE" />
<String fx:value="VALUEDATE" />
</FXCollections>
</items>
</ComboBox>
<ComboBox fx:id="operator" prefWidth="150.0"
promptText="Select Operator" GridPane.columnIndex="1"
GridPane.rowIndex="1">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="IN" />
<String fx:value="NOT IN" />
<String fx:value="EQUALS" />
<String fx:value="NOT EQUALS" />
<String fx:value="LESS THAN" />
<String fx:value="LESS THAN EQUALS" />
<String fx:value="GREATER THAN" />
<String fx:value="GREATER THAN EQUALS" />
</FXCollections>
</items>
</ComboBox>
<TextField fx:id="fieldValue"
GridPane.columnIndex="2" GridPane.rowIndex="1" />
<Button fx:id="addImage" mnemonicParsing="false"
onAction="#addOptions" prefHeight="20.0" prefWidth="20.0"
styleClass="addImg" GridPane.columnIndex="3"
GridPane.rowIndex="1">
<GridPane.margin>
<Insets left="5.0" />
</GridPane.margin>
</Button>
</children>
</GridPane>
</children>
</HBox>
</children>
</AnchorPane>
</children>
</VBox>
</graphic>
</MenuItem>
</items>
<HBox.margin>
<Insets left="6.0" />
</HBox.margin>
<cursor>
<Cursor fx:constant="HAND" />
</cursor>
</MenuButton>
使用 CustomMenuItem
并设置其 content
属性 以显示 VBox
及其所有内容。将 hideOnClick
属性 设置为 false
:
<MenuButton fx:id="searchCriteriaMenu" mnemonicParsing="false"
nodeOrientation="LEFT_TO_RIGHT" onAction="#searchCriteriaMenu"
styleClass="redButton" text="Search Criteria" textFill="WHITE"
wrapText="true">
<items>
<CustomMenuItem fx:id="scMenuItem" hideOnClick="false" mnemonicParsing="false"
style="-fx-background-color: transparent; -fx-padding: 0; -fx-margin: 0;">
<content>
<VBox fx:id="advancedSearchVbox" prefHeight="406.0" prefWidth="359.0"
style="-fx-font-weight: bold;">
<!-- etc etc etc -->
</VBox>
</content>
</CustomMenuItem>
</items>
<!-- ... -->
</MenuButton>
我只有一个菜单。单击它我将打开一个菜单项,其中包含 "search items"。所以有文本框、组合框、按钮等等很多东西都在 vbox 之下。
当我在 vobx 中单击任何项目时,菜单项正在关闭。如何阻止它?如果我在菜单项外部单击,它应该关闭但不会在内部关闭。
这是我的 fxml 代码:
<MenuButton fx:id="searchCriteriaMenu" mnemonicParsing="false"
nodeOrientation="LEFT_TO_RIGHT" onAction="#searchCriteriaMenu"
styleClass="redButton" text="Search Criteria" textFill="WHITE"
wrapText="true">
<items>
<MenuItem fx:id="scMenuItem" mnemonicParsing="false"
style="-fx-background-color: transparent; -fx-padding: 0; -fx-margin: 0;">
<graphic>
<VBox fx:id="advancedSearchVbox" prefHeight="406.0" prefWidth="359.0"
style="-fx-font-weight: bold;">
<children>
<AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="615.0"
prefWidth="200.0" styleClass="noborder">
<children>
<HBox layoutY="76.0" minHeight="168.0" minWidth="345.0"
prefHeight="168.0" prefWidth="357.0">
<children>
<ScrollPane hbarPolicy="NEVER" maxHeight="230.0"
minWidth="355.0" prefHeight="216.0" prefWidth="355.0"
vbarPolicy="AS_NEEDED">
<content>
<VBox fx:id="userSelectedValues" fillWidth="true"
layoutY="5.0" maxWidth="355.0">
</VBox>
</content>
</ScrollPane>
</children>
</HBox>
<Group layoutY="-100.0">
<children>
<HBox layoutX="7.0" layoutY="350.0" prefHeight="35.0"
prefWidth="348.0">
<children>
<Text layoutX="7.0" layoutY="335.0" strokeType="OUTSIDE"
strokeWidth="0.0" text="Template Name">
<HBox.margin>
<Insets right="5.0" top="9.0" />
</HBox.margin>
</Text>
<ComboBox fx:id="templateNameComboBox" layoutX="94.0"
layoutY="330.0" prefWidth="248.0" promptText="Select Template Name">
<HBox.margin>
<Insets left="7.0" />
</HBox.margin>
</ComboBox>
</children>
</HBox>
<HBox layoutX="7.0" layoutY="385.0" prefHeight="35.0"
prefWidth="348.0">
<children>
<Text strokeType="OUTSIDE" strokeWidth="0.0"
text="Type of template">
<HBox.margin>
<Insets top="9.0" />
</HBox.margin>
</Text>
<ComboBox fx:id="templateTypeComboBox" prefWidth="248.0"
promptText="Select Template Type">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="Private" />
<String fx:value="Public" />
</FXCollections>
</items>
<HBox.margin>
<Insets left="5.0" />
</HBox.margin>
</ComboBox>
</children>
</HBox>
<HBox alignment="TOP_CENTER" layoutX="-8.0" layoutY="422.0"
prefHeight="100.0" prefWidth="360.0">
<children>
<CheckBox fx:id="defaultTemplate" mnemonicParsing="false" />
<Text strokeType="OUTSIDE" strokeWidth="0.0"
text="Set as a default template">
<HBox.margin>
<Insets top="3.0" />
</HBox.margin>
</Text>
</children>
</HBox>
<HBox layoutX="5.0" layoutY="450.0" prefHeight="45.0"
prefWidth="352.0">
<children>
<Button mnemonicParsing="false" onAction="#onSaveTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Save Template" textAlignment="CENTER" wrapText="true" />
<Button mnemonicParsing="false" onAction="#onEditTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Edit Template" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#onDeleteTemplate"
prefHeight="45.0" prefWidth="67.0" styleClass="advancedRedButton"
text="Delete Template" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#onClearTemplate"
prefHeight="45.0" prefWidth="55.0" styleClass="advancedRedButton"
text="Clear" textAlignment="CENTER" wrapText="true">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
<Button mnemonicParsing="false" onAction="#advancedSearch"
prefHeight="45.0" prefWidth="55.0" styleClass="advancedRedButton"
text="Search">
<HBox.margin>
<Insets left="8.0" />
</HBox.margin>
</Button>
</children>
</HBox>
</children>
</Group>
<HBox layoutX="5.0" layoutY="5.0" prefHeight="73.0"
prefWidth="348.0">
<children>
<GridPane fx:id="gridPane" hgap="3.0" layoutX="6.6"
layoutY="60.6" prefHeight="43.0" prefWidth="348.0" vgap="1.0"
AnchorPane.bottomAnchor="30.0" AnchorPane.leftAnchor="-3.0"
AnchorPane.rightAnchor="-10.0" AnchorPane.topAnchor="51.0">
<columnConstraints>
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="132.99999237060547" minWidth="10.0" prefWidth="126.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="102.0" minWidth="10.0" prefWidth="102.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="115.0" minWidth="10.0" prefWidth="86.0" />
<ColumnConstraints hgrow="SOMETIMES"
maxWidth="76.0" minWidth="10.0" prefWidth="28.0" />
<ColumnConstraints />
</columnConstraints>
<rowConstraints>
<RowConstraints maxHeight="140.0" minHeight="10.0"
prefHeight="24.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="275.0" minHeight="10.0"
prefHeight="48.0" vgrow="SOMETIMES" />
</rowConstraints>
<children>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Field"
textAlignment="CENTER" wrappingWidth="35.9765625"
GridPane.halignment="CENTER" GridPane.valignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Operator"
GridPane.columnIndex="1" GridPane.halignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Value"
GridPane.columnIndex="2" GridPane.halignment="CENTER">
<styleClass>
<String fx:value="boldFont" />
<String fx:value="px16Font" />
</styleClass>
</Text>
<ComboBox fx:id="fieldName" prefWidth="150.0"
promptText="Select Field" GridPane.rowIndex="1">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="CLSMESSAGEID" />
<String fx:value="PAYMENTTYPE" />
<String fx:value="REQUESTTYPE" />
<String fx:value="VALUEDATE" />
</FXCollections>
</items>
</ComboBox>
<ComboBox fx:id="operator" prefWidth="150.0"
promptText="Select Operator" GridPane.columnIndex="1"
GridPane.rowIndex="1">
<items>
<FXCollections fx:factory="observableArrayList">
<String fx:value="IN" />
<String fx:value="NOT IN" />
<String fx:value="EQUALS" />
<String fx:value="NOT EQUALS" />
<String fx:value="LESS THAN" />
<String fx:value="LESS THAN EQUALS" />
<String fx:value="GREATER THAN" />
<String fx:value="GREATER THAN EQUALS" />
</FXCollections>
</items>
</ComboBox>
<TextField fx:id="fieldValue"
GridPane.columnIndex="2" GridPane.rowIndex="1" />
<Button fx:id="addImage" mnemonicParsing="false"
onAction="#addOptions" prefHeight="20.0" prefWidth="20.0"
styleClass="addImg" GridPane.columnIndex="3"
GridPane.rowIndex="1">
<GridPane.margin>
<Insets left="5.0" />
</GridPane.margin>
</Button>
</children>
</GridPane>
</children>
</HBox>
</children>
</AnchorPane>
</children>
</VBox>
</graphic>
</MenuItem>
</items>
<HBox.margin>
<Insets left="6.0" />
</HBox.margin>
<cursor>
<Cursor fx:constant="HAND" />
</cursor>
</MenuButton>
使用 CustomMenuItem
并设置其 content
属性 以显示 VBox
及其所有内容。将 hideOnClick
属性 设置为 false
:
<MenuButton fx:id="searchCriteriaMenu" mnemonicParsing="false"
nodeOrientation="LEFT_TO_RIGHT" onAction="#searchCriteriaMenu"
styleClass="redButton" text="Search Criteria" textFill="WHITE"
wrapText="true">
<items>
<CustomMenuItem fx:id="scMenuItem" hideOnClick="false" mnemonicParsing="false"
style="-fx-background-color: transparent; -fx-padding: 0; -fx-margin: 0;">
<content>
<VBox fx:id="advancedSearchVbox" prefHeight="406.0" prefWidth="359.0"
style="-fx-font-weight: bold;">
<!-- etc etc etc -->
</VBox>
</content>
</CustomMenuItem>
</items>
<!-- ... -->
</MenuButton>