projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
* Finish work on Path through the Clouds
[supertux.git]
/
src
/
object
/
camera.hpp
diff --git
a/src/object/camera.hpp
b/src/object/camera.hpp
index
0be750e
..
061fe4d
100644
(file)
--- a/
src/object/camera.hpp
+++ b/
src/object/camera.hpp
@@
-1,7
+1,7
@@
// $Id$
//
// $Id$
//
-// SuperTux
- A Jump'n Run
-// Copyright (C) 200
4 Matthias Braun <matze@braunis.de
+// SuperTux
+// Copyright (C) 200
6 Matthias Braun <matze@braunis.de>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
@@
-28,6
+28,7
@@
#include "video/drawing_context.hpp"
#include "serializable.hpp"
#include "timer.hpp"
#include "video/drawing_context.hpp"
#include "serializable.hpp"
#include "timer.hpp"
+#include "script_interface.hpp"
namespace lisp {
class Lisp;
namespace lisp {
class Lisp;
@@
-36,11
+37,12
@@
class Lisp;
class Sector;
class Path;
class PathWalker;
class Sector;
class Path;
class PathWalker;
+class CameraConfig;
-class Camera : public GameObject, public Serializable
+class Camera : public GameObject, public Serializable
, public ScriptInterface
{
public:
{
public:
- Camera(Sector* sector);
+ Camera(Sector* sector
, std::string name = ""
);
virtual ~Camera();
/// parse camera mode from lisp file
virtual ~Camera();
/// parse camera mode from lisp file
@@
-48,17
+50,18
@@
public:
/// write camera mode to a lisp file
virtual void write(lisp::Writer& writer);
/// write camera mode to a lisp file
virtual void write(lisp::Writer& writer);
- /// reset camera postion
- v
irtual v
oid reset(const Vector& tuxpos);
+ /// reset camera pos
i
tion
+ void reset(const Vector& tuxpos);
/** return camera position */
const Vector& get_translation() const;
virtual void update(float elapsed_time);
/** return camera position */
const Vector& get_translation() const;
virtual void update(float elapsed_time);
- virtual void draw(DrawingContext& )
- {
- }
+ virtual void draw(DrawingContext& );
+
+ virtual void expose(HSQUIRRELVM vm, SQInteger table_idx);
+ virtual void unexpose(HSQUIRRELVM vm, SQInteger table_idx);
// shake camera in a direction 1 time
void shake(float speed, float x, float y);
// shake camera in a direction 1 time
void shake(float speed, float x, float y);
@@
-75,12
+78,19
@@
public:
*/
void scroll_to(const Vector& goal, float scrolltime);
*/
void scroll_to(const Vector& goal, float scrolltime);
+ void reload_config();
+
enum CameraMode
{
NORMAL, AUTOSCROLL, SCROLLTO, MANUAL
};
CameraMode mode;
enum CameraMode
{
NORMAL, AUTOSCROLL, SCROLLTO, MANUAL
};
CameraMode mode;
+ /**
+ * get the coordinates of the point directly in the center of this camera
+ */
+ Vector get_center() const;
+
private:
void update_scroll_normal(float elapsed_time);
void update_scroll_autoscroll(float elapsed_time);
private:
void update_scroll_normal(float elapsed_time);
void update_scroll_autoscroll(float elapsed_time);
@@
-88,9
+98,12
@@
private:
void keep_in_bounds(Vector& vector);
void shake();
void keep_in_bounds(Vector& vector);
void shake();
- enum LeftRightScrollChange
- {
- NONE, LEFT, RIGHT
+ /**
+ * The camera basically provides lookahead on the left or right side
+ * or is undecided.
+ */
+ enum LookaheadMode {
+ LOOKAHEAD_NONE, LOOKAHEAD_LEFT, LOOKAHEAD_RIGHT
};
Vector translation;
};
Vector translation;
@@
-98,8
+111,11
@@
private:
Sector* sector;
// normal mode
Sector* sector;
// normal mode
- bool do_backscrolling;
- LeftRightScrollChange scrollchange;
+ LookaheadMode lookahead_mode;
+ float changetime;
+ Vector lookahead_pos;
+ Vector peek_pos;
+ Vector cached_translation;
// autoscroll mode
std::auto_ptr<Path> autoscroll_path;
// autoscroll mode
std::auto_ptr<Path> autoscroll_path;
@@
-116,7
+132,8
@@
private:
Vector scroll_goal;
float scroll_to_pos;
float scrollspeed;
Vector scroll_goal;
float scroll_to_pos;
float scrollspeed;
+
+ CameraConfig *config;
};
#endif /*SUPERTUX_CAMERA_H*/
};
#endif /*SUPERTUX_CAMERA_H*/
-