Merge pull request #7 from aginetwork7/fix/playback-skip-frame
Fix playback skip frame
This commit is contained in:
commit
2bd551c919
@ -337,18 +337,25 @@ func (client *RTSPClient) appendPlaybackVideoPacket(retmap []*av.Packet, nal []b
|
|||||||
|
|
||||||
if prePkt[i].IsKeyFrame {
|
if prePkt[i].IsKeyFrame {
|
||||||
if prePkt[i].RealTs == client.preRealVideoMs/1000 {
|
if prePkt[i].RealTs == client.preRealVideoMs/1000 {
|
||||||
client.iterateDruation += prePkt[i].Duration
|
prePkt[i].RealTimestamp = client.preKeyRealVideoTs*1000 + client.iterateDruation.Milliseconds()
|
||||||
} else {
|
} else {
|
||||||
client.iterateDruation = 0
|
|
||||||
client.preKeyRealVideoTs = prePkt[i].RealTs
|
client.preKeyRealVideoTs = prePkt[i].RealTs
|
||||||
|
prePkt[i].RealTimestamp = client.preKeyRealVideoTs * 1000
|
||||||
|
client.iterateDruation = 0
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
client.iterateDruation += prePkt[i].Duration
|
prePkt[i].RealTimestamp = client.preKeyRealVideoTs*1000 + client.iterateDruation.Milliseconds()
|
||||||
}
|
}
|
||||||
|
client.iterateDruation += prePkt[i].Duration
|
||||||
prePkt[i].RealTimestamp = client.preKeyRealVideoTs*1000 + client.iterateDruation.Milliseconds()
|
|
||||||
client.preRealVideoMs = prePkt[i].RealTimestamp
|
client.preRealVideoMs = prePkt[i].RealTimestamp
|
||||||
// fmt.Println("playback duration", prePkt[i].IsKeyFrame, prePkt[i].RealTs, client.preRealVideoMs, prePkt[i].Duration, client.iterateDruation)
|
// fmt.Println("playback duration",
|
||||||
|
// prePkt[i].IsKeyFrame,
|
||||||
|
// prePkt[i].Time.Milliseconds(),
|
||||||
|
// curPkt.Time.Milliseconds(),
|
||||||
|
// prePkt[i].RealTs,
|
||||||
|
// prePkt[i].RealTimestamp,
|
||||||
|
// prePkt[i].Duration,
|
||||||
|
// client.iterateDruation)
|
||||||
}
|
}
|
||||||
return prePkt
|
return prePkt
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user