0

サイズ変更時にハングする単純な javafx アプリケーションがあります。

アプリケーションは jdk1.7.0_10 でコンパイル/ビルドされました
OS: Windows 8
IDE: NetBeans 7.2.1

この問題は、下部のテーブルにデータを入力し、アプリケーションの右の境界線をシフトしてサイズ変更を開始すると発生します。ときどき、SplitPanes の内側の境界線と外部アプリケーションの境界線が崩壊するまで、しばらくの間サイズ変更を試してみる必要があります。行が空の場合、つまりテーブルに何も入力されていない場合、すべてが正常に機能します-ハングはなく、あらゆる方向に好きなようにサイズを変更できます-そして何もハングしません。アプリケーションがハングし、Netbeans 出力ウィンドウに Java Result: 255 が表示されて終了します。
どうなり得るか?ログも例外も何もありません...それは私を怒らせ、多くの時間を失いました:(

これが私のコントローラーです:

public class MyFXMLController implements Initializable {

@FXML
TableView<Person> table;

@FXML
TableColumn<Person, String> firstNameCol;
@FXML
TableColumn<Person, String> lastNameCol;
@FXML
TableColumn<Person, String> carCol;

@Override
public void initialize(URL url, ResourceBundle rb) {
    // TODO

    firstNameCol.setCellValueFactory(new PropertyValueFactory("firstName"));
    lastNameCol.setCellValueFactory(new PropertyValueFactory("lastName"));
    carCol.setCellValueFactory(new PropertyValueFactory("car"));

    Person p1 = new Person();
    p1.setFirstName("A");
    p1.setLastName("B");
    p1.setCar("ferrari");
    ObservableList<Person> teamMembers = FXCollections.observableArrayList(p1);
    table.setItems(teamMembers);
}
}

主なクラスは次のとおりです。

public class TestTableView extends Application {

@Override
public void start(Stage primaryStage) {
    Button btn = new Button();
    btn.setText("Say 'Hello World'");
    btn.setOnAction(new EventHandler<ActionEvent>() {
        @Override
        public void handle(ActionEvent event) {
            System.out.println("Hello World!");
        }
    });

    AnchorPane page = null;
    try {
        page = (AnchorPane) FXMLLoader.load(TestTableView.class.getResource("/testtableview/myFXML.fxml"));
    } catch (IOException ex) {
        Logger.getLogger(TestTableView.class.getName()).log(Level.SEVERE, null, ex);
    }
    Scene scene = new Scene(page);
    primaryStage.setScene(scene);
    primaryStage.setTitle("my");
    primaryStage.show();
}

/**
 * The main() method is ignored in correctly deployed JavaFX application.
 * main() serves only as fallback in case the application can not be
 * launched through deployment artifacts, e.g., in IDEs with limited FX
 * support. NetBeans ignores main().
 *
 * @param args the command line arguments
 */
public static void main(String[] args) {
    launch(args);

}
}

および使用される FXML ファイル:

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

<?import java.lang.*?>
<?import java.net.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>

    <AnchorPane id="AnchorPane" prefHeight="400.0" prefWidth="715.0000999999975" styleClass="mainFxmlClass" xmlns:fx="http://javafx.com/fxml" fx:controller="testtableview.MyFXMLController">
      <children>
        <SplitPane dividerPositions="0.22720894429047145" focusTraversable="true" prefHeight="400.0" prefWidth="600.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
          <items>
            <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="160.0" prefWidth="100.0">
              <children>
                <TreeView prefHeight="398.0" prefWidth="159.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0" />
              </children>
            </AnchorPane>
            <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="160.0" prefWidth="100.0">
              <children>
                <SplitPane dividerPositions="0.5" focusTraversable="true" orientation="VERTICAL" prefHeight="398.0" prefWidth="491.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
                  <items>
                    <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="100.0" prefWidth="160.0">
                      <children>
                        <TableView id="table" prefHeight="195.0" prefWidth="489.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
                          <columns>
                            <TableColumn prefWidth="75.0" text="Column X" />
                            <TableColumn prefWidth="75.0" text="Column X">
                              <columns>
                                <TableColumn prefWidth="75.0" text="Column X" />
                                <TableColumn prefWidth="75.0" text="Column X" />
                              </columns>
                            </TableColumn>
                            <TableColumn prefWidth="75.0" text="Column X">
                              <columns>
                                <TableColumn prefWidth="75.0" text="Column X" />
                                <TableColumn prefWidth="75.0" text="Column X" />
                              </columns>
                            </TableColumn>
                            <TableColumn prefWidth="75.0" text="Column X" />
                            <TableColumn prefWidth="75.0" text="Column X" />
                          </columns>
                        </TableView>
                      </children>
                    </AnchorPane>
                    <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="100.0" prefWidth="160.0">
                      <children>
                        <TableView fx:id="table" prefHeight="195.0" prefWidth="489.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
                          <columns>
                            <TableColumn prefWidth="75.0" text="firstNameCol" fx:id="firstNameCol" />
                            <TableColumn prefWidth="75.0" text="lastNameCol" fx:id="lastNameCol" />
                            <TableColumn prefWidth="75.0" text="carCol" fx:id="carCol" />
                            <TableColumn prefWidth="75.0" text="Column X" />
                            <TableColumn prefWidth="75.0" text="Column X" />
                            <TableColumn prefWidth="75.0" text="Column X" />
                          </columns>
                        </TableView>
                      </children>
                    </AnchorPane>
                  </items>
                </SplitPane>
              </children>
            </AnchorPane>
          </items>
        </SplitPane>
      </children>
      <stylesheets>
        <URL value="@myfxml.css" />
      </stylesheets>
    </AnchorPane>

基になるデータ クラスは次のとおりです。

package testtableview;

import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;

public class Person {

    private StringProperty firstName;

    public void setFirstName(String value) {
        firstNameProperty().set(value);
    }

    public String getFirstName() {
        return firstNameProperty().get();
    }

    public StringProperty firstNameProperty() {
        if (firstName == null) {
            firstName = new SimpleStringProperty(this, "firstName");
        }
        return firstName;
    }
    private StringProperty lastName;

    public void setLastName(String value) {
        lastNameProperty().set(value);
    }

    public String getLastName() {
        return lastNameProperty().get();
    }

    public StringProperty lastNameProperty() {
        if (lastName == null) {
            lastName = new SimpleStringProperty(this, "lastName");
        }
        return lastName;
    }

       private StringProperty car;

    public void setCar(String value) {
        carProperty().set(value);
    }

    public String getCar() {
        return carProperty().get();
    }

    public StringProperty carProperty() {
        if (car == null) {
            car = new SimpleStringProperty(this, "car");
        }
        return car;
    }

}
4

1 に答える 1