2016-04-28 21:04:59 -04:00
|
|
|
//
|
|
|
|
// IntermediateShader.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 28/04/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef IntermediateShader_hpp
|
|
|
|
#define IntermediateShader_hpp
|
|
|
|
|
|
|
|
#include "Shader.hpp"
|
2017-11-11 15:28:40 -05:00
|
|
|
|
|
|
|
#include <cstdio>
|
2016-04-28 21:04:59 -04:00
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
namespace OpenGL {
|
|
|
|
|
|
|
|
class IntermediateShader: public Shader {
|
|
|
|
public:
|
|
|
|
using Shader::Shader;
|
|
|
|
|
2016-04-28 21:55:14 -04:00
|
|
|
/*!
|
|
|
|
Constructs and returns an intermediate shader that will take runs from the inputPositions,
|
|
|
|
converting them to single-channel composite values using @c composite_shader if supplied
|
|
|
|
or @c rgb_shader and a reference composite conversion if @c composite_shader is @c nullptr.
|
|
|
|
*/
|
2017-02-20 10:35:33 -05:00
|
|
|
static std::unique_ptr<IntermediateShader> make_source_conversion_shader(const std::string &composite_shader, const std::string &rgb_shader);
|
2016-04-28 21:55:14 -04:00
|
|
|
|
2016-05-02 21:05:58 -04:00
|
|
|
/*!
|
|
|
|
Constructs and returns an intermediate shader that will take runs from the inputPositions,
|
|
|
|
converting them to RGB values using @c rgb_shader.
|
|
|
|
*/
|
2017-02-20 10:35:33 -05:00
|
|
|
static std::unique_ptr<IntermediateShader> make_rgb_source_shader(const std::string &rgb_shader);
|
2016-05-02 21:05:58 -04:00
|
|
|
|
2016-04-28 21:55:14 -04:00
|
|
|
/*!
|
|
|
|
Constructs and returns an intermediate shader that will read composite samples from the R channel,
|
|
|
|
filter then to obtain luminance, stored to R, and to separate out unfiltered chrominance, store to G and B.
|
|
|
|
*/
|
2016-04-28 21:04:59 -04:00
|
|
|
static std::unique_ptr<IntermediateShader> make_chroma_luma_separation_shader();
|
2016-04-28 21:55:14 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Constructs and returns an intermediate shader that will pass R through unchanged while filtering G and B.
|
|
|
|
*/
|
2016-04-28 21:04:59 -04:00
|
|
|
static std::unique_ptr<IntermediateShader> make_chroma_filter_shader();
|
|
|
|
|
2016-05-02 21:05:58 -04:00
|
|
|
/*!
|
|
|
|
Constructs and returns an intermediate shader that will filter R, G and B.
|
|
|
|
*/
|
|
|
|
static std::unique_ptr<IntermediateShader> make_rgb_filter_shader();
|
|
|
|
|
2016-04-28 21:04:59 -04:00
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues the configuration of this shader for output to an area of `output_width` and `output_height` pixels
|
|
|
|
to occur upon the next `bind`.
|
2016-04-28 21:04:59 -04:00
|
|
|
*/
|
|
|
|
void set_output_size(unsigned int output_width, unsigned int output_height);
|
|
|
|
|
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues setting the texture unit (as an enum, e.g. `GL_TEXTURE0`) for source data to occur upon the next `bind`.
|
2016-04-28 21:04:59 -04:00
|
|
|
*/
|
|
|
|
void set_source_texture_unit(GLenum unit);
|
|
|
|
|
2016-04-28 21:45:44 -04:00
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues setting filtering coefficients for a lowpass filter based on the cutoff frequency to occur upon the next `bind`.
|
2016-04-28 21:45:44 -04:00
|
|
|
*/
|
2016-04-28 21:04:59 -04:00
|
|
|
void set_filter_coefficients(float sampling_rate, float cutoff_frequency);
|
|
|
|
|
2016-05-02 21:05:58 -04:00
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues configuration of filtering to separate luminance and chrominance based on a colour
|
|
|
|
subcarrier of the given frequency to occur upon the next `bind`.
|
2016-05-02 21:05:58 -04:00
|
|
|
*/
|
|
|
|
void set_separation_frequency(float sampling_rate, float colour_burst_frequency);
|
|
|
|
|
2016-04-28 21:45:44 -04:00
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues setting of the number of colour phase cycles per sample, indicating whether output
|
|
|
|
geometry should be extended so that a complete colour cycle is included at both the beginning and end,
|
|
|
|
to occur upon the next `bind`.
|
2016-04-28 21:45:44 -04:00
|
|
|
*/
|
2017-01-08 16:48:02 -05:00
|
|
|
void set_extension(float extension);
|
2016-04-28 21:04:59 -04:00
|
|
|
|
2016-04-28 21:45:44 -04:00
|
|
|
/*!
|
2016-05-15 14:59:59 -04:00
|
|
|
Queues setting the matrices that convert between RGB and chrominance/luminance to occur on the next `bind`.
|
2016-04-28 21:45:44 -04:00
|
|
|
*/
|
2016-04-28 21:04:59 -04:00
|
|
|
void set_colour_conversion_matrices(float *fromRGB, float *toRGB);
|
|
|
|
|
2017-01-03 22:16:52 -05:00
|
|
|
/*!
|
|
|
|
Sets the proportions of the input and output areas that should be considered the whole width — 1.0 means use all available
|
|
|
|
space, 0.5 means use half, etc.
|
|
|
|
*/
|
|
|
|
void set_width_scalers(float input_scaler, float output_scaler);
|
|
|
|
|
2017-01-08 11:13:20 -05:00
|
|
|
/*!
|
|
|
|
Sets source and target vertical offsets.
|
|
|
|
*/
|
2017-01-08 14:47:16 -05:00
|
|
|
void set_is_double_height(bool is_double_height, float input_offset = 0.0f, float output_offset = 0.0f);
|
2017-01-08 11:13:20 -05:00
|
|
|
|
2016-04-28 21:04:59 -04:00
|
|
|
private:
|
2017-02-20 10:35:33 -05:00
|
|
|
static std::unique_ptr<IntermediateShader> make_shader(const std::string &fragment_shader, bool use_usampler, bool input_is_inputPosition);
|
2016-04-28 21:04:59 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* IntermediateShader_hpp */
|