X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=flat_input.h;h=25b9091abc837baa699d5d36bc2c0b94253dc97a;hp=965e34ddd1b79f8c6b996a572e0edb9a80622586;hb=95edbfccb0843da3cc105dadc5bc6d8e102f6071;hpb=b65b7cace3efb474a378e65d395f278307c1c44c diff --git a/flat_input.h b/flat_input.h index 965e34d..25b9091 100644 --- a/flat_input.h +++ b/flat_input.h @@ -1,7 +1,7 @@ #ifndef _MOVIT_FLAT_INPUT_H #define _MOVIT_FLAT_INPUT_H 1 -#include +#include #include #include @@ -26,23 +26,26 @@ public: virtual std::string effect_type_id() const { return "FlatInput"; } virtual bool can_output_linear_gamma() const { + // On desktop OpenGL, there's also GL_SLUMINANCE8 which could give us + // support for single-channel sRGB decoding, but it's not supported + // on GLES, and we're already actively rewriting single-channel inputs + // to GL_RED (even on desktop), so we stick to 3- and 4-channel inputs. return (movit_srgb_textures_supported && type == GL_UNSIGNED_BYTE && + (pixel_format == FORMAT_RGB || + pixel_format == FORMAT_RGBA_POSTMULTIPLIED_ALPHA) && (image_format.gamma_curve == GAMMA_LINEAR || image_format.gamma_curve == GAMMA_sRGB)); } virtual AlphaHandling alpha_handling() const { switch (pixel_format) { case FORMAT_RGBA_PREMULTIPLIED_ALPHA: - case FORMAT_BGRA_PREMULTIPLIED_ALPHA: return INPUT_AND_OUTPUT_PREMULTIPLIED_ALPHA; case FORMAT_RGBA_POSTMULTIPLIED_ALPHA: - case FORMAT_BGRA_POSTMULTIPLIED_ALPHA: return OUTPUT_POSTMULTIPLIED_ALPHA; + case FORMAT_R: case FORMAT_RG: case FORMAT_RGB: - case FORMAT_BGR: - case FORMAT_GRAYSCALE: return OUTPUT_BLANK_ALPHA; default: assert(false); @@ -123,6 +126,7 @@ private: unsigned width, height, pitch; const void *pixel_data; ResourcePool *resource_pool; + bool fixup_swap_rb, fixup_red_to_grayscale; }; } // namespace movit