- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 TableView
上使用编辑功能。我用这个图作为引用: http://docs.oracle.com/javafx/2/ui_controls/table-view.htm#但我使用 FXML 文件进行创建(使用 JavaFX 场景生成器)。我已选中表和列的可编辑复选框(在场景生成器中),但如果执行程序,我无法编辑这些值。我已经从 tut 下载了示例项目,并且在那里进行编辑...所以,在我的项目中 TextField
没有打开:( Controller :
public class StatesPopupController implements Controllerable, Initializable {
// <editor-fold desc="fxml import stuff" defaultstate="collapsed">
@FXML // fx:id="guiStatesTable"
private TableView<StateData> guiStatesTable; // Value injected by FXMLLoader
@FXML // fx:id="guiColorColumn"
private TableColumn<StateData, String> guiColorColumn; // Value injected by FXMLLoader
@FXML // fx:id="guiFontEffectColumn"
private TableColumn<StateData, String> guiFontEffectColumn; // Value injected by FXMLLoader
@FXML // fx:id="guiUseColumn"
private TableColumn<StateData, String> guiUseColumn; // Value injected by FXMLLoader
@FXML // fx:id="guiValueColumn"
private TableColumn<StateData, String> guiValueColumn; // Value injected by FXMLLoader
@FXML // fx:id="guiStateAddColor"
private TextField guiStateAddColor; // Value injected by FXMLLoader
@FXML // fx:id="guiStateAddFontEffect"
private TextField guiStateAddFontEffect; // Value injected by FXMLLoader
@FXML // fx:id="guiStateAddUse"
private TextField guiStateAddUse; // Value injected by FXMLLoader
@FXML // fx:id="guiStateAddValue"
private TextField guiStateAddValue; // Value injected by FXMLLoader
// </editor-fold>
private Modelable model = null;
public StatesPopupController() {
this.model = new StatesPopupModel();
}
@Override
public Modelable getModel() {
return model;
}
@Override
public void initialize(URL url, ResourceBundle rb) {
this.guiStatesTable.setEditable(true);
this.guiValueColumn.setCellValueFactory(new PropertyValueFactory<StateData, String>("value"));
this.guiColorColumn.setCellValueFactory(new PropertyValueFactory<StateData, String>("color"));
this.guiUseColumn.setCellValueFactory(new PropertyValueFactory<StateData, String>("use"));
this.guiFontEffectColumn.setCellValueFactory(new PropertyValueFactory<StateData, String>("fontEffect"));
this.guiStatesTable.setItems(((StatesPopupModel)this.model).getTableData());
}
public void newAddBtnEvent(ActionEvent event {
((StatesPopupModel)this.model).addDataEntry(guiStateAddValue.getText(), guiStateAddColor.getText(), guiStateAddUse.getText(), guiStateAddFontEffect.getText());
guiStateAddValue.clear();
guiStateAddColor.clear();
guiStateAddUse.clear();
guiStateAddFontEffect.clear();
this.guiStatesTable.setItems(((StatesPopupModel) this.model).getTableData());
}
public void newEditValueEvent(CellEditEvent<StateData, String> event) {
((StateData)event.getTableView().getItems().get(event.getTablePosition().getRow())).setValue(event.getNewValue());
}
public void newEditColorEvent(ActionEvent event) {
System.out.print("asd");
}
public void newEditUseEvent(ActionEvent event) {}
public void newEditFontEffectEvent(ActionEvent event) {}
}
型号:
public class StatesPopupModel implements Modelable {
private ObservableList<StateData> data = FXCollections.observableArrayList(
new StateData("inactive", "9", "permit", "plain"),
new StateData("active", "2", "permit", "plain"),
new StateData("unavailable", "7", "inhibit", "plain"),
new StateData("available", "2", "permit", "plain"),
new StateData("invisible", "2", "inhibit", "plain"),
new StateData("visible", "4", "permit", "plain"),
new StateData("controlSign", "10", "inhibit", "plain"),
new StateData("label", "5", "permit", "plain"));
public void addDataEntry(String value, String color, String use, String fontEffect) {
data.add(new StateData(value, color, use, fontEffect));
}
public ObservableList<StateData> getTableData() {
return data;
}
}
StateData
类:
public class StateData
{
private final SimpleStringProperty value;
private final SimpleStringProperty color;
private final SimpleStringProperty use;
private final SimpleStringProperty fontEffect;
public StateData(String value, String color, String use, String fontEffect) {
this.value = new SimpleStringProperty(value);
this.color = new SimpleStringProperty(color);
this.use = new SimpleStringProperty(use);
this.fontEffect = new SimpleStringProperty(fontEffect);
}
/**
* @return the value
*/
public String getValue() {
return value.get();
}
/**
* @param value the value to set
*/
public void setValue(String value) {
this.value.set(value);
}
/**
* @return the color
*/
public String getColor() {
return color.get();
}
/**
* @param color the color to set
*/
public void setColor(String color) {
this.color.set(color);
}
/**
* @return the use
*/
public String getUse() {
return use.get();
}
/**
* @param use the use to set
*/
public void setUse(String use) {
this.use.set(use);
}
/**
* @return the fontEffect
*/
public String getFontEffect() {
return fontEffect.get();
}
/**
* @param fontEffect the fontEffect to set
*/
public void setFontEffect(String fontEffect) {
this.fontEffect.set(fontEffect);
}
}
这里是 fxml:
<?xml version="1.0" encoding="UTF-8"?>
<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.text.*?>
<AnchorPane id="AnchorPane" minHeight="397.0" minWidth="264.0" prefHeight="397.0" prefWidth="427.0" xmlns:fx="http://javafx.com/fxml" fx:controller="controller.popup.StatesPopupController">
<children>
<Label text="States" AnchorPane.leftAnchor="14.0" AnchorPane.topAnchor="6.0">
<font>
<Font name="System Bold" size="15.0" />
</font>
</Label>
<TableView fx:id="guiStatesTable" editable="true" prefHeight="311.0" prefWidth="236.0" AnchorPane.bottomAnchor="52.0" AnchorPane.leftAnchor="14.0" AnchorPane.rightAnchor="14.0" AnchorPane.topAnchor="34.0">
<columns>
<TableColumn prefWidth="75.0" text="Value" fx:id="guiValueColumn" />
<TableColumn prefWidth="75.0" text="Color" fx:id="guiColorColumn" />
<TableColumn prefWidth="75.0" text="Use" fx:id="guiUseColumn" />
<TableColumn prefWidth="75.0" text="fontEffect" fx:id="guiFontEffectColumn" />
</columns>
</TableView>
<HBox id="HBox" alignment="CENTER" prefWidth="236.0" spacing="5.0" AnchorPane.bottomAnchor="17.0" AnchorPane.leftAnchor="14.0" AnchorPane.rightAnchor="14.0">
<children>
<TextField fx:id="guiStateAddValue" prefWidth="93.0" promptText="Value" />
<TextField fx:id="guiStateAddColor" prefWidth="79.0" promptText="Color" />
<TextField fx:id="guiStateAddUse" prefWidth="79.0" promptText="Use" />
<TextField fx:id="guiStateAddFontEffect" prefWidth="79.0" promptText="Font Effect" />
<Button mnemonicParsing="false" onAction="#newAddBtnEvent" text="Add" />
</children>
</HBox>
</children>
</AnchorPane>
欢迎任何帮助。
编辑:如果我使用:
.setCellFactory(TextFieldTableCell.forTableColumn());
我收到此错误:
error: method setCellFactory in class TableColumn<S,T> cannot be applied to given types;
guiUseColumn.setCellFactory(TextFieldTableCell.forTableColumn());
^
required: Callback<TableColumn<StateData,String>,TableCell<StateData,String>>
found: Callback<TableColumn<Object,String>,TableCell<Object,String>>
reason: actual argument Callback<TableColumn<Object,String>,TableCell<Object,String>> cannot be converted to Callback<TableColumn<StateData,String>,TableCell<StateData,String>> by method invocation conversion
where S,T are type-variables:
S extends Object declared in class TableColumn
T extends Object declared in class TableColumn
最佳答案
要使 TableView
可编辑,您还应该提供一个 CellFactory
来处理编辑控件的创建。
您可以在这里找到教程的相应部分:http://docs.oracle.com/javafx/2/ui_controls/table-view.htm#sthref119
关于JavaFX TableView - 无法编辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12895517/
我正在对 tableView 是否呈现单元格进行单元测试。 我发现 tableView.cellForRow(at:) 返回 nil,而 tableView.dataSource?tableView(
我有 Tableview 用于显示客户下的食品订单。其中包含水平 UIStackview。在 UIStackView UIStackview 中很少有一/两行标签和一个用于显示订单项的UITableV
我有 Viewcontroller,我在其中设置了 ScrollView 。在 scrollview 中,我有一个 tableview,它位于 Container 中,就在容器下方,当我将 table
我想在滚动时让我的第一个单元格始终位于 tableview 的顶部。 任何帮助都是可观的。提前致谢... 最佳答案 这是为 UITableView 创建标题 View 的方法 - (UIView *)
在我的应用程序中,我点击一行,它会在其下方展开另一行。我想生成一种随机颜色,当我单击一行时,行背景会变成该颜色,而它下面的展开行会变成相同的颜色。如何让行生成相同的随机颜色? 我创建了一个函数来生成随
我正在为这个问题苦苦挣扎,所以我需要你的帮助。基本上我已经编写了一个复杂的 TableView Controller (使用 NSFetchedResults 协议(protocol)等)并且已经在我
我正在使用 JavaFx 2.2。我遇到了一个问题,我无法在 TableView 列中放置不同的组件。例如我有两列 1) 回答 2) 答案类型 如果 AnswerType 包含“Multiple Ch
试图弄清楚如何在 javafx 2 中禁用表列的重新排序? 最佳答案 这是解决方案: tblView.getColumns().addListener(new ListChangeListener()
我一直在寻找有关将数据刷新到 tableview 的信息。我试图直接修改模型,但我遇到了一个错误。我修改了模型,但表格没有刷新,只有当我移动一列时,表格才会显示修改后的值。 为了给你展示一个例子(13
给定一个TableView,我需要检测单元格上的双击。 tableView.setOnMouseClicked(new EventHandler() { @Override publi
我成功创建了一个 TableView,其中将特定列分配给了数据模型类。该程序可以将 csv 文件解析为其中并在表中正确显示所有内容。在此阶段,滚动不是问题。 然后我想选择特定行并将它们发送到另一个表。
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我有一个通过 Tableview 显示玩家的应用程序。用户可以“添加”一个新玩家并输入他的姓名、高度、体重、图片等...保存后将被添加到 Tableview 中。他们还可以点击每个玩家,然后将他们带到
对于大学,我必须编写一个小应用程序,其想法是创建一个小公式集合。这个概念是有一个类别列表,选择类别后您会收到一个公式列表。选择所需的公式后,您将看到公式计算器的 View 。 我正在努力获得第一个UI
如果我只加载一个 TableView ,我的 View 中必须有两个 TableView ,它工作正常。但是当我尝试使用下面的方法加载两个表格 View 时,它给出了以下异常。 未捕获异常“NSRan
我是 JavaFx 的新手,我正在尝试创建一个 TableView ,而 fxml 是使用场景生成器创建的。如果我运行该程序,该表不会获取值。我发现这个问题在某种程度上符合我的要求( javaFX 2
是否可以对 tableView 进行反向排序?我搜索了很多解决方案,但没有任何效果。 效果就像whatsapp聊天。 一个普通的tableView是: ---------- label 1 -----
我有一个有趣的问题。我有两个 TableView ,一个在另一个里面。我有一个结构,我想用它来将数据添加到我的 TableView 中。该结构有 2 个字符串项和另一个具有 3 个字符串项的结构的数组
我正在使用的方法 func tableView(tableView: UITableView, editActionsForRowAtIndexPath indexPath: NSIndexPath
我是一名优秀的程序员,十分优秀!