summaryrefslogtreecommitdiff
path: root/src/lib/frame_rate_change.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-05-03 11:17:34 +0200
committerCarl Hetherington <cth@carlh.net>2021-05-03 20:18:04 +0200
commit689fa55d1529ad88449ca464e9107c4dcc54d1cb (patch)
treeedd1264941263f2fa25a98d61f98c87876c5b667 /src/lib/frame_rate_change.cc
parent0aabe4060ea4bad7c7caac633aef0737fccff8c2 (diff)
C++11 tidying.
Diffstat (limited to 'src/lib/frame_rate_change.cc')
-rw-r--r--src/lib/frame_rate_change.cc47
1 files changed, 18 insertions, 29 deletions
diff --git a/src/lib/frame_rate_change.cc b/src/lib/frame_rate_change.cc
index 7b6d13892..a1ff2ae65 100644
--- a/src/lib/frame_rate_change.cc
+++ b/src/lib/frame_rate_change.cc
@@ -1,5 +1,5 @@
/*
- Copyright (C) 2012-2016 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
@@ -18,6 +18,7 @@
*/
+
#include "frame_rate_change.h"
#include "types.h"
#include "content.h"
@@ -27,46 +28,28 @@
#include "i18n.h"
+
using std::string;
using std::shared_ptr;
-static bool
-about_equal (double a, double b)
-{
- return (fabs (a - b) < VIDEO_FRAME_RATE_EPSILON);
-}
FrameRateChange::FrameRateChange ()
- : source (24)
- , dcp (24)
- , skip (false)
- , repeat (1)
- , change_speed (false)
- , speed_up (1)
{
}
-FrameRateChange::FrameRateChange (double source_, int dcp_)
- : skip (false)
- , repeat (1)
- , change_speed (false)
-{
- construct (source_, dcp_);
-}
-void
-FrameRateChange::construct (double source_, int dcp_)
+FrameRateChange::FrameRateChange (double source_, int dcp_)
{
source = source_;
dcp = dcp_;
- if (fabs (source / 2.0 - dcp) < fabs (source - dcp)) {
+ if (fabs(source / 2.0 - dcp) < fabs(source - dcp)) {
/* The difference between source and DCP frame rate will be lower
(i.e. better) if we skip.
*/
skip = true;
- } else if (fabs (source * 2 - dcp) < fabs (source - dcp)) {
+ } else if (fabs(source * 2 - dcp) < fabs(source - dcp)) {
/* The difference between source and DCP frame rate would be better
if we repeated each frame once; it may be better still if we
repeated more than once. Work out the required repeat.
@@ -75,23 +58,29 @@ FrameRateChange::construct (double source_, int dcp_)
}
speed_up = dcp / (source * factor());
+
+ auto about_equal = [](double a, double b) {
+ return (fabs (a - b) < VIDEO_FRAME_RATE_EPSILON);
+ };
+
change_speed = !about_equal (speed_up, 1.0);
}
+
FrameRateChange::FrameRateChange (shared_ptr<const Film> film, shared_ptr<const Content> content)
- : skip (false)
- , repeat (1)
+ : FrameRateChange (content->active_video_frame_rate(film), film->video_frame_rate())
{
- construct (content->active_video_frame_rate(film), film->video_frame_rate());
+
}
+
FrameRateChange::FrameRateChange (shared_ptr<const Film> film, Content const * content)
- : skip (false)
- , repeat (1)
+ : FrameRateChange (content->active_video_frame_rate(film), film->video_frame_rate())
{
- construct (content->active_video_frame_rate(film), film->video_frame_rate());
+
}
+
string
FrameRateChange::description () const
{