JavaFx 2.0 с FXML: вкладки внизу, а не сверху? - PullRequest
0 голосов
/ 12 ноября 2011

Можно ли определить TabBar для размещения вкладок внизу, а не сверху?

Ответы [ 2 ]

6 голосов
/ 01 февраля 2013

Чтобы установить сторону вкладок, используйте следующий фрагмент:

TabPane tabPane = new TabPane();
Tab tab1 = new Tab("Tab 1");
tab1.setContent(new Label("Tab1 content"))
tabPane.getTabs().add(tab1);
tabPane.setSide(Side.BOTTOM)

Теперь содержимое находится над вкладками.

Также как полный пример FXML:

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

<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.collections.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.effect.*?>
<?import javafx.scene.image.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.paint.*?>
<?import javafx.scene.shape.*?>
<?import javafx.scene.text.*?>
<?import javafx.scene.web.*?>

<BorderPane xmlns:fx="http://javafx.com/fxml" fx:controller="example.MainViewController">
  <bottom>
    <HBox>
      <children>
        <Button fx:id="btnNewTab" mnemonicParsing="false" text="Add New Tab" onAction="#btnNewTabAction" />
      </children>
    </HBox>
  </bottom>
  <center>
    <TabPane fx:id="tabPane" side="BOTTOM">
      <tabs>
        <Tab text="Untitled Tab 1">
          <content>
            <AnchorPane id="Content">
                <Label>Content 1</Label>
            </AnchorPane>
          </content>
        </Tab>
        <Tab text="Untitled Tab 2">
          <content>
            <AnchorPane id="Content">
                <Label>Content 2</Label>
            </AnchorPane>
          </content>
        </Tab>
      </tabs>
    </TabPane>
  </center>
  <top>
    <Label text="TabPane Example" />
  </top>
</BorderPane>

Основной класс:

package example;

import java.io.File;
import java.io.IOException;
import java.net.URL;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.fxml.JavaFXBuilderFactory;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class ExampleMain extends Application {

    /**
     * @param args
     */
    public static void main(String[] args) {
        Application.launch(ExampleMain.class, args);
    }

    @Override
    public void start(Stage primaryStage) throws Exception {
        URL location = ExampleMain.class.getResource("MainView.fxml");

        FXMLLoader fxmlLoader = new FXMLLoader();
        fxmlLoader.setLocation(location);
        fxmlLoader.setBuilderFactory(new JavaFXBuilderFactory());

        try {
            Parent root = (Parent) fxmlLoader.load(location.openStream());

            // in case you need access to the controller
            MainViewController mainViewController = fxmlLoader.getController();

            primaryStage.setScene(new Scene(root, 1024, 768));
            Scene s = primaryStage.getScene();
            s.setRoot(root);
            primaryStage.sizeToScene();
            primaryStage.show();

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

И контроллер:

package example;

import javafx.fxml.FXML;
import javafx.scene.control.Label;
import javafx.scene.control.Tab;
import javafx.scene.control.TabPane;

public class MainViewController {

    private static int counter = 0;

    @FXML
    private TabPane tabPane;

    @FXML
    public void btnNewTabAction() {
        Tab tab = new Tab();
        tab.setText("new Tab " + ++counter);
        tab.setContent(new Label("Content of new tab " + counter));
        tabPane.getTabs().add(tab);
    }
}

, как вы можете видеть в примере, fxml представляет собой представление XML классов Java.Если класс имеет сторону свойства (getSide, setSide), то в fxml класс имеет сторону атрибута.Поэтому вы можете прочитать документацию по API, чтобы узнать, какие атрибуты также доступны в fxml.

Надеюсь, это поможет.

0 голосов
/ 13 ноября 2011

Не определяйте TabBar!Используйте правильную панель макета, например javafx.scene.layout.BorderPane.Найдите прилагаемые примеры для API JavaFX 2.0 и FXML:

API JAVAFX 2.0

package tabtest;

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Tab;
import javafx.scene.control.TabPane;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;

public class TabTest extends Application {

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

    @Override
    public void start(Stage primaryStage) {
        BorderPane root = new BorderPane();
        Scene scene = new Scene(root, 300, 250);

        TabPane tabPane = new TabPane();
        Tab tab1 = new Tab("Tab 1");
        tabPane.getTabs().add(tab1);

        root.setBottom(tabPane);

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

Для получения дополнительной информации см. http://download.oracle.com/javafx/2.0/layout/jfxpub-layout.htm

FXML

package fxmltest;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class FxmlTest extends Application {

    public static void main(String[] args) {
        Application.launch(FxmlTest.class, args);
    }

    @Override
    public void start(Stage stage) throws Exception {
        Parent root = FXMLLoader.load(getClass().getResource("Sample.fxml"));

        Scene scene = new Scene(root, 300, 250);
        stage.setScene(scene);
        stage.show();
    }
}

Sample.fxml:

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

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

<BorderPane>
    <bottom>
        <TabPane>
            <tabs>
                <Tab text="Tab 1" />
            </tabs>
        </TabPane>
    </bottom>
</BorderPane>
...