forked from mirror/openmw-tes3mp
Warning fix
This commit is contained in:
parent
e58f2b98ec
commit
472165097d
1 changed files with 5 additions and 5 deletions
10
extern/ogre-ffmpeg-videoplayer/videostate.cpp
vendored
10
extern/ogre-ffmpeg-videoplayer/videostate.cpp
vendored
|
@ -346,11 +346,11 @@ double VideoState::synchronize_video(AVFrame *src_frame, double pts)
|
|||
* buffer. We use this to store the global_pts in
|
||||
* a frame at the time it is allocated.
|
||||
*/
|
||||
static uint64_t global_video_pkt_pts = static_cast<uint64_t>(AV_NOPTS_VALUE);
|
||||
static int64_t global_video_pkt_pts = AV_NOPTS_VALUE;
|
||||
static int our_get_buffer(struct AVCodecContext *c, AVFrame *pic)
|
||||
{
|
||||
int ret = avcodec_default_get_buffer(c, pic);
|
||||
uint64_t *pts = (uint64_t*)av_malloc(sizeof(uint64_t));
|
||||
int64_t *pts = (int64_t*)av_malloc(sizeof(int64_t));
|
||||
*pts = global_video_pkt_pts;
|
||||
pic->opaque = pts;
|
||||
return ret;
|
||||
|
@ -397,10 +397,10 @@ void VideoState::video_thread_loop(VideoState *self)
|
|||
throw std::runtime_error("Error decoding video frame");
|
||||
|
||||
double pts = 0;
|
||||
if((uint64_t)packet->dts != AV_NOPTS_VALUE)
|
||||
if(packet->dts != AV_NOPTS_VALUE)
|
||||
pts = packet->dts;
|
||||
else if(pFrame->opaque && *(uint64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
||||
pts = *(uint64_t*)pFrame->opaque;
|
||||
else if(pFrame->opaque && *(int64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
||||
pts = *(int64_t*)pFrame->opaque;
|
||||
pts *= av_q2d((*self->video_st)->time_base);
|
||||
|
||||
av_free_packet(packet);
|
||||
|
|
Loading…
Reference in a new issue