【问题标题】:JavaFX LineChart using SceneBuilder使用 SceneBuilder 的 JavaFX LineChart
【发布时间】:2018-05-12 13:42:40
【问题描述】:

我正在尝试使用一些随机信息制作一个简单的 LineChart,但是当我尝试通过 SceneBuilder 使用 fxml 文件进行操作时,图表显示但从未被填充。每当我手动创建 vbox、折线图和场景时,一切正常。使用 fxml 文件时,我真的很困惑图表代码应该去哪里。

public class Main extends Application {
    LineChart chart1;

    @Override
    public void start(Stage primaryStage) throws Exception {
        //Through FXML
        Parent root = FXMLLoader.load(getClass().getResource("sample.fxml"));
        primaryStage.setTitle("Chart Test");
        primaryStage.setScene(new Scene(root, 300, 275));
        primaryStage.show();

        //Manually
//        LineChart chart1;
//        XYChart.Series series1 = new XYChart.Series();
//        NumberAxis xAxis = new NumberAxis();
//        NumberAxis yAxis = new NumberAxis();
//        xAxis.setLabel("X Axis");
//        yAxis.setLabel("Y Axis");
//        series1.setName("Series 1");
//        chart1 = new LineChart(xAxis, yAxis);
//        series1.getData().add(new XYChart.Data<>(1, 20));
//        series1.getData().add(new XYChart.Data<>(2, 100));
//        series1.getData().add(new XYChart.Data<>(3, 80));
//        series1.getData().add(new XYChart.Data<>(4, 180));
//        series1.getData().add(new XYChart.Data<>(5, 20));
//        series1.getData().add(new XYChart.Data<>(6, -10));
//        chart1.getData().add(series1);
//        VBox vbox=new VBox(chart1);
//        Scene scene=new Scene(vbox,600,400);
//        primaryStage.setScene(scene);
//        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}
public class Controller implements Initializable {

    @FXML
    LineChart chart1;

    @Override
    public void initialize(URL location, ResourceBundle resources) {
        XYChart.Series series1 = new XYChart.Series();
        NumberAxis xAxis = new NumberAxis();
        NumberAxis yAxis = new NumberAxis();
        xAxis.setLabel("X Axis");
        yAxis.setLabel("Y Axis");
        series1.setName("Series 1");
        chart1 = new LineChart(xAxis, yAxis);
        series1.getData().add(new XYChart.Data<>(1, 20));
        series1.getData().add(new XYChart.Data<>(2, 100));
        series1.getData().add(new XYChart.Data<>(3, 80));
        series1.getData().add(new XYChart.Data<>(4, 180));
        series1.getData().add(new XYChart.Data<>(5, 20));
        series1.getData().add(new XYChart.Data<>(6, -10));
        chart1.getData().add(series1);
    }

}
<?xml version="1.0" encoding="UTF-8"?>

<?import javafx.scene.chart.CategoryAxis?>
<?import javafx.scene.chart.LineChart?>
<?import javafx.scene.chart.NumberAxis?>
<?import javafx.scene.layout.BorderPane?>
<?import javafx.scene.layout.ColumnConstraints?>
<?import javafx.scene.layout.GridPane?>
<?import javafx.scene.layout.RowConstraints?>

<GridPane alignment="center" hgap="10" vgap="10" xmlns="http://javafx.com/javafx/8.0.141" xmlns:fx="http://javafx.com/fxml/1" fx:controller="sample.Controller">
   <columnConstraints>
      <ColumnConstraints />
   </columnConstraints>
   <rowConstraints>
      <RowConstraints />
   </rowConstraints>
   <children>
      <BorderPane prefHeight="298.0" prefWidth="356.0">
         <center>
            <LineChart fx:id="chart1" title="Chart Test" BorderPane.alignment="CENTER">
              <xAxis>
                <CategoryAxis side="BOTTOM" />
              </xAxis>
              <yAxis>
                <NumberAxis side="LEFT" />
              </yAxis>
            </LineChart>
         </center>
      </BorderPane>
   </children>
</GridPane>

【问题讨论】:

  • 不要新建折线图;它(可能)已经在 FXML 文件中创建。
  • 好的,那我如何将 xAxis 和 yAxis 传递给它呢?
  • 嗯,大概你也在 FXML 文件中这样做......你能在问题中发布 FXML 文件吗?
  • 将 fxml 添加到代码中
  • 好的,所以您的 FXML 定义了图表和两个轴。无需在控制器中创建新的。 (您在控制器中创建的图表永远不会添加到场景图中,这就是为什么您看不到它显示的数据。)去掉initialize() 方法中的轴和chart1 = new LineChart(...) 行。

标签: javafx-8 scenebuilder linechart


【解决方案1】:

您已经使用代码在 FXML 文件中创建了 LineChart 和轴

<LineChart fx:id="chart1" title="Chart Test" BorderPane.alignment="CENTER">
  <xAxis>
    <CategoryAxis side="BOTTOM" />
  </xAxis>
  <yAxis>
    <NumberAxis side="LEFT" />
  </yAxis>
</LineChart>

此图表被添加到边框窗格中,而边框窗格又被添加到从FXMLLoader.load() 方法返回并放置在场景中的网格窗格中。

但是,在您的 initialize() 方法中,您将创建 另一个 折线图:

chart1 = new LineChart(xAxis, yAxis);

然后您继续填充数据。由于这个新的折线图永远不会显示在场景中,因此您永远看不到数据。

另外,请注意两个图表之间存在差异:在 FXML 中创建的图表中,您有一个 CategoryAxis,这是一个 Axis&lt;String&gt; 作为 x 轴,但在控制器中创建的图表中,您使用 NumberAxis 作为 x 轴。您可能想要NumberAxis,所以更改 FXML:

<LineChart fx:id="chart1" title="Chart Test" BorderPane.alignment="CENTER">
  <xAxis>
    <NumberAxis side="BOTTOM" />
  </xAxis>
  <yAxis>
    <NumberAxis side="LEFT" />
  </yAxis>
</LineChart>

然后简单地删除第二个折线图(和第二组轴)的创建:

@FXML
LineChart<Number, Number> chart1;

@Override
public void initialize(URL location, ResourceBundle resources) {
    XYChart.Series<Number, Number> series1 = new XYChart.Series<>();
    series1.setName("Series 1");
    series1.getData().add(new XYChart.Data<>(1, 20));
    series1.getData().add(new XYChart.Data<>(2, 100));
    series1.getData().add(new XYChart.Data<>(3, 80));
    series1.getData().add(new XYChart.Data<>(4, 180));
    series1.getData().add(new XYChart.Data<>(5, 20));
    series1.getData().add(new XYChart.Data<>(6, -10));
    chart1.getData().add(series1);
}

【讨论】:

  • 谢谢!现在可以了。不得不手动修改 fxml 文件,因为我不知道如何在 SceneBuilder 中将轴从 categoryAxis 更改为 numberAxis
  • @Arigatex 似乎不是在场景生成器中改变它的方法:目前是filed as a bug
猜你喜欢
  • 2014-08-14
  • 1970-01-01
  • 1970-01-01
  • 2017-06-16
  • 2014-12-02
  • 2016-05-30
  • 1970-01-01
  • 1970-01-01
  • 2022-01-01
相关资源
最近更新 更多