1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
|
/*
* Jitsi, the OpenSource Java VoIP and Instant Messaging client.
*
* Distributable under LGPL license.
* See terms of license at gnu.org.
*/
package net.java.sip.communicator.service.neomedia;
import java.net.*;
import java.util.*;
import java.beans.*;
import net.java.sip.communicator.service.neomedia.device.*;
import net.java.sip.communicator.service.neomedia.format.*;
/**
* The <tt>MediaStream</tt> class represents a (generally) bidirectional RTP
* stream between exactly two parties. The class reflects one media stream, in
* the SDP sense of the word. <tt>MediaStream</tt> instances are created through
* the <tt>openMediaStream()</tt> method of the <tt>MediaService</tt>.
*
* @author Emil Ivov
* @author Lyubomir Marinov
*/
public interface MediaStream
{
/**
* The name of the property which indicates whether the remote SSRC is
* currently available.
*/
public static final String PNAME_LOCAL_SSRC = "localSSRCAvailable";
/**
* The name of the property which indicates whether the local SSRC is
* currently available.
*/
public static final String PNAME_REMOTE_SSRC = "remoteSSRCAvailable";
/**
* Starts capturing media from this stream's <tt>MediaDevice</tt> and then
* streaming it through the local <tt>StreamConnector</tt> toward the
* stream's target address and port. The method also puts the
* <tt>MediaStream</tt> in a listening state that would make it play all
* media received from the <tt>StreamConnector</tt> on the stream's
* <tt>MediaDevice</tt>.
*/
public void start();
/**
* Stops all streaming and capturing in this <tt>MediaStream</tt> and closes
* and releases all open/allocated devices/resources. This method has no
* effect on an already closed stream and is simply ignored.
*/
public void stop();
/**
* Releases the resources allocated by this instance in the course of its
* execution and prepares it to be garbage collected.
*/
public void close();
/**
* Sets the <tt>MediaFormat</tt> that this <tt>MediaStream</tt> should
* transmit in.
*
* @param format the <tt>MediaFormat</tt> that this <tt>MediaStream</tt>
* should transmit in.
*/
public void setFormat(MediaFormat format);
/**
* Returns the <tt>MediaFormat</tt> that this stream is currently
* transmitting in.
*
* @return the <tt>MediaFormat</tt> that this stream is currently
* transmitting in.
*/
public MediaFormat getFormat();
/**
* Sets the <tt>StreamConnector</tt> to be used by this <tt>MediaStream</tt>
* for sending and receiving media.
*
* @param connector the <tt>StreamConnector</tt> to be used by this
* <tt>MediaStream</tt> for sending and receiving media
*/
public void setConnector(StreamConnector connector);
/**
* Sets the device that this stream should use to play back and capture
* media.
*
* @param device the <tt>MediaDevice</tt> that this stream should use to
* play back and capture media.
*/
public void setDevice(MediaDevice device);
/**
* Gets the device that this stream uses to play back and capture media.
*
* @return the <tt>MediaDevice</tt> that this stream uses to play back and
* capture media.
*/
public MediaDevice getDevice();
/**
* Returns the synchronization source (SSRC) identifier of the remote
* participant or <tt>-1</tt> if that identifier is not yet known at this
* point.
*
* @return the synchronization source (SSRC) identifier of the remote
* participant or <tt>-1</tt> if that identifier is not yet known at this
* point.
*/
public long getRemoteSourceID();
/**
* Gets the synchronization source (SSRC) identifiers of the remote peers.
*
* @return the synchronization source (SSRC) identifiers of the remote peers
* @see MediaStream#getRemoteSourceIDs()
*/
public List<Long> getRemoteSourceIDs();
/**
* Returns the synchronization source (SSRC) identifier of the local
* participant or <tt>-1</tt> if that identifier is not yet known at this
* point.
*
* @return the synchronization source (SSRC) identifier of the local
* participant or <tt>-1</tt> if that identifier is not yet known at this
* point.
*/
public long getLocalSourceID();
/**
* Returns the address that this stream is sending RTCP traffic to.
*
* @return an <tt>InetSocketAddress</tt> instance indicating the address
* that we are sending RTCP packets to.
*/
public InetSocketAddress getRemoteControlAddress();
/**
* Returns the address that this stream is sending RTP traffic to.
*
* @return an <tt>InetSocketAddress</tt> instance indicating the address
* that we are sending RTP packets to.
*/
public InetSocketAddress getRemoteDataAddress();
/**
* Returns the transport protocol used by the streams.
*
* @return the transport protocol (UDP or TCP) used by the streams. null if
* the stream connector is not instanciated.
*/
public StreamConnector.Protocol getTransportProtocol();
/**
* Adds a property change listener to this stream so that it would be
* notified upon property change events like for example an SSRC ID which
* becomes known.
*
* @param listener the listener that we'd like to register for
* <tt>PropertyChangeEvent</tt>s
*/
public void addPropertyChangeListener(PropertyChangeListener listener);
/**
* Removes the specified property change <tt>listener</tt> from this stream
* so that it won't receive further property change events.
*
* @param listener the listener that we'd like to remove.
*/
public void removePropertyChangeListener(PropertyChangeListener listener);
/**
* Sets the target of this <tt>MediaStream</tt> to which it is to send and
* from which it is to receive data (e.g. RTP) and control data (e.g. RTCP).
*
* @param target the <tt>MediaStreamTarget</tt> describing the data
* (e.g. RTP) and the control data (e.g. RTCP) locations to which this
* <tt>MediaStream</tt> is to send and from which it is to receive
*/
public void setTarget(MediaStreamTarget target);
/**
* Returns the target of this <tt>MediaStream</tt> to which it is to send
* and from which it is to receive data (e.g. RTP) and control data (e.g.
* RTCP).
*
* @return the <tt>MediaStreamTarget</tt> describing the data
* (e.g. RTP) and the control data (e.g. RTCP) locations to which this
* <tt>MediaStream</tt> is to send and from which it is to receive
* @see MediaStream#setTarget(MediaStreamTarget)
*/
public MediaStreamTarget getTarget();
/**
* Adds a new association in this <tt>MediaStream</tt> of the specified RTP
* payload type with the specified <tt>MediaFormat</tt> in order to allow it
* to report <tt>rtpPayloadType</tt> in RTP flows sending and receiving
* media in <tt>format</tt>. Usually, <tt>rtpPayloadType</tt> will be in the
* range of dynamic RTP payload types.
*
* @param rtpPayloadType the RTP payload type to be associated in this
* <tt>MediaStream</tt> with the specified <tt>MediaFormat</tt>
* @param format the <tt>MediaFormat</tt> to be associated in this
* <tt>MediaStream</tt> with <tt>rtpPayloadType</tt>
*/
public void addDynamicRTPPayloadType(
byte rtpPayloadType,
MediaFormat format);
/**
* Gets the existing associations in this <tt>MediaStream</tt> of RTP
* payload types to <tt>MediaFormat</tt>s. The returned <tt>Map</tt>
* only contains associations previously added in this instance with
* {@link #addDynamicRTPPayloadType(byte, MediaFormat)} and not globally or
* well-known associations reported by
* {@link MediaFormat#getRTPPayloadType()}.
*
* @return a <tt>Map</tt> of RTP payload type expressed as <tt>Byte</tt> to
* <tt>MediaFormat</tt> describing the existing (dynamic) associations in
* this instance of RTP payload types to <tt>MediaFormat</tt>s. The
* <tt>Map</tt> represents a snapshot of the existing associations at the
* time of the <tt>getDynamicRTPPayloadTypes()</tt> method call and
* modifications to it are not reflected on the internal storage
*/
public Map<Byte, MediaFormat> getDynamicRTPPayloadTypes();
/**
* Adds or updates an association in this <tt>MediaStream</tt> mapping the
* specified <tt>extensionID</tt> to <tt>rtpExtension</tt> and enabling or
* disabling its use according to the direction attribute of
* <tt>rtpExtension</tt>.
*
* @param extensionID the ID that is mapped to <tt>rtpExtension</tt> for
* the lifetime of this <tt>MediaStream</tt>.
* @param rtpExtension the <tt>RTPExtension</tt> that we are mapping to
* <tt>extensionID</tt>.
*/
public void addRTPExtension(byte extensionID, RTPExtension rtpExtension);
/**
* Returns a map containing all currently active <tt>RTPExtension</tt>s in
* use by this stream.
*
* @return a map containing all currently active <tt>RTPExtension</tt>s in
* use by this stream.
*/
public Map<Byte, RTPExtension> getActiveRTPExtensions();
/**
* Sets the direction in which media in this <tt>MediaStream</tt> is to be
* streamed. If this <tt>MediaStream</tt> is not currently started, calls to
* {@link #start()} later on will start it only in the specified
* <tt>direction</tt>. If it is currently started in a direction different
* than the specified, directions other than the specified will be stopped.
*
* @param direction the <tt>MediaDirection</tt> in which this
* <tt>MediaStream</tt> is to stream media when it is started
*/
public void setDirection(MediaDirection direction);
/**
* Gets the direction in which this <tt>MediaStream</tt> is allowed to
* stream media.
*
* @return the <tt>MediaDirection</tt> in which this <tt>MediaStream</tt> is
* allowed to stream media
*/
public MediaDirection getDirection();
/**
* Determines whether {@link #start()} has been called on this
* <tt>MediaStream</tt> without {@link #stop()} or {@link #close()}
* afterwards.
*
* @return <tt>true</tt> if {@link #start()} has been called on this
* <tt>MediaStream</tt> without {@link #stop()} or {@link #close()}
* afterwards
*/
public boolean isStarted();
/**
* Causes this <tt>MediaStream</tt> to stop transmitting the media being fed
* from this stream's <tt>MediaDevice</tt> and transmit "silence" instead.
* "Silence" for video is understood as video data which is not the captured
* video data and may represent, for example, a black image.
*
* @param mute <tt>true</tt> if we are to start transmitting "silence" and
* <tt>false</tt> if we are to use media from this stream's
* <tt>MediaDevice</tt> again.
*/
public void setMute(boolean mute);
/**
* Determines whether this <tt>MediaStream</tt> is set to transmit "silence"
* instead of the media being fed from its <tt>MediaDevice</tt>. "Silence"
* for video is understood as video data which is not the captured video
* data and may represent, for example, a black image.
*
* @return <tt>true</tt> if this <tt>MediaStream</tt> is set to transmit
* "silence" instead of the media fed from its <tt>MediaDevice</tt>;
* <tt>false</tt>, otherwise
*/
public boolean isMute();
/**
* Returns the name of this stream or <tt>null</tt> if no name has been
* set. A stream name is used by some protocols, for diagnostic purposes
* mostly. In XMPP for example this is the name of the content element that
* describes a stream.
*
* @return the name of this stream or <tt>null</tt> if no name has been
* set.
*/
public String getName();
/**
* Sets the name of this stream. Stream names are used by some protocols,
* for diagnostic purposes mostly. In XMPP for example this is the name of
* the content element that describes a stream.
*
* @param name the name of this stream or <tt>null</tt> if no name has been
* set.
*/
public void setName(String name);
/**
* The <tt>ZrtpControl</tt> which controls the ZRTP for this stream.
*
* @return the <tt>ZrtpControl</tt> which controls the ZRTP for this stream
*/
public SrtpControl getSrtpControl();
/**
* Sets the <tt>RTPTranslator</tt> which is to forward RTP and RTCP traffic
* between this and other <tt>MediaStream</tt>s.
*
* @param rtpTranslator the <tt>RTPTranslator</tt> which is to forward RTP
* and RTCP traffic between this and other <tt>MediaStream</tt>s
*/
public void setRTPTranslator(RTPTranslator rtpTranslator);
/**
* Returns a MediaStreamStats object used to get statistics about this
* MediaStream.
*
* @return the MediaStreamStats object used to compute the statistics about
* this MediaStream.
*/
public MediaStreamStats getMediaStreamStats();
}
|