java - 将 VBox 和 StackPane 放入另一个 StackPane 后,按钮不起作用
问题描述
我试图TextField
在屏幕中间获得一个,同时在Circle
它周围有一个,并且在圆圈下方有一个按钮。所以我用VBox
圆圈和按钮做了一个StackPane
,只用TextField
. 我制作了另一个StackPane
将 theVBox
和 theStackPane
放在同一个场景中,但现在按钮不起作用。我真的不知道是什么原因造成的。
以下是我到目前为止的代码。
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package circleandtextbox;
import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.geometry.Pos;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.TextField;
import javafx.scene.layout.Pane;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;
/**
*
* @author diego
*/
public class CircleAndTextBox extends Application {
@Override
public void start(Stage primaryStage) {
int programX = 400;
int programY = 400;
int circleRadius = 100;
Circle circle = new Circle(programX / 2,programY / 2,circleRadius);
circle.setStroke(Color.RED);
circle.setStrokeWidth(3);
circle.setFill(Color.TRANSPARENT);
TextField input = new TextField();
input.setMaxWidth(100);
Button btn = new Button();
btn.setText("Change the size of the circle");
btn.setOnAction((ActionEvent event) -> {
System.out.println("It worked!");
});
VBox root = new VBox();
root.setAlignment(Pos.CENTER);
root.setSpacing(10);
root.getChildren().addAll(circle,btn);
StackPane textBox = new StackPane();
textBox.setAlignment(Pos.CENTER);
textBox.getChildren().add(input);
StackPane together = new StackPane();
together.getChildren().addAll(root,textBox);
Scene scene = new Scene(together, programX, programY);
primaryStage.setTitle("Circle code");
primaryStage.setScene(scene);
primaryStage.show();
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
launch(args);
}
}
解决方案
你的第二个StackPane
覆盖你VBox
,隐藏它Button
。要查看效果,请更改
together.getChildren().addAll(root, textBox);
至
together.getChildren().addAll(textBox , root);
当然,现在TextField
涵盖了。StackPane
相反,对圆圈和字段使用单个:
StackPane textBox = new StackPane();
textBox.setAlignment(Pos.CENTER);
textBox.getChildren().addAll(circle, input);
VBox
然后使用按钮将结果添加到 a中。
VBox root = new VBox();
root.setAlignment(Pos.CENTER);
root.setSpacing(10);
root.setPadding(new Insets(16));
root.getChildren().addAll(textBox, btn);
还可以考虑使用 a Spinner
and/or来控制大小。测试代码:Slider
import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.TextField;
import javafx.scene.layout.Pane;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;
/**
* @author diego
* @see https://stackoverflow.com/a/64852023/230513
* @see https://stackoverflow.com/a/37935114/230513
*/
public class CircleAndTextBox extends Application {
@Override
public void start(Stage primaryStage) {
int programX = 400;
int programY = 400;
int circleRadius = 100;
Circle circle = new Circle(programX / 2,programY / 2,circleRadius);
circle.setStroke(Color.RED);
circle.setStrokeWidth(3);
circle.setFill(Color.TRANSPARENT);
TextField input = new TextField();
input.setMaxWidth(100);
Button btn = new Button();
btn.setText("Change the size of the circle");
btn.setOnAction((ActionEvent event) -> {
System.out.println("It worked!");
});
StackPane textBox = new StackPane();
textBox.setAlignment(Pos.CENTER);
textBox.getChildren().addAll(circle, input);
VBox root = new VBox();
root.setAlignment(Pos.CENTER);
root.setSpacing(10);
root.setPadding(new Insets(16));
root.getChildren().addAll(textBox, btn);
Scene scene = new Scene(root);
primaryStage.setTitle("Circle code");
primaryStage.setScene(scene);
primaryStage.show();
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
launch(args);
}
}
推荐阅读
- python - 仅删除 Pandas 中值为 NAN 的单元格值
- docker - 运行 docker-compose 时,它不会按照 docker-entrypoint.sh 的指示进行
- html - 未根据媒体查询正确选择 CSS 悬停
- linux - Linux 1 次密码
- mongodb - 如何使用 MongoDB 的 $graphLookup 获取所有子节点
- php - 如何在 Laravel 中将多个复选框值存储到数据库中?
- ffmpeg - 无法在服务器中使用 MediaRecorder 录制流?
- unix - crlf和lf在效果和含义上有什么区别?
- php - PHP 从一个获取数组并添加到另一个的属性
- java - 向 Spring Cloud GCP 提供凭据的替代方法