【问题标题】:How to change color of a single bar java fx如何更改单条javafx的颜色
【发布时间】:2013-02-20 10:44:44
【问题描述】:

这是我的代码,它生成从 0 到 10 的 10 个值的条形图。我想改变条的颜色如下

如果 i>5 颜色==红色 如果 i>8 颜色==蓝色

所以最终出局将是 0-5(默认黄色条)6-8(红色条)9(蓝色条)

请帮帮我.. 谢谢

public class BarChartSample extends Application {

    @Override
    public void start(Stage stage) {
        stage.setTitle("Bar Chart Sample");
        final CategoryAxis xAxis = new CategoryAxis();
        final NumberAxis yAxis = new NumberAxis();
        final BarChart < String, Number > bc = new BarChart < String, Number > (xAxis, yAxis);

        bc.setTitle("Country Summary");
        xAxis.setLabel("bars");
        yAxis.setLabel("Value");
        XYChart.Series series1 = new XYChart.Series();
        series1.setName("...");

        for (int i = 0; i < 10; i++) {
            //here i want to change color of bar if value of i is >5 than red if i>8 than blue
            series1.getData().add(new XYChart.Data("Value", i));
        }
    }

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

【问题讨论】:

    标签: java javafx bar-chart


    【解决方案1】:

    我创建了一个sample solution

    解决方案的工作原理是根据条形数据的值将条形的-fx-bar-fill 颜色设置为不同的颜色。

    final XYChart.Data<String, Number> data = new XYChart.Data("Value " + i , i);
    data.nodeProperty().addListener(new ChangeListener<Node>() {
      @Override public void changed(ObservableValue<? extends Node> ov, Node oldNode, Node newNode) {
        if (newNode != null) {
          if (data.getYValue().intValue() > 8 ) {
            newNode.setStyle("-fx-bar-fill: navy;");
          } else if (data.getYValue().intValue() > 5 ) {
            newNode.setStyle("-fx-bar-fill: firebrick;");
          }  
        }
      }
    });
    

    【讨论】:

    • 我还有一个问题是可以在每个条形图的顶部分别显示图形值,即(i 的值)
    • 请以问题而非 cmets 的形式提出其他问题,谢谢
    • @jewelsea 您将此link 标记为重复,但事实并非如此。这是一个条形图,“重复”是一个areachart..
    猜你喜欢
    • 2012-11-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-09-02
    • 2019-01-17
    • 2012-11-08
    • 2017-11-24
    • 1970-01-01
    相关资源
    最近更新 更多