Lumiera 0.pre.04
»edit your freedom«
Loading...
Searching...
No Matches
timeline.hpp File Reference

Top level structural element within the session. More...

Go to the source code of this file.

Description

Top level structural element within the session.

Each Lumiera session may contain multiple top level timeline containers, which at the same time act as structural asset and as part of the public session API exposed to clients for discovering the session contents. Actually, Timelines are facade objects, delegating the implementation to the BindingMO, the Axis and the Sequences/Tracks.

Contrary to usual habits in video/sound editing software, in Lumiera the tracks are not part of the timeline, but rather attached directly to the sequence container. To be usable, a timeline needs a binding to refer to such a sequence, but this sequence may be bound into multiple timelines or even virtual clips simultaneously.

Like every structural asset, the creation of timelines happens automatically on referral; Timelines can be queried from the StructFactory, providing additional requested capabilities. Commonly clients will retrieve a given timeline by query on the name-ID of the timeline: Struct::retrieve (Query<Timeline>("id(theName).")) Additionally, the binding to a specific sequence may be established alongside: "timeline(theTimelineName), bindSequence(theTimelineName,sequenceID)."

Todo:

around 2010, the concept of Timeline and Session binding was defined, together with a rough preliminary implementation. Up to 2017, there was no opportunity to set this system really into motion; this is not necessarily a bad thing, since meanwhile we understand way better in which way the Session will actually be accessed...

looks like we'll represent a secondary, attached slave display of the same Timeline rather by materialising it into a TimelineClone within the session. This topic has been postponed as of 10/2018 //////////////////////////////////////TICKET #1083

See also
Session
Sequence
StructFactory

Definition in file timeline.hpp.

Namespaces

namespace  steam
 Steam-Layer implementation namespace root.
 
namespace  steam::mobject
 Media-Objects, edit operations and high-level session.
 
namespace  steam::mobject::session
 Namespace of Session and user visible high-level objects.
 
namespace  steam::asset
 The asset subsystem of the Steam-Layer.
 

Typedefs

using RBinding = MORef< Binding >
 
using PTimeline = lib::P< Timeline >
 

Classes

class  Timeline