我需要更改字体并删除组合框项目的阴影。
我尝试使用下面的代码但是没有成功:
.combo-box .popup-menu, .combo-box .menu-item, .combo-box .popup-menu .menu-item-radio
{
-fx-shadow-highlight-color: transparent;
-fx-font-family: "Arial";
-fx-font-size: 14px;
}
答案 0 :(得分:2)
对于JavaFX2,您可以创建一个CellFactory来设置它:
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.scene.Scene;
import javafx.scene.control.ComboBox;
import javafx.scene.control.ListCell;
import javafx.scene.control.ListView;
import javafx.scene.layout.Pane;
import javafx.stage.Stage;
import javafx.util.Callback;
public class Main extends Application {
@Override
public void start(Stage stage) throws Exception {
ComboBox<String> cb = new ComboBox<String>();
cb.setItems(FXCollections.observableArrayList("Foo","Bar","777","Batman"));
cb.setCellFactory(new Callback<ListView<String>, ListCell<String>>() {
@Override public ListCell<String> call(ListView<String> p) {
return new ListCell<String>() {
{
getStyleClass().add("customcell");
}
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
setText(item);
}
};
}
});
cb.getSelectionModel().selectFirst();
Pane root = new Pane();
root.getChildren().add(cb);
Scene scene = new Scene(root);
scene.getStylesheets().add(getClass().getResource("style.css").toExternalForm());
stage.setScene(scene);
stage.show();
}
public static void main(String[] args) {launch(args);}
}
<强>的style.css 强>
/* for the main button of the ComboBox */
.combo-box .cell{
-fx-text-fill: blue;
-fx-font: 16px "Arial";
}
.customcell {
-fx-text-fill: blue;
-fx-font: 16px "Arial";
/* No alternate highlighting */
-fx-background-color: #FFF;
}
对于JavaFX 8示例,请检查this answer我给出的一个非常相似的问题,但是对于其他版本。