2016-06-07 112 views
-1

我制作了一张简单的表格,用户可以在其中搜索书籍并购买它。在一个场景中有搜索标签,并且当点击搜索按钮时,新的场景以表格中的搜索结果打开。问题是,当我输入例如要搜索的书名时,它会显示在表格中,但是当我返回时,输入新书名进行搜索时,表格中会有与之前搜索相同的单元格。我希望旧的搜索记录在我输入新的搜索参数时不显示。我不使用JavaFX属性,因为我从服务器获取书籍,并且JavaFX属性不可序列化。这就像表没有令人耳目一新。我试图从本网站的类似问题实现代码,但没有结果。 我的表的代码(最后一列是复选框)。表中的JavaFX旧单元格以新单元格显示

  TableView<Knjiga> table = new TableView<Knjiga>(); 
      ObservableList<Knjiga> data = 
      FXCollections.observableArrayList(list); 

      table.setColumnResizePolicy(TableView.CONSTRAINED_RESIZE_POLICY); 
      TableColumn<Knjiga, String> nameCol = new TableColumn<Knjiga, String>("Naziv"); 
      TableColumn<Knjiga, String> authorCol = new TableColumn<Knjiga, String>("Autor"); 
      TableColumn<Knjiga, String> costCol = new TableColumn<Knjiga, String>("Cijena"); 
      Callback<TableColumn<Knjiga, Boolean>, TableCell<Knjiga, Boolean>> cellFactory; 
      TableColumn checkCol= new TableColumn<Knjiga, Boolean>(); 
      table.setItems(data); 
      nameCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("bookName")); 
      authorCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("authorName")); 
      costCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("cost")); 
      checkCol.setCellValueFactory(new PropertyValueFactory<Knjiga, Boolean>("checked"));     
      cellFactory = new Callback<TableColumn<Knjiga, Boolean>, TableCell<Knjiga, Boolean>>() { 
      @Override 
      public TableCell call(final TableColumn param) { 
       final CheckBox checkBox = new CheckBox(); 
       final TableCell cell = new TableCell() { 

       @Override 
       public void updateItem(Object item, boolean empty) { 
        super.updateItem(item, empty); 
        if (item == null) { 
         checkBox.setDisable(true); 
         checkBox.setSelected(false); 
        } else { 
         checkBox.setDisable(false); 
         checkBox.setSelected(item.equals(true) ? true : false); 
         checkBox.selectedProperty().addListener(new ChangeListener<Boolean>() { 
          @Override 
          public void changed(ObservableValue<? extends Boolean> observable, Boolean oldValue, Boolean newValue) { 
           for(int i = 0; i < fromServer.size(); i++) 
            fromServer.get(i).setQuantity(fromServer.get(i).getQuantity() - 1); 
          } 
         }); 
        commitEdit(checkBox.isSelected() ? true : false); 
        } 
       } 
      }; 
      cell.setGraphic(checkBox); 
      refresh(table, data); 
      return cell; 
     } 
    };  
      checkCol.setCellValueFactory(new PropertyValueFactory("checked")); 
      checkCol.setCellFactory(cellFactory); 
+1

另外:仅仅因为JavaFX属性不是'Serializable',它并不意味着你的模型类不能使用它们。通过实现'readObject'和'writeObject'方法来使用自定义序列化。参见例如[here](http://www.oracle.com/technetwork/articles/java/javaserial-1536170.html)或[here](http://stackoverflow.com/questions/35039557/javafx-and-serializability)。 (还有......不是每个人都只是用最近的JSON与服务器通信吗?) –

+0

是的,他们这样做。问题是我不能使用JSON,因为它不适用于我的应用程序。 (大学项目)。 – MGKP

+0

够公平的。无论如何,请考虑使用JavaFX属性,它使控件能够更好地发挥作用。 –

回答

1

你应该空出的文本&图形时,细胞是空的,它会清除先前填充细胞。就你而言,图形就够了。

@Override 
public void updateItem(Object item, boolean empty) { 
    super.updateItem(item, empty); 
    if (empty) { 
     setText(null); 
     setGraphic(null); 
    } else { 
     // do stuff here 
    } 
} 
+0

我已经尝试过了。什么都没发生。 http://prntscr.com/bdndut – MGKP

+0

@Mogogic如果这不起作用,您可能需要创建一个[MCVE]并编辑您的问题以包含它。 –

+1

@Magicic - 当单元格为空时('item == null'),您显然不会将图形设置为null。您可能只包含'cell.setGraphic(null);'where item == null'。 – Zsolt

1

问题解决了。事情是,当我从服务器发送图书的ArrayList到客户端时,我没有清除列表,所以服务器发送新旧对象。