Я знаю, что можно создать CSS-файл, подобный этому, и установить его в моей сцене.
.chart-line-symbol {
-fx-scale-x: 0.5;
-fx-scale-y: 0.5;
}
Но это не то, что мне нужно. Если я сделаю это, размер точки будет всегда одинаковым.
Как динамически изменить размер символа диаграммы, используя значение, полученное из TextField?
ChangeSymbolSize.java
package changesymbolsize;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;
public class ChangeSymbolSize extends Application {
@Override
public void start(Stage stage) throws Exception {
Parent root = FXMLLoader.load(getClass().getResource("MainLayout.fxml"));
Scene scene = new Scene(root);
stage.setTitle("Changing the symbol size");
stage.setScene(scene);
stage.show();
}
public static void main(String[] args) {
launch(args);
}
}
MainLayout.fxml
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.Button?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.control.SplitPane?>
<?import javafx.scene.control.TextField?>
<?import javafx.scene.layout.AnchorPane?>
<?import javafx.scene.layout.FlowPane?>
<AnchorPane id="AnchorPane" prefHeight="600.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/10.0.1" xmlns:fx="http://javafx.com/fxml/1" fx:controller="changesymbolsize.MainLayoutController">
<children>
<SplitPane dividerPositions="0.25" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
<items>
<AnchorPane>
<children>
<TextField fx:id="txt_pointSize" layoutX="14.0" layoutY="31.0" onAction="#setPointSize" prefWidth="60.0" AnchorPane.leftAnchor="14.0" AnchorPane.topAnchor="31.0" />
<Label layoutX="14.0" layoutY="14.0" text="Point Size" AnchorPane.leftAnchor="14.0" AnchorPane.topAnchor="14.0" />
<Button layoutX="74.0" layoutY="31.0" mnemonicParsing="false" onAction="#setPointSize" text="OK" />
</children>
</AnchorPane>
<FlowPane fx:id="pane_chart" />
</items>
</SplitPane>
</children>
</AnchorPane>
MainLayoutController.java
package changesymbolsize;
import java.net.URL;
import java.util.ResourceBundle;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.Node;
import javafx.scene.chart.LineChart;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.layout.FlowPane;
public class MainLayoutController implements Initializable {
@FXML
private Label label;
@FXML
private TextField txt_pointSize;
@FXML
private FlowPane pane_chart;
LineChart<Number, Number> lineChart;
@FXML
private void setPointSize(ActionEvent event) {
System.out.println("We should be able to change the symbol size");
System.out.println("using the value from the TextField");
double size = Double.parseDouble(txt_pointSize.getText());
// But how?
}
@Override
public void initialize(URL url, ResourceBundle rb) {
pane_chart.getChildren().add(getExampleChart());
}
Node getExampleChart(){
NumberAxis xAxis = new NumberAxis();
NumberAxis yAxis = new NumberAxis();
lineChart = new LineChart<Number, Number>(xAxis, yAxis);
int a = 6;
int b = 2;
lineChart.setTitle("f(x) = " + a + " x + " + b);
XYChart.Series series = new XYChart.Series();
series.setName("Example 1");
for (int x = 0; x <= 100; x++) {
double y = (a * x) + b;
series.getData().add(new XYChart.Data(x, y));
}
lineChart.getData().add(series);
lineChart.setCreateSymbols(true);
return lineChart;
}
}
Я новичок в JavaFX и CSS. Поэтому я не знаю, легко ли то, что я хочу сделать, но мне сложно понять, как это сделать.