如何为JavaFX图表设置背景图像?

javafx.scene.chart包提供类来创建即各图表-线图,面积图,条形图,饼图,气泡图,散点图等

您可以通过实例化相应的类来创建所需的图表。

设置背景图像和颜色

  • JavaFX CSS的-fx-background-image类用于将图像设置为图表的背景。

  • JavaFX CSS的-fx-background-color(属于region chart-plot-background)类用于设置背景色。

  • JavaFX Scene类具有一个可观察的列表,用于保存所有必需的样式表。您可以使用getStylesheets()方法获取此列表。

要将图像设置为图表的背景-

  • 在项目表的当前包中创建一个CSS文件(例如LineChart.css)。

  • 使用-fx-background-image CSS类将背景图像设置为-

.chart-plot-background {

   -fx-background-image: url("cat.jpg");

}

  • 使用-fx-background-color CSS类将绘图颜色设置为透明-

.chart-plot-background {

   -fx-background-color: transparent;

}

  • 在程序中,使用getStylesheets()方法获取样式表的可观察列表。

  • 使用add()方法将创建的CSS文件添加到列表中。

示例

LineChart.CSS-

.chart {

   -fx-padding: 10px;

   -fx-background-image: url("cat.jpg");

}

.chart-plot-background {

   -fx-background-color: transparent;

}

.chart-vertical-grid-lines {

   -fx-stroke: #dedddc; -fx-stroke-width: 2;

}

.chart-horizontal-grid-lines {

   -fx-stroke: #dedddc; -fx-stroke-width: 2;

}

Example.java-

import javafx.application.Application;

import javafx.scene.Scene;

import javafx.scene.chart.BubbleChart;

import javafx.stage.Stage;

import javafx.scene.chart.NumberAxis;

import javafx.scene.chart.XYChart;

import javafx.scene.layout.StackPane;

public class Example extends Application {

   public void start(Stage stage) {

      //定义轴

      NumberAxis xAxis = new NumberAxis(0, 100, 10);

      xAxis.setLabel("Age");

      NumberAxis yAxis = new NumberAxis(20, 100, 10);

      yAxis.setLabel("Weight");

      //创建气泡图

      BubbleChart bubbleChart = new BubbleChart(xAxis, yAxis);

      //准备XYChart.Series对象

      XYChart.Series series = new XYChart.Series();

      series.setName("work");

      series.getData().add(new XYChart.Data(10,30,4));

      series.getData().add(new XYChart.Data(25,40,5));

      series.getData().add(new XYChart.Data(40,50,9));

      series.getData().add(new XYChart.Data(55,60,7));

      series.getData().add(new XYChart.Data(70,70,9));

      series.getData().add(new XYChart.Data(85,80,6));

      //将数据设置为条形图

      bubbleChart.getData().add(series);

      //创建一个组对象

      StackPane root = new StackPane(bubbleChart);

      //设置场景

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

      stage.setTitle("Bubble Chart");

      scene.getStylesheets().add("styles/LineChart.css");

      stage.setScene(scene);

      stage.show();

   }

   public static void main(String args[]){

      launch(args);

   }

}

输出结果


以上是 如何为JavaFX图表设置背景图像? 的全部内容, 来源链接: utcz.com/z/360803.html

回到顶部