aboutsummaryrefslogtreecommitdiff
path: root/src/layer_video.h
diff options
context:
space:
mode:
authorRobin Haberkorn <robin.haberkorn@googlemail.com>2012-09-28 15:26:29 +0200
committerRobin Haberkorn <robin.haberkorn@googlemail.com>2012-09-28 15:26:29 +0200
commite7da86053b3df2882816b0df8089e1a51b61939f (patch)
tree8f7430f7d1e82ddb8449548886f57a3a7c646c05 /src/layer_video.h
parent9b134ea457f91ba8ea6ae558c9192f58c09f62bc (diff)
downloadosc-graphics-e7da86053b3df2882816b0df8089e1a51b61939f.tar.gz
autotools based build system
Diffstat (limited to 'src/layer_video.h')
-rw-r--r--src/layer_video.h92
1 files changed, 92 insertions, 0 deletions
diff --git a/src/layer_video.h b/src/layer_video.h
new file mode 100644
index 0000000..c3a4806
--- /dev/null
+++ b/src/layer_video.h
@@ -0,0 +1,92 @@
+#ifndef __LAYER_VIDEO_H
+#define __LAYER_VIDEO_H
+
+#include <SDL.h>
+#include <SDL_thread.h>
+
+#include <lo/lo.h>
+
+#include <vlc/vlc.h>
+
+#include "osc_graphics.h"
+#include "layer.h"
+
+class LayerVideo : public Layer {
+ static libvlc_instance_t *vlcinst;
+ libvlc_media_player_t *mp;
+
+ SDL_Surface *surf;
+ SDL_mutex *mutex;
+
+ SDL_Rect geov;
+ float alphav;
+
+ float ratev;
+ bool pausedv;
+
+public:
+ LayerVideo(const char *name,
+ SDL_Rect geo = (SDL_Rect){0, 0, 0, 0},
+ float opacity = 1.,
+ const char *url = NULL);
+
+ static CtorInfo ctor_info;
+ static Layer *
+ ctor_osc(const char *name, SDL_Rect geo, float opacity, lo_arg **argv)
+ {
+ return new LayerVideo(name, geo, opacity, &argv[0]->s);
+ }
+
+ ~LayerVideo();
+
+ inline void *
+ lock_surf()
+ {
+ SDL_LockMutex(mutex);
+ SDL_MAYBE_LOCK(surf);
+ return surf->pixels;
+ }
+ inline void
+ unlock_surf()
+ {
+ SDL_MAYBE_UNLOCK(surf);
+ SDL_UnlockMutex(mutex);
+ }
+
+ void frame(SDL_Surface *target);
+
+private:
+ void geo(SDL_Rect geo);
+ void alpha(float opacity);
+
+ void url(const char *url = NULL);
+ OSCServer::MethodHandlerId *url_osc_id;
+ static void
+ url_osc(LayerVideo *obj, lo_arg **argv)
+ {
+ obj->url(&argv[0]->s);
+ }
+ void rate(float rate);
+ OSCServer::MethodHandlerId *rate_osc_id;
+ static void
+ rate_osc(LayerVideo *obj, lo_arg **argv)
+ {
+ obj->rate(argv[0]->f);
+ }
+ void position(float position);
+ OSCServer::MethodHandlerId *position_osc_id;
+ static void
+ position_osc(LayerVideo *obj, lo_arg **argv)
+ {
+ obj->position(argv[0]->f);
+ }
+ void paused(bool paused);
+ OSCServer::MethodHandlerId *paused_osc_id;
+ static void
+ paused_osc(LayerVideo *obj, lo_arg **argv)
+ {
+ obj->paused(argv[0]->i);
+ }
+};
+
+#endif