如何在JAVAFX中使用带动态列的动态TableView编辑数据

时间:2013-10-02 17:18:44

标签: javafx-2 javafx

今天这是在JavaFX 2.0中的tableView上显示来自 CSV for DAT文件而没有make custom class 的数据的演示。我将此TableView称为Dynamic TableView,因为tableview自动管理列和行。
在我对tableView上的可编辑的研究中,我们必须有一个自定义类并将其实现到tableView以显示为此demo ==> http://docs.oracle.com/javafx/2/ui_controls/table-view.htm

但是在这种情况下我无法做到,因为我们不知道csv文件或.dat文件有多少列示例....我想在这个表格中执行可编辑通过将TextField添加到TableCell中。如果没有制作自定义类(因为你没有多少列...),如果它必须使自定义类,那么如何本案例的自定义类的设计< /强>

你能帮我吗?

    private void getDataDetailWithDynamic() {
    tblView.getItems().clear();
    tblView.getColumns().clear();
    tblView.setPlaceholder(new Label("Loading..."));
        //            @Override



            try {
                File aFile = new File(txtFilePath.getText());
                InputStream is = new BufferedInputStream(new FileInputStream(aFile));
                Reader reader = new InputStreamReader(is, "UTF-8");

                BufferedReader in = new BufferedReader(reader);

                final String headerLine = in.readLine();
                final String[] headerValues = headerLine.split("\t");
                        for (int column = 0; column < headerValues.length; column++) {
                            tblView.getColumns().add(
                                    createColumn(column, headerValues[column]));
                        }

                // Data:

                String dataLine;
                while ((dataLine = in.readLine()) != null) {
                    final String[] dataValues = dataLine.split("\t");
                            // Add additional columns if necessary:
                            for (int columnIndex = tblView.getColumns().size(); columnIndex < dataValues.length; columnIndex++) {
                                tblView.getColumns().add(createColumn(columnIndex, ""));
                            }
                            // Add data to table:
                            ObservableList<StringProperty> data = FXCollections
                                    .observableArrayList();
                            for (String value : dataValues) {
                                data.add(new SimpleStringProperty(value));
                            }
                            tblView.getItems().add(data);
                }
            } catch (Exception ex) {
                System.out.println("ex: " + ex.toString());
            }


    for(int i=0; i<tblView.getColumns().size(); i++) {
        TableColumn col = (TableColumn)tblView.getColumns().get(i);
        col.setPrefWidth(70);
    }
}

private TableColumn createColumn(
        final int columnIndex, String columnTitle) {
    TableColumn column = new TableColumn(DefaultVars.BLANK_CHARACTER);
    String title;
    if (columnTitle == null || columnTitle.trim().length() == 0) {
        title = "Column " + (columnIndex + 1);
    } else {
        title = columnTitle;
    }


            Callback<TableColumn, TableCell> cellFactory = new Callback<TableColumn, TableCell>() {
                @Override
                public TableCell call(TableColumn p) {

                    System.out.println("event cell");
                    EditingCellData cellExtend = new EditingCellData();
                    return cellExtend;
                }
            };

    column.setText(title);
    column.setCellValueFactory(cellFactory);
    return column;
}

感谢您的阅读。

1 个答案:

答案 0 :(得分:0)

这是解决问题的最佳方法==&gt; https://forums.oracle.com/message/11216643#11216643

我非常感谢你对此的阅读。

由于