本文整理匯總了Java中org.red5.server.net.rtmp.event.Ping類的典型用法代碼示例。如果您正苦於以下問題:Java Ping類的具體用法?Java Ping怎麽用?Java Ping使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Ping類屬於org.red5.server.net.rtmp.event包,在下文中一共展示了Ping類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: sendReset
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Send reset message
*/
private void sendReset() {
if (pullMode) {
Ping recorded = new Ping();
recorded.setEventType(Ping.RECORDED_STREAM);
recorded.setValue2(streamId);
// recorded
RTMPMessage recordedMsg = RTMPMessage.build(recorded);
doPushMessage(recordedMsg);
}
Ping begin = new Ping();
begin.setEventType(Ping.STREAM_BEGIN);
begin.setValue2(streamId);
// begin
RTMPMessage beginMsg = RTMPMessage.build(begin);
doPushMessage(beginMsg);
// reset
ResetMessage reset = new ResetMessage();
doPushMessage(reset);
}
示例2: ping
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/** {@inheritDoc} */
public void ping() {
long newPingTime = System.currentTimeMillis();
if (log.isDebugEnabled()) {
log.debug("Send Ping: session=[{}], currentTime=[{}], lastPingTime=[{}]", new Object[] { getSessionId(), newPingTime, lastPingSentOn.get() });
}
if (lastPingSentOn.get() == 0) {
lastPongReceivedOn.set(newPingTime);
}
Ping pingRequest = new Ping();
pingRequest.setEventType(Ping.PING_CLIENT);
lastPingSentOn.set(newPingTime);
int now = (int) (newPingTime & 0xffffffffL);
pingRequest.setValue2(now);
ping(pingRequest);
}
示例3: pingReceived
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Marks that ping back was received.
*
* @param pong
* Ping object
*/
public void pingReceived(Ping pong) {
long now = System.currentTimeMillis();
long previousPingTime = lastPingSentOn.get();
int previousPingValue = (int) (previousPingTime & 0xffffffffL);
int pongValue = pong.getValue2().intValue();
if (log.isDebugEnabled()) {
log.debug("Pong received: session=[{}] at {} with value {}, previous received at {}", new Object[] { getSessionId(), now, pongValue, previousPingValue });
}
if (pongValue == previousPingValue) {
lastPingRoundTripTime.set((int) ((now - previousPingTime) & 0xffffffffL));
if (log.isDebugEnabled()) {
log.debug("Ping response session=[{}], RTT=[{} ms]", new Object[] { getSessionId(), lastPingRoundTripTime.get() });
}
} else {
// don't log the congestion entry unless there are more than X messages waiting
if (getPendingMessages() > 4) {
int pingRtt = (int) ((now & 0xffffffffL)) - pongValue;
log.info("Pong delayed: session=[{}], ping response took [{} ms] to arrive. Connection may be congested, or loopback", new Object[] { getSessionId(), pingRtt });
}
}
lastPongReceivedOn.set(now);
}
示例4: play
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
@Override
public void play(Number streamId, String name, int start, int length) {
log.debug("play stream {}, name: {}, start {}, length {}", new Object[] { streamId, name, start, length });
if (conn != null) {
// get the channel
int channel = getChannelForStreamId(streamId);
// send our requested buffer size
ping(Ping.CLIENT_BUFFER, streamId, 2000);
// send our request for a/v
PendingCall receiveAudioCall = new PendingCall("receiveAudio");
conn.invoke(receiveAudioCall, channel);
PendingCall receiveVideoCall = new PendingCall("receiveVideo");
conn.invoke(receiveVideoCall, channel);
// call play
Object[] params = new Object[3];
params[0] = name;
params[1] = (start >= 1000 || start <= -1000) ? start : start * 1000;
params[2] = (length >= 1000 || length <= -1000) ? length : length * 1000;
PendingCall pendingCall = new PendingCall("play", params);
conn.invoke(pendingCall, channel);
} else {
log.info("Connection was null ?");
}
}
示例5: sendReset
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Send reset message
*/
private void sendReset() {
if (pullMode) {
Ping recorded = new Ping();
recorded.setEventType(Ping.RECORDED_STREAM);
recorded.setValue2(streamId);
// recorded
RTMPMessage recordedMsg = RTMPMessage.build(recorded);
doPushMessage(recordedMsg);
}
Ping begin = new Ping();
begin.setEventType(Ping.STREAM_BEGIN);
begin.setValue2(streamId);
// begin
RTMPMessage beginMsg = RTMPMessage.build(begin);
doPushMessage(beginMsg);
// reset
ResetMessage reset = new ResetMessage();
doPushMessage(reset);
}
示例6: sendClearPing
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Send clear ping. Lets client know that stream has no more data to send.
*/
private void sendClearPing() {
Ping eof = new Ping();
eof.setEventType(Ping.STREAM_PLAYBUFFER_CLEAR);
eof.setValue2(streamId);
// eos
RTMPMessage eofMsg = RTMPMessage.build(eof);
doPushMessage(eofMsg);
}
示例7: onPing
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/** {@inheritDoc} */
@Override
protected void onPing(RTMPConnection conn, Channel channel, Header source, Ping ping) {
switch (ping.getEventType()) {
case Ping.CLIENT_BUFFER:
SetBuffer setBuffer = (SetBuffer) ping;
// get the stream id
int streamId = setBuffer.getStreamId();
// get requested buffer size in milliseconds
int buffer = setBuffer.getBufferLength();
log.debug("Client sent a buffer size: {} ms for stream id: {}", buffer, streamId);
IClientStream stream = null;
if (streamId != 0) {
// The client wants to set the buffer time
stream = conn.getStreamById(streamId);
if (stream != null) {
stream.setClientBufferDuration(buffer);
log.trace("Stream type: {}", stream.getClass().getName());
}
}
//catch-all to make sure buffer size is set
if (stream == null) {
// Remember buffer time until stream is created
conn.rememberStreamBufferDuration(streamId, buffer);
log.debug("Remembering client buffer on stream: {}", buffer);
}
break;
case Ping.PONG_SERVER:
// This is the response to an IConnection.ping request
conn.pingReceived(ping);
break;
default:
log.warn("Unhandled ping: {}", ping);
}
}
示例8: resultReceived
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
@Override
public void resultReceived(IPendingServiceCall call) {
Number streamId = (Number) call.getResult();
// live buffer 0.5s / vod buffer 4s
if (Boolean.valueOf(PropertiesReader.getProperty("live"))) {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 500));
play(streamId, PropertiesReader.getProperty("name"), -1, -1);
} else {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 4000));
play(streamId, PropertiesReader.getProperty("name"), 0, -1);
}
}
示例9: resultReceived
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
@Override
public void resultReceived(IPendingServiceCall call) {
int streamId = (Integer) call.getResult();
// live buffer 0.5s / vod buffer 4s
if (Boolean.valueOf(PropertiesReader.getProperty("rtmpts.live"))) {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 500));
play(streamId, PropertiesReader.getProperty("rtmpts.name"), -1, -1);
} else {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 4000));
play(streamId, PropertiesReader.getProperty("rtmpts.name"), 0, -1);
}
}
示例10: resultReceived
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
@Override
public void resultReceived(IPendingServiceCall call) {
int streamId = (Integer) call.getResult();
// live buffer 0.5s / vod buffer 4s
if (Boolean.valueOf(PropertiesReader.getProperty("rtmpt.live"))) {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 500));
play(streamId, PropertiesReader.getProperty("rtmpt.name"), -1, -1);
} else {
conn.ping(new Ping(Ping.CLIENT_BUFFER, streamId, 4000));
play(streamId, PropertiesReader.getProperty("rtmpt.name"), 0, -1);
}
}
示例11: sendClearPing
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Send clear ping. Lets client know that stream has no more data to
* send.
*/
private void sendClearPing() {
Ping eof = new Ping();
eof.setEventType(Ping.STREAM_PLAYBUFFER_CLEAR);
eof.setValue2(streamId);
// eos
RTMPMessage eofMsg = RTMPMessage.build(eof);
doPushMessage(eofMsg);
}
示例12: ping
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/** {@inheritDoc} */
public void ping() {
long newPingTime = System.currentTimeMillis();
log.debug("Pinging client with id {} at {}, last ping sent at {}", new Object[] { getId(), newPingTime, lastPingSent.get() });
if (lastPingSent.get() == 0) {
lastPongReceived.set(newPingTime);
}
Ping pingRequest = new Ping();
pingRequest.setEventType(Ping.PING_CLIENT);
lastPingSent.set(newPingTime);
int now = (int) (newPingTime & 0xffffffff);
pingRequest.setValue2(now);
ping(pingRequest);
}
示例13: pingReceived
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/**
* Marks that ping back was received.
*
* @param pong
* Ping object
*/
public void pingReceived(Ping pong) {
long now = System.currentTimeMillis();
long previousReceived = (int) (lastPingSent.get() & 0xffffffff);
log.debug("Pong from client id {} at {} with value {}, previous received at {}", new Object[] { getId(), now, pong.getValue2(), previousReceived });
if (pong.getValue2() == previousReceived) {
lastPingTime.set((int) (now & 0xffffffff) - pong.getValue2());
}
lastPongReceived.set(now);
}
示例14: onPing
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/** {@inheritDoc} */
@Override
protected void onPing(RTMPConnection conn, Channel channel, Header source, Ping ping) {
switch (ping.getEventType()) {
case Ping.CLIENT_BUFFER:
SetBuffer setBuffer = (SetBuffer) ping;
// get the stream id
int streamId = setBuffer.getStreamId();
// get requested buffer size in milliseconds
int buffer = setBuffer.getBufferLength();
log.debug("Client sent a buffer size: {} ms for stream id: {}", buffer, streamId);
IClientStream stream = null;
if (streamId != 0) {
// The client wants to set the buffer time
stream = conn.getStreamById(streamId);
if (stream != null) {
stream.setClientBufferDuration(buffer);
log.trace("Stream type: {}", stream.getClass().getName());
}
}
//catch-all to make sure buffer size is set
if (stream == null) {
// Remember buffer time until stream is created
conn.rememberStreamBufferDuration(streamId, buffer);
log.info("Remembering client buffer on stream: {}", buffer);
}
break;
case Ping.PONG_SERVER:
// This is the response to an IConnection.ping request
conn.pingReceived(ping);
break;
default:
log.warn("Unhandled ping: {}", ping);
}
}
示例15: encodePing
import org.red5.server.net.rtmp.event.Ping; //導入依賴的package包/類
/** {@inheritDoc} */
public IoBuffer encodePing(Ping ping) {
int len;
short type = ping.getEventType();
switch (type) {
case Ping.CLIENT_BUFFER:
len = 10;
break;
case Ping.PONG_SWF_VERIFY:
len = 44;
break;
default:
len = 6;
}
final IoBuffer out = IoBuffer.allocate(len);
out.putShort(type);
switch (type) {
case Ping.STREAM_BEGIN:
case Ping.STREAM_PLAYBUFFER_CLEAR:
case Ping.STREAM_DRY:
case Ping.RECORDED_STREAM:
case Ping.PING_CLIENT:
case Ping.PONG_SERVER:
case Ping.BUFFER_EMPTY:
case Ping.BUFFER_FULL:
out.putInt(ping.getValue2().intValue());
break;
case Ping.CLIENT_BUFFER:
if (ping instanceof SetBuffer) {
SetBuffer setBuffer = (SetBuffer) ping;
out.putInt(setBuffer.getStreamId());
out.putInt(setBuffer.getBufferLength());
} else {
out.putInt(ping.getValue2().intValue());
out.putInt(ping.getValue3());
}
break;
case Ping.PING_SWF_VERIFY:
break;
case Ping.PONG_SWF_VERIFY:
out.put(((SWFResponse) ping).getBytes());
break;
}
// this may not be needed anymore
if (ping.getValue4() != Ping.UNDEFINED) {
out.putInt(ping.getValue4());
}
return out;
}