From 5eafd409586663b63fc6f18e8cba4cbc87e0a3bb Mon Sep 17 00:00:00 2001 From: Peter Targett <131255921+peter-targett@users.noreply.github.com> Date: Thu, 5 Dec 2024 18:09:00 +0000 Subject: [PATCH] Add effect and marker initialization to Clip (#1808) * Add effect and marker initialization to Clip Extend Clip to allow effects and markers to be set. Signed-off-by: Peter Targett --------- Signed-off-by: Peter Targett --- src/opentimelineio/clip.cpp | 4 ++- src/opentimelineio/clip.h | 2 ++ .../otio_serializableObjects.cpp | 9 ++++- .../opentimelineio/schema/clip.py | 12 +++++-- tests/test_clip.cpp | 33 +++++++++++++++++++ tests/test_clip.py | 18 ++++++++++ 6 files changed, 73 insertions(+), 5 deletions(-) diff --git a/src/opentimelineio/clip.cpp b/src/opentimelineio/clip.cpp index e642b48f35..eb5be6380b 100644 --- a/src/opentimelineio/clip.cpp +++ b/src/opentimelineio/clip.cpp @@ -13,8 +13,10 @@ Clip::Clip( MediaReference* media_reference, std::optional const& source_range, AnyDictionary const& metadata, + std::vector const& effects, + std::vector const& markers, std::string const& active_media_reference_key) - : Parent{ name, source_range, metadata } + : Parent{ name, source_range, metadata, effects, markers } , _active_media_reference_key(active_media_reference_key) { set_media_reference(media_reference); diff --git a/src/opentimelineio/clip.h b/src/opentimelineio/clip.h index 5d7d5baccf..27f8bc9cf5 100644 --- a/src/opentimelineio/clip.h +++ b/src/opentimelineio/clip.h @@ -27,6 +27,8 @@ class Clip : public Item MediaReference* media_reference = nullptr, std::optional const& source_range = std::nullopt, AnyDictionary const& metadata = AnyDictionary(), + std::vector const& effects = std::vector(), + std::vector const& markers = std::vector(), std::string const& active_media_reference_key = default_media_key); void set_media_reference(MediaReference* media_reference); diff --git a/src/py-opentimelineio/opentimelineio-bindings/otio_serializableObjects.cpp b/src/py-opentimelineio/opentimelineio-bindings/otio_serializableObjects.cpp index b8361d0942..5be092c3a9 100644 --- a/src/py-opentimelineio/opentimelineio-bindings/otio_serializableObjects.cpp +++ b/src/py-opentimelineio/opentimelineio-bindings/otio_serializableObjects.cpp @@ -425,13 +425,20 @@ Contains a :class:`.MediaReference` and a trim on that media reference. )docstring") .def(py::init([](std::string name, MediaReference* media_reference, std::optional source_range, py::object metadata, + std::optional> effects, + std::optional> markers, const std::string& active_media_reference) { - return new Clip(name, media_reference, source_range, py_to_any_dictionary(metadata), active_media_reference); + return new Clip(name, media_reference, source_range, py_to_any_dictionary(metadata), + vector_or_default(effects), + vector_or_default(markers), + active_media_reference); }), py::arg_v("name"_a = std::string()), "media_reference"_a = nullptr, "source_range"_a = std::nullopt, py::arg_v("metadata"_a = py::none()), + "effects"_a = py::none(), + "markers"_a = py::none(), "active_media_reference"_a = std::string(Clip::default_media_key)) .def_property_readonly_static("DEFAULT_MEDIA_KEY",[](py::object /* self */) { return Clip::default_media_key; diff --git a/src/py-opentimelineio/opentimelineio/schema/clip.py b/src/py-opentimelineio/opentimelineio/schema/clip.py index c0de97158b..cfa31a67cd 100644 --- a/src/py-opentimelineio/opentimelineio/schema/clip.py +++ b/src/py-opentimelineio/opentimelineio/schema/clip.py @@ -7,11 +7,13 @@ @add_method(_otio.Clip) def __str__(self): - return 'Clip("{}", {}, {}, {})'.format( + return 'Clip("{}", {}, {}, {}, {}, {})'.format( self.name, self.media_reference, self.source_range, - self.metadata + self.metadata, + self.effects, + self.markers ) @@ -22,12 +24,16 @@ def __repr__(self): 'name={}, ' 'media_reference={}, ' 'source_range={}, ' - 'metadata={}' + 'metadata={}, ' + 'effects={}, ' + 'markers={}' ')'.format( repr(self.name), repr(self.media_reference), repr(self.source_range), repr(self.metadata), + repr(self.effects), + repr(self.markers) ) ) diff --git a/tests/test_clip.cpp b/tests/test_clip.cpp index 467211d7f0..285bbd76e0 100644 --- a/tests/test_clip.cpp +++ b/tests/test_clip.cpp @@ -9,6 +9,9 @@ #include #include #include +#include +#include +#include #include @@ -150,6 +153,22 @@ main(int argc, char** argv) tests.add_test("test_clip_media_representation", [] { using namespace otio; + static constexpr auto time_scalar = 1.5; + + SerializableObject::Retainer ltw(new LinearTimeWarp( + LinearTimeWarp::Schema::name, + LinearTimeWarp::Schema::name, + time_scalar)); + std::vector effects = { ltw }; + + static constexpr auto red = Marker::Color::red; + + SerializableObject::Retainer m(new Marker( + LinearTimeWarp::Schema::name, + TimeRange(), + red)); + std::vector markers = { m }; + static constexpr auto high_quality = "high_quality"; static constexpr auto proxy_quality = "proxy_quality"; @@ -161,6 +180,8 @@ main(int argc, char** argv) media, std::nullopt, AnyDictionary(), + effects, + markers, high_quality)); assertEqual(clip->active_media_reference_key().c_str(), high_quality); @@ -225,6 +246,18 @@ main(int argc, char** argv) // should work clip->set_media_references({ { "cloud", ref4 } }, "cloud"); assertEqual(clip->media_reference(), ref4.value); + + // basic test for an effect + assertEqual(clip->effects().size(), effects.size()); + auto effect = dynamic_cast( + clip->effects().front().value); + assertEqual(effect->time_scalar(), time_scalar); + + // basic test for a marker + assertEqual(clip->markers().size(), markers.size()); + auto marker = dynamic_cast( + clip->markers().front().value); + assertEqual(marker->color().c_str(), red); }); tests.run(argc, argv); diff --git a/tests/test_clip.py b/tests/test_clip.py index 1cab19b185..cb2dafd7cf 100644 --- a/tests/test_clip.py +++ b/tests/test_clip.py @@ -21,10 +21,24 @@ def test_cons(self): target_url="/var/tmp/test.mov" ) + ltw = otio.schema.LinearTimeWarp( + name="linear_time_warp", + time_scalar=1.5) + effects = [] + effects.append(ltw) + + red = otio.schema.MarkerColor.RED + m = otio.schema.Marker( + name="red_marker", color=red) + markers = [] + markers.append(m) + cl = otio.schema.Clip( name=name, media_reference=mr, source_range=tr, + effects=effects, + markers=markers, # transition_in # transition_out ) @@ -32,6 +46,10 @@ def test_cons(self): self.assertEqual(cl.source_range, tr) self.assertIsOTIOEquivalentTo(cl.media_reference, mr) + self.assertTrue(isinstance(cl.effects[0], otio.schema.LinearTimeWarp)) + + self.assertEqual(cl.markers[0].color, red) + encoded = otio.adapters.otio_json.write_to_string(cl) decoded = otio.adapters.otio_json.read_from_string(encoded) self.assertIsOTIOEquivalentTo(cl, decoded)