2

我正在开发一个具有视频聊天功能的模块。为此,我正在使用 Webrtc。我非常接近做到这一点,但我在打电话时遇到了一个问题。

服务器总是返回

{"params": {"messages": []}, "result": "FULL"}

在此之后,我遇到了另一个问题,例如,

java.lang.UnsatisfiedLinkError: Native method not found: org.webrtc.PeerConnectionFactory.initializeFieldTrials:(Ljava/lang/String;)V

首先,我遇到了 jingle 本机库的问题。我也将它集成到 jni 目录中。还更新了 peerconnection_jni.cc 文件但同样的错误..

我也可以附加 peerconnection_jni.cc 文件(如果需要)。

我也在谷歌上搜索过。但没有得到实际输出。谁能帮帮我吗?

更新 :

这是我的 peerconnection_jni.cc 的代码

extern "C" {
    JNIEXPORT void JNICALL Java_org_webrtc_PeerConnectionFactory_initializeFieldTrials
    (JNIEnv* evn,jclass _class,jstring j_trials_init_string) {
        field_trials_init_string = NULL;
        if (j_trials_init_string != NULL) {
            const char* init_string =
                    jni->GetStringUTFChars(j_trials_init_string, NULL);
            int init_string_length = jni->GetStringUTFLength(j_trials_init_string);
            field_trials_init_string = new char[init_string_length + 1];
            rtc::strcpyn(field_trials_init_string, init_string_length + 1, init_string);
            jni->ReleaseStringUTFChars(j_trials_init_string, init_string);
            LOG(LS_INFO) << "initializeFieldTrials: " << field_trials_init_string;
        }
        webrtc::field_trial::InitFieldTrialsFromString(field_trials_init_string);
    }
}

这是我的 Logcat 输出。

04-06 19:20:57.041: E/AppRTCDemoActivity(26645): Fatal error: Native method not found: org.webrtc.PeerConnectionFactory.initializeFieldTrials:(Ljava/lang/String;)V
04-06 19:20:57.041: E/AppRTCDemoActivity(26645): java.lang.UnsatisfiedLinkError: Native method not found: org.webrtc.PeerConnectionFactory.initializeFieldTrials:(Ljava/lang/String;)V
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at org.webrtc.PeerConnectionFactory.initializeFieldTrials(Native Method)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at org.appspot.apprtc.PeerConnectionClient.createPeerConnectionFactoryInternal(PeerConnectionClient.java:268)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at org.appspot.apprtc.PeerConnectionClient.access$18(PeerConnectionClient.java:257)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at org.appspot.apprtc.PeerConnectionClient$1.run(PeerConnectionClient.java:222)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at android.os.Handler.handleCallback(Handler.java:725)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at android.os.Handler.dispatchMessage(Handler.java:92)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at android.os.Looper.loop(Looper.java:137)
04-06 19:20:57.041: E/AppRTCDemoActivity(26645):    at org.appspot.apprtc.util.LooperExecutor.run(LooperExecutor.java:57)
4

1 回答 1

0

听起来你正在尝试初始化一个对象。
所以,我猜你的方法不是静态的。
您需要第二个参数是调用该方法的对象,而不是对象的类:

JNIEXPORT void JNICALL Java_org_webrtc_PeerConnectionFactory_initializeFieldTrials
    (JNIEnv* evn,    jobject _thiz     ,jstring j_trials_init_string) 
于 2015-05-02T11:42:06.017 回答