我想使用堆积图(条形图和折线图)显示数据,并且找到了本教程:Stacking charts in JavaFX

效果很好,但是当我使用较小值的列表时,结果显示不正确。

这是代码示例:

public class StackedChartSample extends Application {

    final static String austria = "Austria";
    final static String brazil = "Brazil";
    final static String france = "France";
    final static String italy = "Italy";
    final static String usa = "USA";

    @Override
    public void start(Stage stage) {

        final CategoryAxis xAxis = new CategoryAxis();
        final NumberAxis yAxis = new NumberAxis();

        // base chart
        final BarChart<String, Number> barChart = new BarChart<String, Number>(xAxis, yAxis);
        barChart.setLegendVisible(false);
        barChart.setAnimated(false);
        barChart.setTitle("Equipe1 Chart");
        barChart.setStyle("CHART_COLOR_1: blue;");

        xAxis.setLabel("Country");
        yAxis.setLabel("Value");

        // overlay chart
        LineChart<String, Number> lineChart = new LineChart<String, Number>(xAxis, yAxis);
        lineChart.setLegendVisible(false);
        lineChart.setAnimated(false);
        lineChart.setCreateSymbols(true);
        lineChart.setAlternativeRowFillVisible(false);
        lineChart.setAlternativeColumnFillVisible(false);
        lineChart.setHorizontalGridLinesVisible(false);
        lineChart.setVerticalGridLinesVisible(false);
        lineChart.getXAxis().setVisible(false);
        lineChart.getYAxis().setVisible(false);
        lineChart.getStylesheets().addAll(getClass().getResource("chart.css").toExternalForm());

        barChart.getData().add( createChartSeries());
        lineChart.getData().add( createChartSeries2());

        StackPane root = new StackPane();
        root.getChildren().addAll( barChart, lineChart);

        Scene scene = new Scene(root, 800, 600);

        stage.setScene(scene);
        stage.show();
    }

    private XYChart.Series<String,Number> createChartSeries() {

        XYChart.Series<String,Number> series = new XYChart.Series<String,Number>();
        series.getData().add(new XYChart.Data<String,Number>("frf", 68));
        series.getData().add(new XYChart.Data<String,Number>("fef", 67.82));
        series.getData().add(new XYChart.Data<String,Number>("fdf", 50));
        series.getData().add(new XYChart.Data<String,Number>("fsf", 43.15));
        series.getData().add(new XYChart.Data<String,Number>("faf", 70));
        series.getData().add(new XYChart.Data<String,Number>("fxf", 68,34));
        series.getData().add(new XYChart.Data<String,Number>("dd", 60.82));
        series.getData().add(new XYChart.Data<String,Number>("ddd", 50));
        series.getData().add(new XYChart.Data<String,Number>("dyy", 80.15));
        series.getData().add(new XYChart.Data<String,Number>("ccc", 85));

        return series;
    }

    private XYChart.Series<String,Number> createChartSeries2() {

        XYChart.Series<String,Number> series = new XYChart.Series<String,Number>();
        series.getData().add(new XYChart.Data<String,Number>("frf", 67));
        series.getData().add(new XYChart.Data<String,Number>("fef", 67));
        series.getData().add(new XYChart.Data<String,Number>("fdf", 67));
        series.getData().add(new XYChart.Data<String,Number>("fsf", 67));
        series.getData().add(new XYChart.Data<String,Number>("faf", 67));
        series.getData().add(new XYChart.Data<String,Number>("fxf", 67));
        series.getData().add(new XYChart.Data<String,Number>("dd", 67));
        series.getData().add(new XYChart.Data<String,Number>("ddd", 67));
        series.getData().add(new XYChart.Data<String,Number>("dyy", 67));
        series.getData().add(new XYChart.Data<String,Number>("ccc", 67));
        return series;
    }

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


结果如下:

最佳答案

您必须设置:


lowerBound-该轴的下限
upperBound-该轴的上限,
tickUnit-刻度单位,即刻度之间的间隔

final NumberAxis yAxis = new NumberAxis(0,100,10);

09-25 22:00