[英]JavaFX, How to Resize a Checkbox?
無論使用寬度/高度,minWidth / minHeight還是maxWidth / maxHeight,我似乎都無法調整復選框的大小。 僅更改最小寬度似乎只會影響節點填充
package checkboxtest;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.CheckBox;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class CheckBoxTest extends Application {
@Override
public void start(Stage primaryStage) {
CheckBox checkBoxResize = new CheckBox("Resize");
checkBoxResize.setMinWidth(300);
checkBoxResize.setMinHeight(300);
CheckBox checkBoxNoResize = new CheckBox("No Resize");
StackPane root = new StackPane();
root.getChildren().add(checkBoxResize);
root.getChildren().add(checkBoxNoResize);
Scene scene = new Scene(root, 300, 250);
primaryStage.setTitle("Hello Checkbox!");
primaryStage.setScene(scene);
primaryStage.show();
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
launch(args);
}
}
復選框中的“框”和“標記”(即復選標記或勾號)由CSS確定。 兩者都被渲染為帶有填充的區域以確定它們的大小; 標記使用SVG形狀來渲染復選標記。 因此,要更改大小,您需要更改應用於這些的填充。
來自modena.css的默認值是
.check-box > .box {
/* ... */
-fx-padding: 0.166667em 0.166667em 0.25em 0.25em; /* 2 2 3 3 */
}
.check-box > .box > .mark {
/* ... */
-fx-padding: 0.416667em 0.416667em 0.5em 0.5em; /* 5 5 6 6 */
-fx-shape: "M-0.25,6.083c0.843-0.758,4.583,4.833,5.75,4.833S14.5-1.5,15.917-0.917c1.292,0.532-8.75,17.083-10.5,17.083C3,16.167-1.083,6.833-0.25,6.083z";
}
因此,要將大小增加12倍,您可以使用:
.big-check-box > .box {
-fx-padding: 2em 2em 3em 3em ;
}
.big-check-box > .box > .mark {
-fx-padding: 5em 5em 6em 6em;
}
以下SSCCE,上面的CSS(第二個代碼塊)在文件“big-check-box.css”中:
import javafx.application.Application;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.CheckBox;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
public class BigCheckBox extends Application {
@Override
public void start(Stage primaryStage) {
CheckBox checkBox = new CheckBox("Regular");
CheckBox bigCheckBox = new CheckBox("Big");
bigCheckBox.getStyleClass().add("big-check-box");
VBox root = new VBox(5, checkBox, bigCheckBox);
root.setPadding(new Insets(20));
Scene scene = new Scene(root);
scene.getStylesheets().add("big-check-box.css");
primaryStage.setScene(scene);
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
給
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.