2016-06-24 68 views
0

我已經創建了自己的SpreadsheetCellEditor以顯示ColorPicker,但我不想返回ColorPicker.getValue().toString,我想返回帶有 的標籤的背景色。我已經搜索了setContentDisplay(ContentDisplay.GRAPHIC_ONLY),但它似乎不存在於SpreadsheetCell上。 那我怎麼能做到這一點? 這裏是我的實現,到目前爲止,ControlsFX SpreadsheetView:如何將SpreadsheetCell設置爲僅用於圖形?

public class comboboxCellEditor extends SpreadsheetCellEditor { 
    private final ColorPicker colorPicker = new ColorPicker(); 
    private EventHandler<KeyEvent> eh; 
    private ChangeListener<Color> cl; 
    private boolean ending = false; 

    public comboboxCellEditor(SpreadsheetView view) { 
     super(view); 

    } 

    @Override 
    public void startEdit(Object value) { 
     if (value instanceof Color) { 
      this.colorPicker.setValue((Color) value); 
     } 

     attachEnterEscapeEventHandler(); 
     this.colorPicker.show(); 
     this.colorPicker.requestFocus(); 

    } 


    @Override 
    public Control getEditor() { 
     return colorPicker; 
    } 


    public String getControlValue() { 

     return this.colorPicker.getValue().toString(); 

    } 

    @Override 
    public void end() { 
     if (this.colorPicker.isShowing()) { 
      this.colorPicker.hide(); 
     } 

     this.colorPicker.removeEventFilter(KeyEvent.KEY_PRESSED, this.eh); 
     this.colorPicker.valueProperty().removeListener(this.cl); 
    } 

    private void attachEnterEscapeEventHandler() { 
     this.eh = 
       new EventHandler<KeyEvent>() { 
        public void handle(KeyEvent t) { 
         if (t.getCode() == KeyCode.ENTER) { 
          comboboxCellEditor.this.ending = true; 
          comboboxCellEditor.this.endEdit(true); 
          comboboxCellEditor.this.ending = false; 
         } else if (t.getCode() == KeyCode.ESCAPE) { 
          comboboxCellEditor.this.endEdit(false); 
         } 

        } 
       }; 
     this.colorPicker.addEventFilter(KeyEvent.KEY_PRESSED, this.eh); 
     this.cl = new ChangeListener<Color>() { 
      public void changed(ObservableValue<? extends Color> observable, Color oldValue, Color newValue) { 
       if (!comboboxCellEditor.this.ending) 
        comboboxCellEditor.this.endEdit(true); 

      } 
     }; 
     this.colorPicker.valueProperty().addListener(this.cl); 
    } 

} 

public class SpreadSheetComboboxCellType extends SpreadsheetCellType<Color> { 
    @Override 
    public SpreadsheetCellEditor createEditor(SpreadsheetView spreadsheetView) { 
     return new comboboxCellEditor(spreadsheetView); 
    } 

    @Override 
    public String toString(Color color) { 
     return color.toString(); 
    } 

    @Override 
    public boolean match(Object o) { 
     return true; 

    } 

    @Override 
    public Color convertValue(Object o) { 
     if (o instanceof Color) 
      return (Color) o; 
     else { 
      return Color.valueOf((String) o); 
     } 
    } 

    public SpreadsheetCell createCell(int row, int column, int rowSpan, int columnSpan, Color value) { 
     SpreadsheetCellBase cell = new SpreadsheetCellBase(row, column, rowSpan, columnSpan, this); 
     cell.setItem(value); 
     Label label = new Label(); 
     label.setGraphic(null); 
     label.setContentDisplay(ContentDisplay.GRAPHIC_ONLY); 
     cell.setGraphic(label); 

     return cell; 
    } 

} 

回答

1

的SpreadsheetCell都有每個你修改的項目時間UPDATETEXT方法。因此它的意思是首先顯示文本。

你有幾種選擇。

最簡單的方法是在該單元格中添加偵聽器並修改圖形: 單元格中顯示的文本將是SpreadsheetCellType轉換的結果。既然你不想要的文本,在你SpreadSheetComboboxCellType返回任何結果:

@Override 
public String toString(Color color) { 
    return ""; 
} 

然後,只需在您的SpreadsheetCell添加監聽器並修改圖形:

cell.itemProperty().addListener(new ChangeListener<Object>() { 
     @Override 
     public void changed(ObservableValue<? extends Object> ov, Object t, Object newValue) { 

      if (newValue != null && newValue instanceof Color) { 
       //Do something 
       cell.setGraphic(My_Graphic_Object); 
      } else { 
       cell.setGraphic(null); 
      } 
     } 
    }); 

這應該做的伎倆。現在,您可以實施自己的SpreadsheetCell,以便在顯示屏上進行全面控制。它會更有效率。基本上覆制了SpreadsheetCellBase所有代碼(這裏:https://bitbucket.org/controlsfx/controlsfx/src/755c59605e623476ff0a6c860e2c218488776aec/controlsfx/src/main/java/org/controlsfx/control/spreadsheet/SpreadsheetCellBase.java?at=default&fileviewer=file-view-default) 並簡單修改UPDATETEXT方法:

private void updateText() { 
    if(getItem() == null){ 
     text.setValue(""); //$NON-NLS-1$ 
    }else if (!("").equals(getFormat())) { //$NON-NLS-1$ 
     text.setValue(type.toString(getItem(), getFormat())); 
    } else { 
     text.setValue(type.toString(getItem())); 
    } 
} 

不是修改文字,你會修改與新的顏色圖形。

相關問題