WebRTC Android——createPeerConnection()始终返回null

4

我是Android和WebRTC的新手,一直在努力实现网站和我的Android设备之间的P2P视频连接。在两个网站之间已经成功实现了此功能,所以我相信问题出在Android端。

当我尝试使用PeerConnectionFactory.createPeerConnection()创建一个新的PeerConnection对象时,结果总是null。我正在使用WebRTC的M58版本。

PeerConnection.IceServer iceServer = new PeerConnection.IceServer("http://stun.stun.l.google.com:19302/");
List<PeerConnection.IceServer> servers = new ArrayList<PeerConnection.IceServer>();
servers.add(iceServer);

// Media Constraints
final MediaConstraints mediaConstraints = new MediaConstraints();
mediaConstraints.mandatory.add(new MediaConstraints.KeyValuePair("OfferToReceiveAudio", "true"));
mediaConstraints.mandatory.add(new MediaConstraints.KeyValuePair("OfferToReceiveVideo", "true"));
mediaConstraints.optional.add(new MediaConstraints.KeyValuePair("DtlsSrtpKeyAgreement", "true"));

// Set up remote rendering stuff
rootEGLBase = EglBase.create();
svr = (SurfaceViewRenderer) findViewById(R.id.remote_video);
svr.init(rootEGLBase.getEglBaseContext(), null);
svr.setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FIT);
svr.setZOrderMediaOverlay(true);
svr.setEnableHardwareScaler(true);

remoteProxyRenderer.setTarget(svr);
remoteRender = remoteProxyRenderer;

// Create a peer connection factory
PeerConnectionFactory.initializeAndroidGlobals(this.ctx, true);
PeerConnectionFactory.Options options = new PeerConnectionFactory.Options();
options.networkIgnoreMask = 0;

PeerConnectionFactory peerConnectionFactory = new PeerConnectionFactory(options);

// wait until my websocket has connected
System.out.println("waiting for websocket to be inited...");
while (this.ws == null);
System.out.println("done wait");
final WebSocket in_scope_ws = this.ws;

// create peer connection observer
PeerConnection.Observer pcObserver = new PeerConnection.Observer() {/* not included - mostly just prints */};

// Create peerconnection
final PeerConnection peerConnection = peerConnectionFactory.createPeerConnection(servers, mediaConstraints, pcObserver);

这里是从上面代码中删除的PeerConnection.Observer匿名实现。我确定我在这里做了很多其他错误的事情,但我想我应该先解决提供/回答交换的问题。

PeerConnection.Observer pcObserver = new PeerConnection.Observer() {
    final String TAG = "PEER_CONNECTION_FACTORY";

    @Override
    public void onSignalingChange(PeerConnection.SignalingState signalingState) {
        Log.d(TAG, "onSignalingChange");
    }

    @Override
    public void onIceConnectionChange(PeerConnection.IceConnectionState iceConnectionState) {
        Log.d(TAG, "onIceConnectionChange");
    }

    @Override
    public void onIceConnectionReceivingChange(boolean b) {
        Log.d(TAG, "onIceConnectionReceivingChange");
    }

    @Override
    public void onIceGatheringChange(PeerConnection.IceGatheringState iceGatheringState) {
        Log.d(TAG, "onIceGatheringChange");
    }

    // not sure what to put here
    @Override
    public void onIceCandidate(IceCandidate iceCandidate) {
        System.out.println("AN ICE CANDIDATE HAS BEEN DISCOVERED");
        if (iceCandidate != null && in_scope_ws != null) {
            try {
                JSONObject payload = new JSONObject();
                payload.put("sdpMLineIndex", iceCandidate.sdpMLineIndex);
                payload.put("sdpMid", iceCandidate.sdpMid);
                payload.put("candidate", iceCandidate.sdp);
                JSONObject candidateObject = new JSONObject();
                candidateObject.put("ice", iceCandidate.toString());
                in_scope_ws.sendText(candidateObject.toString());
            } catch (JSONException e) {
                e.printStackTrace();
            }
            //send ice candidate to server - probably need to convert to string and put in JSON object
//                    in_scope_ws.send("")
        }
    }

    @Override
    public void onIceCandidatesRemoved(IceCandidate[] iceCandidates) {
        Log.d(TAG, "onIceCandidatesRemoved");
    }

    // pretty sure this is the only garbage I need right now
    @Override
    public void onAddStream(MediaStream mediaStream) {
        System.out.println("IN ADD STREAM");
        if(mediaStream.videoTracks.size()==0) {
            Log.d("onAddStream", "NO REMOTE STREAM");
            System.out.println("NO REMOTE STREAM (PRINTLN)");
        }
        mediaStream.videoTracks.get(0).addRenderer(new VideoRenderer (remoteRender));
//                VideoRendererGui.update(remoteRender, 0, 0, 100, 100, RendererCommon.ScalingType.SCALE_ASPECT_FILL, false);
    }

    @Override
    public void onRemoveStream(MediaStream mediaStream) {
        Log.d(TAG, "onRemoveStream");
    }

    @Override
    public void onDataChannel(DataChannel dataChannel) {
        Log.d(TAG, "onDataChannel");
    }

    @Override
    public void onRenegotiationNeeded() {
        Log.d(TAG, "onRenegotiationNeeded");
    }

    @Override
    public void onAddTrack(RtpReceiver rtpReceiver, MediaStream[] mediaStreams) { Log.d(TAG, "onAddTrack"); }

};
4个回答

2

createPeerConnection() 返回空的另一个问题可能是与 IceServer 的配置错误相关的,确保您设置了正确的 IceServer 和正确的凭据。


1

您可以启用详细日志记录以跟踪问题。

org.webrtc.Logging.enableLogToDebugOutput(Logging.Severity.LS_VERBOSE);

同时确保您已经授予所需的运行时权限(相机,录音)


0

我曾经遇到过同样的问题。peerConnection对象总是返回null。

在我的情况下,其中一个转发服务器的用户名未设置。设置后,peerConnection对象成功创建。

val servers = listOf(
...,    
PeerConnection.IceServer.builder("server_url")
                .setUsername("user_name")
                .setPassword("password")
                .createIceServer()
...

        ) as MutableList<PeerConnection.IceServer>

0

在创建PeerConnection之前,您需要创建LocalMediaStream并设置videoHeight、videoWidth、createVideoSource和createAudioSource。


谢谢!我会尝试的。不过我只需要单向视频,所以我是创建本地媒体流并忽略它呢?还是直接发送并相信对方不会做任何事情呢? - Benjamin Efron

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接