]> git.sesse.net Git - nageru/blobdiff - theme.h
Hook up white balance into the theme.
[nageru] / theme.h
diff --git a/theme.h b/theme.h
index 49152637975c8d2df8a90325c8f2dbd247a5eebb..f00c7a2acc2067b656af4598b1b9c2022e1af756 100644 (file)
--- a/theme.h
+++ b/theme.h
@@ -1,16 +1,27 @@
 #ifndef _THEME_H
 #define _THEME_H 1
 
-#include <stdio.h>
-#include <lua.h>
+#include <epoxy/gl.h>
 #include <lauxlib.h>
-
+#include <lua.h>
+#include <movit/effect_chain.h>
+#include <movit/ycbcr_input.h>
+#include <stdbool.h>
+#include <stdio.h>
 #include <functional>
 #include <mutex>
+#include <set>
+#include <string>
 #include <utility>
+#include <vector>
 
-#include <movit/effect_chain.h>
-#include <movit/ycbcr_input.h>
+namespace movit {
+class ResourcePool;
+struct ImageFormat;
+struct YCbCrFormat;
+}  // namespace movit
+
+#define MAX_CARDS 16
 
 class NonBouncingYCbCrInput : public movit::YCbCrInput {
 public:
@@ -25,7 +36,7 @@ public:
 
 class Theme {
 public:
-       Theme(const char *filename, movit::ResourcePool *resource_pool);
+       Theme(const char *filename, movit::ResourcePool *resource_pool, unsigned num_cards);
 
        std::pair<movit::EffectChain *, std::function<void()>>
        get_chain(unsigned num, float t, unsigned width, unsigned height);
@@ -35,6 +46,9 @@ public:
                input_textures[signal_num].tex_cbcr = tex_cbcr;
        }
        int get_num_channels() { return num_channels; }
+       std::string get_channel_name(unsigned channel);
+       bool get_supports_set_wb(unsigned channel);
+       void set_wb(unsigned channel, double r, double g, double b);
 
        std::vector<std::string> get_transition_names(float t);
 
@@ -50,8 +64,10 @@ private:
        movit::ResourcePool *resource_pool;
        struct {
                GLuint tex_y = 0, tex_cbcr = 0;
-       } input_textures[16];  // FIXME
+       } input_textures[MAX_CARDS];
        int num_channels;
+       unsigned num_cards;
+       std::set<int> signals_warned_about;
 };
 
 class LiveInputWrapper {