javascript - 未定义phonertc - 浏览器上的Cordova Phonertc

标签 javascript cordova browser cordova-plugins phonertc

我正在尝试使用 phonertc plugin for apache cordova 构建一个测试应用 。 我正在关注 wiki,所以我创建了 Turn 服务器,并且实现了一个 socket.io 信号服务器。所有这些服务器都在工作。

但是当我尝试构建演示应用程序时,在创建项目、添加平台和插件后,从 the wiki 复制,

var config = {
    isInitiator: true,
    turn: {
        host: 'turn:turn.example.com:3478',
        username: 'test',
        password: '123'
    },
    streams: {
        audio: true,
        video: false
    }
}

var session = new phonertc.Session(config);

我在

上收到错误
var session = new phonertc.Session(config);

在 Chrome 上运行演示时。错误是

main.js:27 Uncaught ReferenceError: phonertc is not defined

index.html完整版本

<!DOCTYPE html>

<html>
    <head>
        <meta name="format-detection" content="telephone=no">
        <meta name="msapplication-tap-highlight" content="no">
        <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
        <link rel="stylesheet" type="text/css" href="css/index.css">
        <title>Hello World</title>
    </head>
    <body>
        <div class="app">
            <h1>Apache Cordova</h1>
            <div id="deviceready" class="blink">
                <p class="event listening">Connecting to Device</p>
                <p class="event received">Device is Ready</p>
            </div>
        </div>
        <script type="text/javascript" src="cordova.js"></script>
        <script type="text/javascript" src="js/index.js"></script>
        <script src="js/socket.io-1.4.5.js"></script>
        <script src="js/main.js"></script>
        <script>
            document.addEventListener('deviceready', function() {
                doAll();
            });
        </script>
    </body>
</html>

index.js 和 cordova.js 是 cordova hello world 的默认值,ma​​in.js

var socket;
var config;
var session;
function doAll(){
    socket;
    function setup(){
        socket = io.connect("http://192.168.1.121:3000");
        socket.emit("add-user", {"userCode": "1"});

    }
    setup();


    config = {
        isInitiator: true,
        turn: {
            host: 'turn:192.168.1.121:3478',
            username: 'aaaa',
            password: 'bbbb'
        },
        streams: {
            audio: true,
            video: false
        }
    }

    session = new phonertc.Session(config);
    session.on('sendMessage', function (data) { 
        socket.emit("private-message",{content:data,userCode:"2"});
    });
    socket.on("add-message", function(data){

            console.log(data.content);
            session.receiveMessage(JSON.parse(data.content));
        });
    session.on('answer', function () { 
        console.log('Other client answered!');
    });

    session.on('disconnect', function () { 
        console.log('Other client disconnected!');
    });
    session.call();
}

我知道,代码很糟糕,但这只是一个演示。 如何解决对phonertc的引用?我需要在index.html中导入一些东西吗? 谢谢

最佳答案

好的,我改了线路

var session = new phonertc.Session(config);

var session = new cordova.plugins.phonertc.Session(config);

现在可以了。

关于javascript - 未定义phonertc - 浏览器上的Cordova Phonertc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38718223/

相关文章:

javascript - 如何通过node.js server-sent-event发送命令行输出并在浏览器中显示它

javascript - 后台验证的谷歌表格API来编辑和读取单元格的格式

javascript - JavaScript 浏览器内编辑器的名称

browser - 如何从 CFC 文件跟踪或记录

html - Opera (11.0) 中的水平滚动条

javascript - 将变量值绑定(bind)到 View 或 html 页面的特定部分/div?

javascript - 莫里斯图表日自定义问题

javascript - if循环不跳转到else

android - E/DroidGap(21383) : DroidGap: TIMEOUT ERROR! - 调用 webViewClient

javascript - 类型错误 : Cannot assign to read only property 'done' of#<Object>