I have encountered some problem when selecting a row and get the index in first column. I know you can do this in Java Swing:
jTable.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
// Fire this when selected value changed
jTable.getSelectionModel().addListSelectionListener(
new ListSelectionListener() {
@Override
public void valueChanged(ListSelectionEvent e) {
if (!e.getValueIsAdjusting()) {
int viewRow = jTable.getSelectedRow();
// Get the first column data of the selectedrow
int topicID = Integer.parseInt(jTable.getValueAt(
viewRow, 0).toString());
}
});
And this is how I populate my table data:
public void getAndPopulateCategory() {
data = FXCollections.observableArrayList();
try {
db.getConnection();
String sql = "SELECT * FROM sm_category";
ResultSet rs = null;
// Call readRequest to get the result
rs = db.readRequest(sql);
while (rs.next()) {
ObservableList<String> row = FXCollections.observableArrayList();
//All the rows are added here dynamically
row.add(rs.getString("categoryID"));
row.add(rs.getString("categoryName"));
row.add(rs.getString("categoryDescription"));
data.add(row);
}
viewCategory.setItems(data);
rs.close();
} catch (SQLException ex) {
ex.printStackTrace();
System.out.println("Error SQL!!!");
System.exit(0);
}
TableColumn id = new TableColumn("ID");
id.setVisible(false);
id.setCellValueFactory(new Callback<TableColumn.CellDataFeatures<ObservableList, String>, ObservableValue<String>>() {
public ObservableValue<String> call(TableColumn.CellDataFeatures<ObservableList, String> param) {
return new SimpleStringProperty(param.getValue().get(0).toString());
}
});
viewCategory.getColumns().addAll(id;
}
I am trying to do like get the first column value of selected row in javaFX. Anybody knows? Thanks in advance.