OpenShot Library | libopenshot  0.5.0
Public Types | Public Member Functions | Public Attributes | List of all members
openshot::SphericalProjection Class Reference

Projects 360° or fisheye video through a virtual camera. Supports yaw, pitch, roll, input and output FOV, sphere/hemisphere/fisheye modes, optional inversion, and automatic quality selection. More...

#include <effects/SphericalProjection.h>

Inheritance diagram for openshot::SphericalProjection:
[legend]
Collaboration diagram for openshot::SphericalProjection:
[legend]

Public Types

enum  InputModel {
  INPUT_EQUIRECT = 0, INPUT_FEQ_EQUIDISTANT = 1, INPUT_FEQ_EQUISOLID = 2, INPUT_FEQ_STEREOGRAPHIC = 3,
  INPUT_FEQ_ORTHOGRAPHIC = 4
}
 
enum  InterpMode { INTERP_NEAREST = 0, INTERP_BILINEAR = 1, INTERP_BICUBIC = 2, INTERP_AUTO = 3 }
 
enum  InvertFlag { INVERT_NORMAL = 0, INVERT_BACK = 1 }
 
enum  ProjectionMode {
  MODE_RECT_SPHERE = 0, MODE_RECT_HEMISPHERE = 1, MODE_FISHEYE_EQUIDISTANT = 2, MODE_FISHEYE_EQUISOLID = 3,
  MODE_FISHEYE_STEREOGRAPHIC = 4, MODE_FISHEYE_ORTHOGRAPHIC = 5
}
 

Public Member Functions

std::shared_ptr< FrameGetFrame (int64_t frame_number) override
 ClipBase override: create a fresh Frame then call the main GetFrame. More...
 
std::shared_ptr< FrameGetFrame (std::shared_ptr< Frame > frame, int64_t frame_number) override
 EffectBase override: reproject the QImage. More...
 
std::string Json () const override
 Generate JSON string of this object. More...
 
Json::Value JsonValue () const override
 Generate Json::Value for this object. More...
 
std::string PropertiesJSON (int64_t requested_frame) const override
 
void SetJson (std::string value) override
 Load JSON string into this object. More...
 
void SetJsonValue (Json::Value root) override
 Load Json::Value into this object. More...
 
 SphericalProjection ()
 Blank ctor (for JSON deserialization) More...
 
 SphericalProjection (Keyframe new_yaw, Keyframe new_pitch, Keyframe new_roll, Keyframe new_fov)
 Ctor with custom curves. More...
 
- Public Member Functions inherited from openshot::EffectBase
Json::Value BasePropertiesJSON (int64_t requested_frame) const
 Generate JSON object of base properties (recommended to be used by all effects) More...
 
int constrain (int color_value)
 Constrain a color value from 0 to 255. More...
 
void DisplayInfo (std::ostream *out=&std::cout)
 Display effect information in the standard output stream (stdout) More...
 
virtual std::string GetVisibleObjects (int64_t frame_number) const
 Get the indexes and IDs of all visible objects in the given frame. More...
 
void InitEffectInfo ()
 
virtual std::string Json (int64_t requested_frame) const
 
Json::Value JsonInfo () const
 Generate JSON object of meta data / info. More...
 
int Order () const
 Get the order that this effect should be executed. More...
 
void Order (int new_order)
 Set the order that this effect should be executed. More...
 
openshot::ClipBaseParentClip ()
 Parent clip object of this effect (which can be unparented and NULL) More...
 
void ParentClip (openshot::ClipBase *new_clip)
 Set parent clip object of this effect. More...
 
std::string ParentClipId () const
 Return the ID of this effect's parent clip. More...
 
virtual void SetJson (int64_t requested_frame, const std::string value)
 
void SetParentEffect (std::string parentEffect_id)
 Set the parent effect from which this properties will be set to. More...
 
virtual ~EffectBase ()=default
 
- Public Member Functions inherited from openshot::ClipBase
 ClipBase ()
 Constructor for the base clip. More...
 
virtual void End (float value)
 Set end position (in seconds) of clip (trim end of video) More...
 
virtual std::shared_ptr< openshot::FrameGetFrame (std::shared_ptr< openshot::Frame > frame, int64_t frame_number)=0
 This method is required for all derived classes of ClipBase, and returns a modified openshot::Frame object. More...
 
void Id (std::string value)
 
void Layer (int value)
 Set layer of clip on timeline (lower number is covered by higher numbers) More...
 
bool operator< (ClipBase &a)
 
bool operator<= (ClipBase &a)
 
bool operator> (ClipBase &a)
 
bool operator>= (ClipBase &a)
 
void Position (float value)
 

Set the Id of this clip object

More...
 
void Start (float value)
 Set start position (in seconds) of clip (trim start of video) More...
 
virtual ~ClipBase ()=default
 

Public Attributes

Keyframe fov
 Output field-of-view (degrees) More...
 
Keyframe in_fov
 Source lens coverage / FOV (degrees) More...
 
int input_model
 0=Equirect, 1=Fisheye-Equidistant More...
 
int interpolation
 0=Nearest, 1=Bilinear, 2=Bicubic, 3=Auto More...
 
int invert
 0=Normal, 1=Invert (back lens / +180°) More...
 
Keyframe pitch
 Pitch around right-axis (degrees) More...
 
int projection_mode
 0=Sphere, 1=Hemisphere, 2=Fisheye More...
 
Keyframe roll
 Roll around forward-axis (degrees) More...
 
Keyframe yaw
 Yaw around up-axis (degrees) More...
 
- Public Attributes inherited from openshot::EffectBase
EffectInfoStruct info
 Information about the current effect. More...
 
EffectBaseparentEffect
 Parent effect (which properties will set this effect properties) More...
 
std::map< int, std::shared_ptr< openshot::TrackedObjectBase > > trackedObjects
 Map of Tracked Object's by their indices (used by Effects that track objects on clips) More...
 

Additional Inherited Members

- Protected Member Functions inherited from openshot::ClipBase
Json::Value add_property_choice_json (std::string name, int value, int selected_value) const
 Generate JSON choice for a property (dropdown properties) More...
 
Json::Value add_property_json (std::string name, float value, std::string type, std::string memo, const Keyframe *keyframe, float min_value, float max_value, bool readonly, int64_t requested_frame) const
 Generate JSON for a property. More...
 
- Protected Attributes inherited from openshot::EffectBase
openshot::ClipBaseclip
 Pointer to the parent clip instance (if any) More...
 
- Protected Attributes inherited from openshot::ClipBase
float end
 The position in seconds to end playing (used to trim the ending of a clip) More...
 
std::string id
 ID Property for all derived Clip and Effect classes. More...
 
int layer
 The layer this clip is on. Lower clips are covered up by higher clips. More...
 
float position
 The position on the timeline where this clip should start playing. More...
 
std::string previous_properties
 This string contains the previous JSON properties. More...
 
float start
 The position in seconds to start playing (used to trim the beginning of a clip) More...
 
openshot::TimelineBasetimeline
 Pointer to the parent timeline instance (if any) More...
 

Detailed Description

Projects 360° or fisheye video through a virtual camera. Supports yaw, pitch, roll, input and output FOV, sphere/hemisphere/fisheye modes, optional inversion, and automatic quality selection.

Definition at line 32 of file SphericalProjection.h.

Member Enumeration Documentation

◆ InputModel

Enumerator
INPUT_EQUIRECT 
INPUT_FEQ_EQUIDISTANT 
INPUT_FEQ_EQUISOLID 
INPUT_FEQ_STEREOGRAPHIC 
INPUT_FEQ_ORTHOGRAPHIC 

Definition at line 38 of file SphericalProjection.h.

◆ InterpMode

Enumerator
INTERP_NEAREST 
INTERP_BILINEAR 
INTERP_BICUBIC 
INTERP_AUTO 

Definition at line 55 of file SphericalProjection.h.

◆ InvertFlag

Enumerator
INVERT_NORMAL 
INVERT_BACK 

Definition at line 62 of file SphericalProjection.h.

◆ ProjectionMode

Enumerator
MODE_RECT_SPHERE 
MODE_RECT_HEMISPHERE 
MODE_FISHEYE_EQUIDISTANT 
MODE_FISHEYE_EQUISOLID 
MODE_FISHEYE_STEREOGRAPHIC 
MODE_FISHEYE_ORTHOGRAPHIC 

Definition at line 46 of file SphericalProjection.h.

Constructor & Destructor Documentation

◆ SphericalProjection() [1/2]

SphericalProjection::SphericalProjection ( )

Blank ctor (for JSON deserialization)

Definition at line 23 of file SphericalProjection.cpp.

◆ SphericalProjection() [2/2]

SphericalProjection::SphericalProjection ( Keyframe  new_yaw,
Keyframe  new_pitch,
Keyframe  new_roll,
Keyframe  new_fov 
)

Ctor with custom curves.

Definition at line 30 of file SphericalProjection.cpp.

Member Function Documentation

◆ GetFrame() [1/2]

std::shared_ptr<Frame> openshot::SphericalProjection::GetFrame ( int64_t  frame_number)
inlineoverridevirtual

ClipBase override: create a fresh Frame then call the main GetFrame.

Implements openshot::ClipBase.

Definition at line 86 of file SphericalProjection.h.

◆ GetFrame() [2/2]

std::shared_ptr<Frame> openshot::SphericalProjection::GetFrame ( std::shared_ptr< Frame frame,
int64_t  frame_number 
)
override

EffectBase override: reproject the QImage.

◆ Json()

std::string SphericalProjection::Json ( ) const
overridevirtual

Generate JSON string of this object.

Reimplemented from openshot::EffectBase.

Definition at line 422 of file SphericalProjection.cpp.

◆ JsonValue()

Json::Value SphericalProjection::JsonValue ( ) const
overridevirtual

Generate Json::Value for this object.

Reimplemented from openshot::EffectBase.

Definition at line 427 of file SphericalProjection.cpp.

Referenced by Json().

◆ PropertiesJSON()

std::string SphericalProjection::PropertiesJSON ( int64_t  requested_frame) const
overridevirtual

Get all properties for a specific frame (perfect for a UI to display the current state of all properties at any time)

Implements openshot::ClipBase.

Definition at line 493 of file SphericalProjection.cpp.

◆ SetJson()

void SphericalProjection::SetJson ( std::string  value)
overridevirtual

Load JSON string into this object.

Reimplemented from openshot::EffectBase.

Definition at line 443 of file SphericalProjection.cpp.

◆ SetJsonValue()

void SphericalProjection::SetJsonValue ( Json::Value  root)
overridevirtual

Load Json::Value into this object.

Reimplemented from openshot::EffectBase.

Definition at line 456 of file SphericalProjection.cpp.

Referenced by SetJson().

Member Data Documentation

◆ fov

Keyframe openshot::SphericalProjection::fov

Output field-of-view (degrees)

Definition at line 70 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ in_fov

Keyframe openshot::SphericalProjection::in_fov

Source lens coverage / FOV (degrees)

Definition at line 71 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ input_model

int openshot::SphericalProjection::input_model

0=Equirect, 1=Fisheye-Equidistant

Definition at line 75 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ interpolation

int openshot::SphericalProjection::interpolation

0=Nearest, 1=Bilinear, 2=Bicubic, 3=Auto

Definition at line 76 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ invert

int openshot::SphericalProjection::invert

0=Normal, 1=Invert (back lens / +180°)

Definition at line 74 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ pitch

Keyframe openshot::SphericalProjection::pitch

Pitch around right-axis (degrees)

Definition at line 68 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ projection_mode

int openshot::SphericalProjection::projection_mode

0=Sphere, 1=Hemisphere, 2=Fisheye

Definition at line 73 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ roll

Keyframe openshot::SphericalProjection::roll

Roll around forward-axis (degrees)

Definition at line 69 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().

◆ yaw

Keyframe openshot::SphericalProjection::yaw

Yaw around up-axis (degrees)

Definition at line 67 of file SphericalProjection.h.

Referenced by JsonValue(), PropertiesJSON(), and SetJsonValue().


The documentation for this class was generated from the following files: