mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-15 20:31:36 +00:00
Documented this interface, albeit that the English could do with a second pass, and very sightly simplified inline with current usage.
This commit is contained in:
parent
4d0d5eb919
commit
c1a509910d
@ -183,8 +183,7 @@ class OpenGLOutputBuilder {
|
|||||||
|
|
||||||
inline uint8_t *allocate_write_area(size_t required_length)
|
inline uint8_t *allocate_write_area(size_t required_length)
|
||||||
{
|
{
|
||||||
_texture_builder->allocate_write_area(required_length);
|
return _texture_builder->allocate_write_area(required_length);
|
||||||
return _texture_builder->get_write_target();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void reduce_previous_allocation_to(size_t actual_length)
|
inline void reduce_previous_allocation_to(size_t actual_length)
|
||||||
|
@ -20,7 +20,7 @@ InputTextureBuilder::InputTextureBuilder(size_t bytes_per_pixel) :
|
|||||||
_image.resize(bytes_per_pixel * InputBufferBuilderWidth * InputBufferBuilderHeight);
|
_image.resize(bytes_per_pixel * InputBufferBuilderWidth * InputBufferBuilderHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputTextureBuilder::allocate_write_area(size_t required_length)
|
uint8_t *InputTextureBuilder::allocate_write_area(size_t required_length)
|
||||||
{
|
{
|
||||||
if(_next_write_y_position != InputBufferBuilderHeight)
|
if(_next_write_y_position != InputBufferBuilderHeight)
|
||||||
{
|
{
|
||||||
@ -32,7 +32,7 @@ void InputTextureBuilder::allocate_write_area(size_t required_length)
|
|||||||
_next_write_y_position++;
|
_next_write_y_position++;
|
||||||
|
|
||||||
if(_next_write_y_position == InputBufferBuilderHeight)
|
if(_next_write_y_position == InputBufferBuilderHeight)
|
||||||
return;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
_write_x_position = _next_write_x_position + 1;
|
_write_x_position = _next_write_x_position + 1;
|
||||||
@ -40,6 +40,9 @@ void InputTextureBuilder::allocate_write_area(size_t required_length)
|
|||||||
_write_target_pointer = (_write_y_position * InputBufferBuilderWidth) + _write_x_position;
|
_write_target_pointer = (_write_y_position * InputBufferBuilderWidth) + _write_x_position;
|
||||||
_next_write_x_position += required_length + 2;
|
_next_write_x_position += required_length + 2;
|
||||||
}
|
}
|
||||||
|
else return nullptr;
|
||||||
|
|
||||||
|
return &_image[_write_target_pointer * _bytes_per_pixel];
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InputTextureBuilder::is_full()
|
bool InputTextureBuilder::is_full()
|
||||||
@ -90,11 +93,6 @@ uint16_t InputTextureBuilder::get_and_finalise_current_line()
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t *InputTextureBuilder::get_write_target()
|
|
||||||
{
|
|
||||||
return (_next_write_y_position == InputBufferBuilderHeight) ? nullptr : &_image[_write_target_pointer * _bytes_per_pixel];
|
|
||||||
}
|
|
||||||
|
|
||||||
uint16_t InputTextureBuilder::get_last_write_x_position()
|
uint16_t InputTextureBuilder::get_last_write_x_position()
|
||||||
{
|
{
|
||||||
return _write_x_position;
|
return _write_x_position;
|
||||||
|
@ -31,7 +31,8 @@ class InputTextureBuilder {
|
|||||||
|
|
||||||
/// Finds the first available space of at least @c required_length pixels in size. Calls must be paired off
|
/// Finds the first available space of at least @c required_length pixels in size. Calls must be paired off
|
||||||
/// with calls to @c reduce_previous_allocation_to.
|
/// with calls to @c reduce_previous_allocation_to.
|
||||||
void allocate_write_area(size_t required_length);
|
/// @returns a pointer to the allocated space if any was available; @c nullptr otherwise.
|
||||||
|
uint8_t *allocate_write_area(size_t required_length);
|
||||||
|
|
||||||
/// Announces that the owner is finished with the region created by the most recent @c allocate_write_area
|
/// Announces that the owner is finished with the region created by the most recent @c allocate_write_area
|
||||||
/// and indicates that its actual final size was @c actual_length.
|
/// and indicates that its actual final size was @c actual_length.
|
||||||
@ -44,14 +45,17 @@ class InputTextureBuilder {
|
|||||||
/// @returns a pointer to the image data for this texture.
|
/// @returns a pointer to the image data for this texture.
|
||||||
uint8_t *get_image_pointer();
|
uint8_t *get_image_pointer();
|
||||||
|
|
||||||
uint8_t *get_write_target();
|
/// @returns the start column for the most recent allocated write area.
|
||||||
|
|
||||||
uint16_t get_last_write_x_position();
|
uint16_t get_last_write_x_position();
|
||||||
|
|
||||||
|
/// @returns the row of the most recent allocated write area.
|
||||||
uint16_t get_last_write_y_position();
|
uint16_t get_last_write_y_position();
|
||||||
|
|
||||||
|
/// @returns the number of bytes per pixel as supplied to the constructor.
|
||||||
size_t get_bytes_per_pixel();
|
size_t get_bytes_per_pixel();
|
||||||
|
|
||||||
|
/// @returns @c true if all future calls to @c allocate_write_area will fail on account of the input texture
|
||||||
|
/// being full; @c false if calls may succeed.
|
||||||
bool is_full();
|
bool is_full();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user