如何在javaFX webView中找到完全加载网页的确切时间

Dil*_*Dil 2 javafx-2

我试图找出web-View加载网页所花费的确切时间.如果我在webEngine.load(url)之前和之后使用计时器,它不会给我加载网址的确切时间.在大多数情况下,我用这种方法花费的时间是1毫秒,而页面实际上是在很长一段时间后加载的.

请帮忙.提前致谢.

jew*_*sea 11

webEngine.load(url)触发异步加载任务,可以使用webEngine.getLoadWorker()监视该任务.

这是一个监视加载工作者加载进度并在页面顶部报告进度的示例.

loadprogress

import javafx.application.Application;
import javafx.beans.binding.Bindings;
import javafx.beans.property.*;
import javafx.beans.value.*;
import javafx.concurrent.Worker;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.layout.*;
import javafx.scene.web.*;
import javafx.stage.Stage;

/** Reports load times for pages loaded in a WebView */
public class LoadTimer extends Application {

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

  @Override public void start(final Stage stage) {
    final WebView webview  = new WebView();

    VBox layout = new VBox();
    layout.getChildren().setAll(
        createProgressReport(webview.getEngine()),
        webview
    );

    stage.setScene(new Scene(layout));
    stage.show();

    webview.getEngine().load("http://www.fxexperience.com");
  }

  /** @return a HBox containing a ProgressBar bound to engine load progress and a Label showing load times */
  private HBox createProgressReport(WebEngine engine) {
    final LongProperty startTime   = new SimpleLongProperty();
    final LongProperty endTime     = new SimpleLongProperty();
    final LongProperty elapsedTime = new SimpleLongProperty();

    final ProgressBar loadProgress = new ProgressBar();
    loadProgress.progressProperty().bind(engine.getLoadWorker().progressProperty());

    final Label loadTimeLabel = new Label();
    loadTimeLabel.textProperty().bind(
        Bindings.when(
            elapsedTime.greaterThan(0))
              .then(
                  Bindings.concat("Loaded page in ", elapsedTime.divide(1_000_000), "ms")
              )
              .otherwise(
                  "Loading..."
              )
    );

    elapsedTime.bind(Bindings.subtract(endTime, startTime));

    engine.getLoadWorker().stateProperty().addListener(new ChangeListener<Worker.State>() {
      @Override
      public void changed(ObservableValue<? extends Worker.State> observableValue, Worker.State oldState, Worker.State state) {
        switch (state) {
          case RUNNING:
            startTime.set(System.nanoTime());
            break;

          case SUCCEEDED:
            endTime.set(System.nanoTime());
            break;
        }
      }
    });

    HBox progressReport = new HBox(10);
    progressReport.getChildren().setAll(
        loadProgress,
        loadTimeLabel
    );
    progressReport.setPadding(new Insets(5));
    progressReport.setAlignment(Pos.CENTER_LEFT);

    return progressReport;
  }
}
Run Code Online (Sandbox Code Playgroud)