- All Known Subinterfaces:
- LocalParticipant, RemoteParticipant
- public interface Participant
This interface represents one participant in an RTP session.
Within a session, a participant is defined to be the application
sending and receiving data on that session. Note that this doesn't
necessarily imply that participants are human. A single participant
may be the source of zero or more streams of RTP data packets, each
of which is represented by an RTPStream object obtainable via the
RTPSM only creates instances of the two subclasses of this class,
RTPRemoteParticipant and RTPLocalParticipant. Of all the
Participants objects managed by the RTPSessionManager, only one
is the local participant and thus an instance of
All the other Participants in the session (obtainable via
RTPSM.getRemoteParticipants()) are "remote" and are instances of
RTPRemoteParticipant; calls to getStreams() on remote participants
return a Vector of ReceiveStream objects. The client can determine
whether an Participant is local doing a simple "instanceof" test.
Participants are identified by the CNAME string, which is
transmitted in every RTCP packet.Since a participant may begin
sending data packets *before* the CNAME of the participant has
arrived in an RTCP packet, it is possible that a data stream will
exist, for a short time, as "unassociated" with any participant.
See ReceiveStream for more details.
Note that this abstraction defines a participant *within* a
session; in real life, "participants"
can be involved in more than one RTP session at a time.
Provides a quick method to get the CNAME of this participant.
Returns a Vector of RTCPReport objects, each representing the
most recent RTCP report for an SSRC sent by this participant.
Returns a Vector of RTCPSourceDescription objects.
Retrieves a Vector which is the set of all RTPStream objects for
public java.util.Vector getStreams()
- Retrieves a Vector which is the set of all RTPStream objects for
this participant. Note that if the participant is not sending a
stream of RTP packets (i.e. it is a "passive" participant),this
method will return an empty Vector. Note that if this call is
made after data has started coming in from a new SSRC from this
participant, but before an RTCP packet has arrived to map that
SSRC to this participant, that receive stream will not turn up
in this call; when and if said RTCP packet arrives and the orphan
stream can be associated with an Participant, the
recvStreamMapped callback will be issued to all RTPSessionListeners.
If this is the local participant, the returned Vector will
contain null. if it is a remote participant it
will contain ReceiveStream objects.
- the Vector of RTPStream objects.
public java.util.Vector getReports()
- Returns a Vector of RTCPReport objects, each representing the
most recent RTCP report for an SSRC sent by this participant. In
most cases, this Vector will contain exactly one report, be it an
SR or RR, because most participants (passive receivers and
single-stream senders) only send out one SSRC. The exceptions are
those participants sending multiple data streams, in which case
there will be one report per stream (i.e. per SSRC); these reports
would also be accessible via the getReport() call on each
public java.lang.String getCNAME()
- Provides a quick method to get the CNAME of this participant.
This value can also be obtained from the RTCPReport objects
returned through getReports() on this participant.
- the CNAME identifying this participant.
public java.util.Vector getSourceDescription()
- Returns a Vector of RTCPSourceDescription objects. Each such
object is one field from the most recent RTCP SDES packet for
this participant. Since typically the most recent SDES packet
will not contain all of the RTCPSourceDescription objects
simultaneously, the returned Vector contains the most recent SDES type
received from this participant, possibly from many RTCP
reports. (Each of the returned SDES types therefore may not be
from the latest RTCP report necessarliy). A convenient method
to get at the source description without having to go through
calling getReports(), enumerating the Vector, and then
calling getSourceDescription() on the RTCPReport.
- the Vector representing the latest SDES report from this
participant. May be an empty Vector.
Submit a bug or feature
Copyright 1999-2000 Sun Microsystems, Inc. 901 San Antonio Road, Palo Alto, California, 94303, U.S.A. All Rights Reserved. See the Specification License for more details.
Sun, Sun Microsystems, and Java are trademarks or registered trademarks of Sun Microsystems, Inc. in the US and other countries.