javafx - 为什么 -fx-border-color 重置 TextField 的边框半径?

标签 javafx javafx-8 javafx-css

我想使用 JavaFX CSS 更改 TextField 的背景和边框颜色。我不明白为什么 -fx-border-color 会重置 TextField 的边框半径?

enter image description here

如您所见,第二个 TextField 没有边框半径。

示例/style.css:

.validation-error {
    -fx-background-color: #FFF0F0;
    -fx-border-color: #DBB1B1;
}

示例/Main.java

package sample;

import javafx.application.Application;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.TextField;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class Main extends Application {

    @Override
    public void start(Stage primaryStage) throws Exception{
        TextField txtWithoutStyle = new TextField();
        txtWithoutStyle.setText("Without Style");

        TextField txtWithStyle = new TextField();
        txtWithStyle.setText("With Style");
        txtWithStyle.getStyleClass().add("validation-error");

        VBox root = new VBox();
        root.setPadding(new Insets(14));
        root.setSpacing(14);
        root.getChildren().addAll(txtWithoutStyle, txtWithStyle);
        root.getStylesheets().add("/sample/style.css");

        Scene scene = new Scene(root, 300, 275);

        primaryStage.setTitle("Hello World");
        primaryStage.setScene(scene);
        primaryStage.show();
    }


    public static void main(String[] args) {
        launch(args);
    }
}

更新 1

附加问题:为什么 -fx-background-color 删除 TextField 边框(只需从 style.css 中删除 -fx-border-color重现它)?

最佳答案

default stylesheet通过使用“嵌套背景”而不是边框​​将边框应用于文本字段(以及几乎所有其他控件)。

默认样式表中 TextInputControl 的一些设置是:

-fx-background-color: linear-gradient(to bottom, derive(-fx-text-box-border, -10%), -fx-text-box-border),
    linear-gradient(from 0px 0px to 0px 5px, derive(-fx-control-inner-background, -9%), -fx-control-inner-background);
-fx-background-insets: 0, 1;
-fx-background-radius: 3, 2;

这基本上设置了两种背景颜色(均由线性渐变定义),一种(“外部”颜色)的颜色基于 -fx-text-box-border,另一种颜色基于 -fx-control-inner-background。 “外部”背景位于“内部”背景之外,因为它们分别具有 01 的插入;通过分别为每个背景设置 32 的半径来创建最终明显边界的弯曲边缘。

至少据传闻,这比在 CSS 中使用实际边框更有效,因此选择这种技术是出于性能原因。

因此,为了保留边框的半径,您可以使用相同的技术,只需覆盖两种背景颜色即可:

.validation-error {
    -fx-background-color: #DBB1B1, #FFF0F0 ;
 }

请注意,您也可以只替换“looked-up-colors”,这也将保留正在使用的细微线性渐变:

.validation-error {
    -fx-text-box-border: #DBB1B1 ;
    -fx-control-inner-background: #FFF0F0 ;
  }

为了在聚焦时突出显示,默认使用名为 -fx-focus-color-fx-faint-focus-color 的颜色:所以在后一个版本中你会可能也想重新定义它们:

.validation-error {
    -fx-text-box-border: #DBB1B1 ;
    -fx-control-inner-background: #FFF0F0 ;
    -fx-focus-color: #FF2020 ;
    -fx-faint-focus-color: #FF202020 ;
  }

关于javafx - 为什么 -fx-border-color 重置 TextField 的边框半径?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29396105/

相关文章:

java - Javafx8 Webview 支持哪些 CSS3 特性?

javafx - 设置 JavaFX 表列名称填充

css - 是否可以在 CSS 中设置 JavaFX 静态属性?

Javafx文本区域滚动 Pane 边框颜色问题

button - 在javafx中设置没有背景的imageview周围的边框

java - 如何检测 JavaFx 双击 listView

java - 如何在JavaFX中支持macOS字符输入

javafx-8 - 如何在向上滚动时触发事件,javafx

JavaFX (controlsfx-8.20.8) 选项卡式 Pane View 部分显示

java - fxml 阶段无法使用 Controller 类构造函数加载