JavaFX 未以 16:9 比例显示完整网页

JavaFX not showing full web page on 16:9 ratio

代码如下:

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.VBox;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javafx.stage.Stage;

public class Main extends Application{

public static void main(String[] args){

    Application.launch(args);

}

@Override

public void start(Stage stage) throws Exception{

    WebView myWebView = new WebView();
    WebEngine engine = myWebView.getEngine();
    engine.load("https://twitter.com/");

    VBox root = new VBox();
    root.getChildren().addAll(myWebView);

    Scene scene = new Scene(root, 1280, 720);
    stage.setScene(scene);

    stage.show();
}
}

如果我 运行 这样做,它将在应用程序的前 3 个四分之一处显示网页 window,白框占据另一四分之一。更糟糕的是,如果我最大化 window,该站点只占应用程序的一半左右 window。不确定是什么原因造成的...

您需要让它填满舞台上的整个 space。根据您的选择,您将遇到上述情况。

案例 1: 使用 BorderPane。

通过将 BorderPane 直接添加到舞台,并将 WebView 添加到 BorderPane 的中心,这将使 webView 占用舞台的所有可用宽度和高度。

示例:

@Override
public void start(Stage stage) throws Exception {

    WebView myWebView = new WebView();
    WebEngine engine = myWebView.getEngine();
    engine.load("https://twitter.com/");

    BorderPane root = new BorderPane();
    root.setCenter(myWebView);

    Scene scene = new Scene(root);
    stage.setScene(scene);

    stage.show();
}

案例 2: 使用 VBox 或 HBox。

这些窗格默认采用 VBox 的所有可用宽度和 HBox 的所有可用高度 space,并留下其他维度由其子节点计算。为了利用完整的 space,您需要告诉这些窗格内的节点始终增长(垂直或水平取决于窗格)

示例:

@Override
public void start(Stage stage) throws Exception {

    WebView myWebView = new WebView();
    WebEngine engine = myWebView.getEngine();
    engine.load("https://twitter.com/");

    VBox root = new VBox(); // or HBox 
    root.getChildren().add(myWebView);

    // HBox.setHgrow(myWebView, Priority.ALWAYS);
    VBox.setVgrow(myWebView, Priority.ALWAYS);

    Scene scene = new Scene(root);
    stage.setScene(scene);

    stage.show();
}

还有很多其他窗格,如 AnchorPane(您需要设置其锚点)或 FlowPane 等,在某些情况下,您必须将它们的 prefWidthProperty 和 prefHeightProperty 与实际绑定 widthProperty/heightProperty舞台的。但我相信你明白了。