JavaFX中WebView的java与JS代码互相调用

java代码 

package main;

import javafx.application.Application;
import javafx.beans.value.ObservableValue;
import javafx.concurrent.Worker;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.VBox;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javafx.stage.Stage;
import netscape.javascript.JSObject;

import java.io.File;
import java.io.IOException;

public class Main extends Application {
    @Override
    public void start(final Stage stage) throws IOException {

        final WebView browser = new WebView();
        webEngine = browser.getEngine();
        String url = new File("./filePage.html").toURI().toURL().toString();
        webEngine.load(url);
        webEngine.getLoadWorker().stateProperty().addListener(
                (ObservableValue<? extends Worker.State> ov, Worker.State oldState,
                 Worker.State newState) -> {

                    if (newState == Worker.State.SUCCEEDED) {
                        JSObject win = (JSObject) webEngine.executeScript("window");
                        win.setMember("apps",apps);//设置变量
                    }
                });

        Button button1 = new Button("java调JS方法");
        button1.setOnAction(event -> {
            try {
                
                JSObject win = (JSObject) webEngine.executeScript("window");
                //webEngine.executeScript("show()");//执行js函数
                //win.call("show","a","b");
                win.eval("show('a','b')");
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        VBox stackPane = new VBox();
        stackPane.setSpacing(20);
        stackPane.getChildren().addAll(button1,browser);
        Scene scene = new Scene(stackPane,600,400);

        scene.setRoot(stackPane);
        stage.setScene(scene);
        stage.show();

    }

    A apps = new A();

    WebEngine webEngine;

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

    //必须公有
    public static class A{

        public String showInfo(String info) {
            return "A{info="+ info +"}";
        }
    }
}

html代码

filePage.html
<html>
<head>
    <meta charset="UTF-8">
</head>
<body>
<div class="top">
    <button onclick="showJava()">JS调java方法</button>
    <div >JS调java方法结果:<span id="infoJava"></span></div>
    <div >java调JS方法结果:<span id="info"></span></div>
</div>
</body>
<script>
    var apps = 'test';
    function showJava() {
        document.getElementById("infoJava").innerText= apps.showInfo("java");
    }
    function show(a,b) {
        document.getElementById("info").innerText="a="+a+",b="+b;
    }
</script>
</html>

运行结果

JavaFX WebView 默认情况下是无法调用摄像头的,因为它是基于 WebKit 引擎实现的。不过,你可以通过添加一些自定义的 JavaScript 代码来实现该功能。 以下是一个简单的示例,演示如何在 JavaFX WebView 启用摄像头: ```java import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.layout.StackPane; import javafx.scene.web.WebEngine; import javafx.scene.web.WebView; import javafx.stage.Stage; public class WebViewExample extends Application { @Override public void start(Stage primaryStage) { WebView webView = new WebView(); WebEngine webEngine = webView.getEngine(); webEngine.loadContent("<html><body><video id='video' autoplay></video><script>" + "navigator.mediaDevices.getUserMedia({video: true})" + ".then(function(stream) {document.getElementById('video').srcObject = stream;})" + ".catch(function(error) {console.log('Error: ' + error);});" + "</script></body></html>"); StackPane root = new StackPane(); root.getChildren().add(webView); Scene scene = new Scene(root, 800, 600); primaryStage.setScene(scene); primaryStage.show(); } public static void main(String[] args) { launch(args); } } ``` 该示例,我们使用了 JavaScript 的 `navigator.mediaDevices.getUserMedia()` 方法来请求摄像头访问权限,并将其返回的视频流对象赋值给页面上的 `<video>` 标签。注意,该代码只能在使用 HTTPS 或 localhost 访问的页面上运行,否则浏览器会拒绝访问摄像头。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值