packet= 1 fps= 25.0 dts= 21600 pts= 21600 duration= 3600, stream_index= 0
Error: [flv @ 0000000021dc8b80] Application provided invalid, non monotonically increasing dts to muxer in stream 0: 240 >= 40
packet= 2 fps= 25.0 dts= 3600 pts= 3600 duration= 3600, stream_index= 0
org.bytedeco.javacv.FrameRecorder$Exception: av_write_frame() error -22 while writing video packet.
at com.lin.FFmpegFrameRecorderPlus.writePacket(FFmpegFrameRecorderPlus.java:1194)
at com.lin.FFmpegFrameRecorderPlus.recordPacket(FFmpegFrameRecorderPlus.java:1223)
at com.lin.FFmpegTask.remuxing(FFmpegTask.java:192)
at com.lin.FFmpegTask.start(FFmpegTask.java:88)
at com.lin.FFmpegTask.lambda$startAsync$0(FFmpegTask.java:49)
分析发现未重新设置dts和pts之前,packet 1 dts=pts = 21600,packet 2 dts=pts = 3600
重新设置pts和dts之后,packet1 dts=pts=240 packet2 dts=pts=40
此时第一个包的dts大于第二个包的pts就会报错,猜测是因为ffmpeg探测数据时遗留下的帧,所以先将缓存中的包flush掉,然后在读取即可
grabber.flush();
while(true) {
pkt = grabber.grabPacket();
}