forked from teamnwah/openmw-tes3coop
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
|
* buffer. We use this to store the global_pts in
|
||||||
* a frame at the time it is allocated.
|
* 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)
|
static int our_get_buffer(struct AVCodecContext *c, AVFrame *pic)
|
||||||
{
|
{
|
||||||
int ret = avcodec_default_get_buffer(c, 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;
|
*pts = global_video_pkt_pts;
|
||||||
pic->opaque = pts;
|
pic->opaque = pts;
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -397,10 +397,10 @@ void VideoState::video_thread_loop(VideoState *self)
|
||||||
throw std::runtime_error("Error decoding video frame");
|
throw std::runtime_error("Error decoding video frame");
|
||||||
|
|
||||||
double pts = 0;
|
double pts = 0;
|
||||||
if((uint64_t)packet->dts != AV_NOPTS_VALUE)
|
if(packet->dts != AV_NOPTS_VALUE)
|
||||||
pts = packet->dts;
|
pts = packet->dts;
|
||||||
else if(pFrame->opaque && *(uint64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
else if(pFrame->opaque && *(int64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
||||||
pts = *(uint64_t*)pFrame->opaque;
|
pts = *(int64_t*)pFrame->opaque;
|
||||||
pts *= av_q2d((*self->video_st)->time_base);
|
pts *= av_q2d((*self->video_st)->time_base);
|
||||||
|
|
||||||
av_free_packet(packet);
|
av_free_packet(packet);
|
||||||
|
|
Loading…
Reference in a new issue