godot/scene/animation/tween.h

271 lines
7.3 KiB
C++
Raw Normal View History

2014-08-20 12:01:41 +08:00
/*************************************************************************/
/* tween.h */
/*************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
/* http://www.godotengine.org */
/*************************************************************************/
/* Copyright (c) 2007-2017 Juan Linietsky, Ariel Manzur. */
2014-08-20 12:01:41 +08:00
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
/* "Software"), to deal in the Software without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of the Software, and to */
/* permit persons to whom the Software is furnished to do so, subject to */
/* the following conditions: */
/* */
/* The above copyright notice and this permission notice shall be */
/* included in all copies or substantial portions of the Software. */
/* */
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
#ifndef TWEEN_H
#define TWEEN_H
#include "scene/main/node.h"
class Tween : public Node {
GDCLASS( Tween, Node );
2014-08-20 12:01:41 +08:00
public:
enum TweenProcessMode {
TWEEN_PROCESS_FIXED,
TWEEN_PROCESS_IDLE,
};
enum TransitionType {
TRANS_LINEAR,
TRANS_SINE,
TRANS_QUINT,
TRANS_QUART,
TRANS_QUAD,
TRANS_EXPO,
TRANS_ELASTIC,
TRANS_CUBIC,
TRANS_CIRC,
TRANS_BOUNCE,
TRANS_BACK,
TRANS_COUNT,
2014-08-20 12:01:41 +08:00
};
2016-03-09 07:00:52 +08:00
2014-08-20 12:01:41 +08:00
enum EaseType {
EASE_IN,
EASE_OUT,
EASE_IN_OUT,
EASE_OUT_IN,
EASE_COUNT,
2014-08-20 12:01:41 +08:00
};
private:
enum InterpolateType {
INTER_PROPERTY,
INTER_METHOD,
FOLLOW_PROPERTY,
FOLLOW_METHOD,
TARGETING_PROPERTY,
TARGETING_METHOD,
INTER_CALLBACK,
};
2014-08-20 12:01:41 +08:00
struct InterpolateData {
bool active;
InterpolateType type;
bool finish;
2015-01-07 19:46:01 +08:00
bool call_deferred;
2014-08-20 12:01:41 +08:00
real_t elapsed;
ObjectID id;
StringName key;
2014-08-20 12:01:41 +08:00
Variant initial_val;
Variant delta_val;
Variant final_val;
ObjectID target_id;
StringName target_key;
real_t duration;
2014-08-20 12:01:41 +08:00
TransitionType trans_type;
EaseType ease_type;
real_t delay;
2015-01-07 19:46:01 +08:00
int args;
Variant arg[5];
2014-08-20 12:01:41 +08:00
};
String autoplay;
TweenProcessMode tween_process_mode;
bool processing;
bool active;
bool repeat;
2014-08-20 12:01:41 +08:00
float speed_scale;
mutable int pending_update;
2014-08-20 12:01:41 +08:00
List<InterpolateData> interpolates;
struct PendingCommand {
StringName key;
int args;
Variant arg[10];
};
List<PendingCommand> pending_commands;
void _add_pending_command(StringName p_key
,const Variant& p_arg1=Variant()
,const Variant& p_arg2=Variant()
,const Variant& p_arg3=Variant()
,const Variant& p_arg4=Variant()
,const Variant& p_arg5=Variant()
,const Variant& p_arg6=Variant()
,const Variant& p_arg7=Variant()
,const Variant& p_arg8=Variant()
,const Variant& p_arg9=Variant()
,const Variant& p_arg10=Variant()
);
void _process_pending_commands();
2014-08-20 12:01:41 +08:00
typedef real_t (*interpolater)(real_t t, real_t b, real_t c, real_t d);
static interpolater interpolaters[TRANS_COUNT][EASE_COUNT];
real_t _run_equation(TransitionType p_trans_type, EaseType p_ease_type, real_t t, real_t b, real_t c, real_t d);
Variant& _get_delta_val(InterpolateData& p_data);
Variant& _get_initial_val(InterpolateData& p_data);
2014-08-20 12:01:41 +08:00
Variant _run_equation(InterpolateData& p_data);
bool _calc_delta_val(const Variant& p_initial_val, const Variant& p_final_val, Variant& p_delta_val);
2014-08-20 12:01:41 +08:00
bool _apply_tween_value(InterpolateData& p_data, Variant& value);
void _tween_process(float p_delta);
void _set_process(bool p_process,bool p_force=false);
2016-10-26 21:15:20 +08:00
void _remove(Object *p_node, String p_key, bool first_only);
2014-08-20 12:01:41 +08:00
protected:
bool _set(const StringName& p_name, const Variant& p_value);
bool _get(const StringName& p_name,Variant &r_ret) const;
void _get_property_list(List<PropertyInfo> *p_list) const;
void _notification(int p_what);
static void _bind_methods();
public:
bool is_active() const;
void set_active(bool p_active);
bool is_repeat() const;
void set_repeat(bool p_repeat);
2014-08-20 12:01:41 +08:00
void set_tween_process_mode(TweenProcessMode p_mode);
TweenProcessMode get_tween_process_mode() const;
void set_speed_scale(float p_speed);
float get_speed_scale() const;
2014-08-20 12:01:41 +08:00
bool start();
bool reset(Object *p_node, String p_key);
2014-08-20 12:01:41 +08:00
bool reset_all();
bool stop(Object *p_node, String p_key);
2014-08-20 12:01:41 +08:00
bool stop_all();
bool resume(Object *p_node, String p_key);
2014-08-20 12:01:41 +08:00
bool resume_all();
bool remove(Object *p_node, String p_key);
2014-08-20 12:19:22 +08:00
bool remove_all();
2014-08-20 12:01:41 +08:00
bool seek(real_t p_time);
2014-08-22 14:25:41 +08:00
real_t tell() const;
real_t get_runtime() const;
bool interpolate_property(Object *p_node
2014-08-20 12:01:41 +08:00
, String p_property
, Variant p_initial_val
, Variant p_final_val
, real_t p_duration
2014-08-20 12:01:41 +08:00
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
2014-08-20 12:01:41 +08:00
);
bool interpolate_method(Object *p_node
2014-08-20 12:01:41 +08:00
, String p_method
, Variant p_initial_val
, Variant p_final_val
, real_t p_duration
2014-08-20 12:01:41 +08:00
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
2014-08-20 12:01:41 +08:00
);
2015-01-07 19:46:01 +08:00
bool interpolate_callback(Object *p_object
, real_t p_duration
, String p_callback
2015-01-07 19:46:01 +08:00
, VARIANT_ARG_DECLARE
);
2016-03-09 07:00:52 +08:00
2015-01-07 19:46:01 +08:00
bool interpolate_deferred_callback(Object *p_object
, real_t p_duration
2015-01-07 19:46:01 +08:00
, String p_callback
, VARIANT_ARG_DECLARE
);
bool follow_property(Object *p_node
, String p_property
, Variant p_initial_val
, Object *p_target
, String p_target_property
, real_t p_duration
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
);
bool follow_method(Object *p_node
, String p_method
, Variant p_initial_val
, Object *p_target
, String p_target_method
, real_t p_duration
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
);
bool targeting_property(Object *p_node
, String p_property
, Object *p_initial
, String p_initial_property
, Variant p_final_val
, real_t p_duration
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
);
bool targeting_method(Object *p_node
, String p_method
, Object *p_initial
, String p_initial_method
, Variant p_final_val
, real_t p_duration
, TransitionType p_trans_type
, EaseType p_ease_type
, real_t p_delay = 0
);
2014-08-20 12:01:41 +08:00
Tween();
~Tween();
};
VARIANT_ENUM_CAST( Tween::TweenProcessMode );
VARIANT_ENUM_CAST( Tween::TransitionType );
VARIANT_ENUM_CAST( Tween::EaseType );
#endif