diff options
-rw-r--r-- | video/video_decoder.cpp | 25 | ||||
-rw-r--r-- | video/video_decoder.h | 11 |
2 files changed, 36 insertions, 0 deletions
diff --git a/video/video_decoder.cpp b/video/video_decoder.cpp index c6171c4450..dce96aae03 100644 --- a/video/video_decoder.cpp +++ b/video/video_decoder.cpp @@ -778,6 +778,31 @@ void VideoDecoder::setEndTime(const Audio::Timestamp &endTime) { } } +void VideoDecoder::setEndFrame(uint frame) { + VideoTrack *track = 0; + + for (TrackList::iterator it = _tracks.begin(); it != _tracks.end(); it++) { + if ((*it)->getTrackType() == Track::kTrackTypeVideo) { + // We only allow this when one video track is present + if (track) + return; + + track = (VideoTrack *)*it; + } + } + + // If we didn't find a video track, we can't set the final frame (of course) + if (!track) + return; + + Audio::Timestamp time = track->getFrameTime(frame + 1); + + if (time < 0) + return; + + setEndTime(time); +} + VideoDecoder::Track *VideoDecoder::getTrack(uint track) { if (track > _internalTracks.size()) return 0; diff --git a/video/video_decoder.h b/video/video_decoder.h index 2faec0fb3e..c3879e9144 100644 --- a/video/video_decoder.h +++ b/video/video_decoder.h @@ -214,6 +214,17 @@ public: void setEndTime(const Audio::Timestamp &endTime); /** + * Set the end frame. + * + * The passed frame will be the last frame to show. + * + * Like seekToFrame(), this only works when one video track is present, + * and that track supports getFrameTime(). This calls setEndTime() + * internally. + */ + void setEndFrame(uint frame); + + /** * Get the stop time of the video (if not set, zero) */ Audio::Timestamp getEndTime() const { return _endTime; } |