28 #include "../../include/effects/Negate.h" 41 info.
description =
"Negates the colors, producing a negative of the image.";
48 tr1::shared_ptr<Frame>
Negate::GetFrame(tr1::shared_ptr<Frame> frame,
long int frame_number)
51 frame->GetImage()->invertPixels();
81 bool success = reader.parse( value, root );
84 throw InvalidJSON(
"JSON could not be parsed (or is invalid)",
"");
94 throw InvalidJSON(
"JSON is invalid (missing keys or invalid data types)",
"");
110 Point requested_point(requested_frame, requested_frame);
114 root[
"id"] =
add_property_json(
"ID", 0.0,
"string",
Id(),
false, 0, -1, -1,
CONSTANT, -1,
true);
115 root[
"position"] =
add_property_json(
"Position",
Position(),
"float",
"",
false, 0, 0, 30 * 60 * 60 * 48,
CONSTANT, -1,
false);
116 root[
"layer"] =
add_property_json(
"Track",
Layer(),
"int",
"",
false, 0, 0, 20,
CONSTANT, -1,
false);
117 root[
"start"] =
add_property_json(
"Start",
Start(),
"float",
"",
false, 0, 0, 30 * 60 * 60 * 48,
CONSTANT, -1,
false);
118 root[
"end"] =
add_property_json(
"End",
End(),
"float",
"",
false, 0, 0, 30 * 60 * 60 * 48,
CONSTANT, -1,
false);
119 root[
"duration"] =
add_property_json(
"Duration",
Duration(),
"float",
"",
false, 0, 0, 30 * 60 * 60 * 48,
CONSTANT, -1,
true);
122 return root.toStyledString();
void SetJsonValue(Json::Value root)
Load Json::JsonValue into this object.
tr1::shared_ptr< Frame > GetFrame(tr1::shared_ptr< Frame > frame, long int frame_number)
This method is required for all derived classes of EffectBase, and returns a modified openshot::Frame...
float End()
Get end position (in seconds) of clip (trim end of video)
A Point is the basic building block of a key-frame curve.
int Layer()
Get layer of clip on timeline (lower number is covered by higher numbers)
Json::Value JsonValue()
Generate Json::JsonValue for this object.
string class_name
The class name of the effect.
virtual Json::Value JsonValue()=0
Generate Json::JsonValue for this object.
bool has_audio
Determines if this effect manipulates the audio of a frame.
Json::Value add_property_json(string name, float value, string type, string memo, bool contains_point, int number_of_points, float min_value, float max_value, InterpolationType intepolation, int closest_point_x, bool readonly)
Generate JSON for a property.
string Id()
Get basic properties.
float Position()
Get position on timeline (in seconds)
string name
The name of the effect.
string PropertiesJSON(long int requested_frame)
string description
The description of this effect and what it does.
virtual void SetJsonValue(Json::Value root)=0
Load Json::JsonValue into this object.
Negate()
Default constructor.
This namespace is the default namespace for all code in the openshot library.
bool has_video
Determines if this effect manipulates the image of a frame.
Exception for invalid JSON.
string Json()
Get and Set JSON methods.
void SetJson(string value)
Load JSON string into this object.
float Duration()
Get the length of this clip (in seconds)
Constant curves jump from their previous position to a new one (with no interpolation).
float Start()
Get start position (in seconds) of clip (trim start of video)
EffectInfoStruct info
Information about the current effect.