我正在研究一个JavaFX应用程序,其中包含少量由内部webkit浏览器呈现的html,css,JS文件。现在,问题在于我们所拥有的CSS动画在JavaFX提供的webkit浏览器中无法顺利呈现,但Firefox或Chrome中的相同代码更加流畅。另外,没有持久性可用(目前在Java中使用变量,并且通过JS进行持久化通信)。JavaFX:使用JavaFX嵌入可用webview以外的浏览器
我在找什么方法可以整合一些无头浏览器或一些设置来使CSS动画更流畅。我遇到的唯一的事情是JxBrowser,但它的个人使用成本太高。
代码:
public class Main extends Application {
private Scene scene;
MyBrowser myBrowser;
String completeText = "";
@Override
public void start(Stage primaryStage) throws Exception{
primaryStage.setTitle("Frontend");
java.net.CookieManager manager = new java.net.CookieManager();
java.net.CookieHandler.setDefault(manager);
myBrowser = new MyBrowser();
scene = new Scene(myBrowser, 1080, 1920);
primaryStage.setScene(scene);
primaryStage.setFullScreen(true);
primaryStage.show();
// @ being the escape character
scene.setOnKeyTyped(new EventHandler<KeyEvent>() {
@Override
public void handle(KeyEvent event) {
String text = event.getCharacter();
if (text.equals("0")) {
String tempText = completeText;
completeText = "";
processText(tempText);
}else {
completeText = completeText+text;
}
}
});
}
}
MyBrowser:
public class MyBrowser extends Region {
public MyBrowser() {
webEngine.getLoadWorker().stateProperty().addListener((observable, oldValue, newValue) -> {
if (newValue == Worker.State.SUCCEEDED) {
JSObject window = (JSObject) webEngine.executeScript("window");
window.setMember("app", this);
}
});
URL urlHello = getClass().getResource(hellohtml);
webEngine.load(urlHello.toExternalForm());
webView.setPrefSize(1080, 1920);
webView.setContextMenuEnabled(false);
getChildren().add(webView);
}
CSS代码包含动画:
#ball-container.go #ball{
-webkit-animation: rotating-inverse 2s ease-out 0s 1 normal;
animation: rotating-inverse 2s ease-out 0s 1 normal;
}
#ball-container {
height: 102px;
width: 102px;
position: absolute;
top: -95px;
left: 480px;
-webkit-transition: all 0.9s ease-in-out 0s;
transition: all 0.9s ease-in-out 0s;
}
#ball-container.shake .ball-wrapper{
-webkit-animation: yAxis 0.9s ease-in-out;
animation: yAxis 0.9s ease-in-out;
}
谢谢。
的你提供的代码不能编译。此外,HTML缺失。 –
@OJKrylow:这段代码仅供参考,我们的动画之一。你可以尝试从网络上的任何CSS动画(我们已经做到了),并且性能很差。 –
我使用https://daneden.github.io/animate.css/在64位和32位模式下测试了WebView。动画没有明显的麻烦。除了某些元素没有正确渲染外,动画看起来很好。 –