RTCPeerConnection
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.
* Some parts of this feature may have varying levels of support.
La interfaz RTCPeerConnection
representa una conexión WebRTC entre la computadora local y un par remoto. Proporciona métodos para conectarse a un par remoto, mantener y monitorear la conexión y cerrar la conexión una vez que ya no se necesita.
Constructor
RTCPeerConnection()
-
Devuelve un
RTCPeerConnection
recién creado, que representa una conexión entre el dispositivo local y un par remoto.
Propiedades de instancia
También hereda propiedades de EventTarget
.
canTrickleIceCandidates
Read only-
Devuelve un valor booleano que indica si el par remoto puede aceptar o no candidatos trickled ICE.
connectionState
Read only-
Indica el estado actual de la conexión entre pares devolviendo una de las cadenas
new
,connecting
,connected
,disconnected
,failed
oclosed
. currentLocalDescription
Read only-
Devuelve un objeto
RTCSessionDescription
que describe el extremo local de la conexión tal como se negoció con éxito más recientemente desde la última vez que estaRTCPeerConnection
terminó de negociar y conectarse a un par remoto. También se incluye una lista de los candidatos de ICE que ya puede haber generado el agente de ICE desde que se instanciaron por primera vez la oferta o respuesta representada por la descripción. currentRemoteDescription
Read only-
Devuelve un objeto
RTCSessionDescription
que describe el extremo remoto de la conexión tal como se negoció con éxito más recientemente desde la última vez queRTCPeerConnection
terminó de negociar y conectarse a un par remoto. También se incluye una lista de los candidatos de ICE que ya puede haber generado el agente de ICE desde que se instanciaron por primera vez la oferta o respuesta representada por la descripción. iceConnectionState
Read only-
Devuelve una cadena cuyo estado del agente ICE asociado con este RTCPeerConnection. Puede ser uno de los siguientes valores:
new
,checking
,connected
,completed
,failed
,disconnected
oclosed
. iceGatheringState
Read only-
Devuelve una cadena que describe el estado de recopilación de ICE de la conexión. Esto le permite detectar, por ejemplo, cuándo finalizó la recopilación de candidatos de ICE. Los valores posibles son:
new
,gathering
ocomplete
. localDescription
Read only-
Devuelve un
RTCSessionDescription
que describe la sesión para el extremo local de la conexión. Si aún no se ha configurado, devuelvenull
. peerIdentity
Read only.-
Devuelve una
Promesa
que se resuelve en unRTCIdentityAssertion
que contiene una cadena que identifica al par remoto. Una vez que esta promesa se resuelve con éxito, la identidad resultante es la identidad del par de destino y no cambiará durante la duración de la conexión. pendingLocalDescription
Read only-
Devuelve un objeto
RTCSessionDescription
que describe un cambio de configuración pendiente para el extremo local de la conexión. Esto no describe la conexión tal como está actualmente, sino como puede existir en un futuro próximo. pendingRemoteDescription
Read only-
Devuelve un objeto
RTCSessionDescription
que describe un cambio de configuración pendiente para el extremo remoto de la conexión. Esto no describe la conexión tal como está actualmente, sino como puede existir en un futuro próximo. remoteDescription
Read only-
Devuelve un objeto
RTCSessionDescription
que describe la sesión, incluida la configuración y la información multimedia, para el extremo remoto de la conexión. Si aún no se ha establecido, devuelvenull
. sctp
Read only-
Devuelve un objeto
RTCSctpTransport
que describe la capa de transporte SCTP sobre la que se envían y reciben los datos SCTP. Si no se ha negociado SCTP, este valor esnull
. signalingState
Read only-
Devuelve una cadena que describe el estado del proceso de señalización en el extremo local de la conexión mientras se conecta o se vuelve a conectar a otro par. Es uno de los siguientes valores:
stable
,have-local-offer
,have-remote-offer
,have-local-pranswer
,have-remote-pranswer
oclosed
.
Métodos estáticos
generateCertificate()
-
Crea un certificado X.509 y su clave privada correspondiente, devolviendo una
Promesa
que se resuelve con el nuevoRTCCertificate
una vez que se genera.
Métodos de instancia
También hereda métodos de EventTarget
.
addIceCandidate()
-
Agrega un nuevo candidato remoto a la descripción remota de
RTCPeerConnection
, que describe el estado del extremo remoto de la conexión. addTrack()
-
Agrega un nuevo
MediaStreamTrack
al conjunto de pistas que se transmitirán al otro par. addTransceiver()
-
Crea un nuevo
RTCRtpTransceiver
y lo agrega al conjunto de transceptores asociados con la conexión. Cada transceptor representa un flujo bidireccional, conRTCRtpSender
yRTCRtpReceiver
asociados con él. close()
-
Cierra la conexión de pares actual.
createAnswer()
-
Inicia la creación de una respuesta SDP a una oferta recibida de un par remoto durante la negociación de oferta/respuesta de una conexión WebRTC. La respuesta contiene información sobre cualquier medio ya adjunto a la sesión, códecs y opciones compatibles con el navegador, y cualquier candidato ICE ya recopilado.
createDataChannel()
-
Inicia la creación de un nuevo canal vinculado con el par remoto, sobre el cual se puede transmitir cualquier tipo de datos. Esto puede ser útil para contenido de canal secundario, como imágenes, transferencia de archivos, chat de texto, paquetes de actualización de juegos, etc.
createOffer()
-
Inicia la creación de una oferta de SDP con el fin de iniciar una nueva conexión WebRTC a un interlocutor remoto. La oferta de SDP incluye información sobre cualquier objeto
MediaStreamTrack
ya adjunto a la sesión, el códec y las opciones de WebRTC admitidos por el navegador, así como cualquier candidato ya recopilado por el agente ICE, con el fin de ser enviado por el canal de señalización a un posible par para solicitar una conexión o actualizar la configuración de una conexión existente. getConfiguration()
-
Devuelve un objeto que indica la configuración actual de la conexión.
getIdentityAssertion()
-
Inicia la recopilación de una afirmación de identidad y devuelve una
Promesa
que se resuelve en una afirmación de identidad codificada como una cadena. Esto tiene efecto solo sisignalingState
no esclosed
. getReceivers()
-
Devuelve un arreglo de objetos
RTCRtpReceiver
, cada uno de los cuales representa un receptor RTP. getSenders()
-
Devuelve un arrreglo de objetos
RTCRtpSender
, cada uno de los cuales representa el remitente RTP responsable de transmitir los datos de una pista. getStats()
-
Devuelve una
Promesa
que se resuelve con datos que proporcionan estadísticas sobre la conexión general o sobre elMediaStreamTrack
especificado. getTransceivers()
-
Devuelve una lista de todos los objetos
RTCRtpTransceiver
que se utilizan para enviar y recibir datos en la conexión. removeTrack()
-
Le dice al extremo local de la conexión que deje de enviar medios desde la pista especificada, sin eliminar realmente el
RTCRtpSender
correspondiente de la lista de remitentes según lo informado porgetSenders()
. Si la pista ya está detenida o no está en la lista de remitentes de la conexión, este método no tiene efecto. restartIce()
-
Permite solicitar fácilmente que la recopilación de candidatos ICE se rehaga en ambos extremos de la conexión. Esto simplifica el proceso al permitir que la persona que llama o el receptor utilicen el mismo método para activar un reinicio ICE.
setConfiguration()
-
Establece la configuración actual de la conexión en función de los valores incluidos en el objeto especificado. Esto le permite cambiar los servidores ICE utilizados por la conexión y qué políticas de transporte utilizar.
setIdentityProvider()
-
Establece el proveedor de identidad (IdP) en el triplete dado en el parámetro: su nombre, el protocolo utilizado para comunicarse con él y un nombre de usuario. El protocolo y el nombre de usuario son opcionales.
setLocalDescription()
-
Cambia la descripción local asociada con la conexión. Esta descripción especifica las propiedades del extremo local de la conexión, incluido el formato de medios. Devuelve una
Promesa
que se cumple una vez que se ha cambiado la descripción, de forma asíncrona. setRemoteDescription()
-
Establece la descripción de la sesión especificada como la oferta o respuesta actual del interlocutor remoto. La descripción especifica las propiedades del extremo remoto de la conexión, incluido el formato de medios. Devuelve una
Promesa
que se cumple una vez que se ha cambiado la descripción, de forma asíncrona.
Métodos obsoletos
addStream()
Obsoleto No estándar-
Agrega un
MediaStream
como fuente local de audio o video. En lugar de usar este método obsoleto, debe usaraddTrack()
una vez por cada pista que desee enviar al interlocutor remoto. createDTMFSender()
Obsoleto-
Crea un nuevo
RTCDTMFSender
, asociado a unMediaStreamTrack
específico, que podrá enviar señalización telefónica DTMF a través de la conexión . removeStream()
Obsoleto No estándar-
Elimina un
MediaStream
como fuente local de audio o video. Debido a que este método está obsoleto, en su lugar debe usarremoveTrack()
.
Eventos
Detecte estos eventos usando addEventListener()
o asignando un detector de eventos a la propiedad oneventname
de esta interfaz.
connectionstatechange
-
Enviado cuando cambia el estado general de conectividad de
RTCPeerConnection
. datachannel
-
Enviado cuando el par remoto agrega un
RTCDataChannel
a la conexión. icecandidate
-
Enviado para solicitar que el candidato especificado se transmita al par remoto.
icecandidateerror
-
Enviado a la conexión si se produjo un error durante la recopilación de candidatos ICE. El evento describe el error.
iceconnectionstatechange
-
Se envía cuando cambia el estado de la conexión ICE, como cuando se desconecta.
icegatheringstatechange
-
Se envía cuando cambia el estado de recopilación de la capa ICE, reflejado por
iceGatheringState
. Esto indica si la negociación de ICE aún no ha comenzado (new
), ha comenzado a reunir candidatos (gathering
) o ha finalizado (complete
). negotiationneeded
-
Enviado cuando es necesario realizar la negociación o renegociación de la conexión ICE; esto puede suceder tanto cuando se abre una conexión por primera vez como cuando es necesario adaptarse a las condiciones cambiantes de la red. El receptor debe responder creando una oferta y enviándola al otro par.
signalingstatechange
-
Se envía cuando cambia el estado de señalización del ICE de la conexión.
track
-
Enviado después de que se haya agregado una nueva pista a una de las instancias
RTCRtpReceiver
que componen la conexión.
Eventos obsoletos
addstream
Obsoleto No estándar-
Enviado cuando se agrega un nuevo
MediaStream
a la conexión. En lugar de detectar este evento obsoleto, debe detectar los eventostrack
; se envía uno por cadaMediaStreamTrack
agregado a la conexión. removestream
Obsoleto No estándar-
Enviado cuando se elimina un
MediaStream
de la conexión. En lugar de detectar este evento obsoleto, debe detectar los eventosremovetrack
en cada transmisión.
Especificaciones
Specification |
---|
WebRTC: Real-Time Communication in Browsers # interface-definition |
Compatibilidad con navegadores
BCD tables only load in the browser
Véase también
- https://github.com/jesup/nightly-gupshup/blob/master/static/js/chat.js
- Comience con WebRTC
- TutorRoom: Captura de video HTML Node.js, aplicación de intercambio de archivos y video entre pares (fuente en GitHub)