stencile
parent
2c29dba90f
commit
b239984fd1
|
@ -1,6 +1,6 @@
|
||||||
cmake_minimum_required(VERSION 3.25)
|
cmake_minimum_required(VERSION 3.25)
|
||||||
|
|
||||||
set(BLT_GRAPHICS_VERSION 0.13.14)
|
set(BLT_GRAPHICS_VERSION 0.13.15)
|
||||||
set(BLT_GRAPHICS_TEST_VERSION 0.0.1)
|
set(BLT_GRAPHICS_TEST_VERSION 0.0.1)
|
||||||
|
|
||||||
project(BLT_WITH_GRAPHICS VERSION ${BLT_GRAPHICS_VERSION})
|
project(BLT_WITH_GRAPHICS VERSION ${BLT_GRAPHICS_VERSION})
|
||||||
|
|
|
@ -107,40 +107,45 @@ namespace blt::gfx
|
||||||
color4 blend;
|
color4 blend;
|
||||||
// should we outline this object?
|
// should we outline this object?
|
||||||
bool outline = false;
|
bool outline = false;
|
||||||
|
float outline_thickness = 1.25f;
|
||||||
// what color should we outline with?
|
// what color should we outline with?
|
||||||
color4 outline_color;
|
color4 outline_color;
|
||||||
|
|
||||||
render_info_t() = default;
|
render_info_t() = default;
|
||||||
|
|
||||||
static render_info_t make_info(const std::string_view texture, const color4 outline = disabled)
|
static render_info_t make_info(const std::string_view texture, const color4 outline = disabled, float outline_thickness = 1.25f)
|
||||||
{
|
{
|
||||||
render_info_t info{texture, empty, full};
|
render_info_t info{texture, empty, full};
|
||||||
if (outline != disabled)
|
if (outline != disabled)
|
||||||
{
|
{
|
||||||
info.outline = true;
|
info.outline = true;
|
||||||
info.outline_color = outline;
|
info.outline_color = outline;
|
||||||
|
info.outline_thickness = outline_thickness;
|
||||||
}
|
}
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
static render_info_t make_info(const color4 color, const color4 outline = disabled)
|
static render_info_t make_info(const color4 color, const color4 outline = disabled, float outline_thickness = 1.25f)
|
||||||
{
|
{
|
||||||
render_info_t info{"", color, empty};
|
render_info_t info{"", color, empty};
|
||||||
if (outline != disabled)
|
if (outline != disabled)
|
||||||
{
|
{
|
||||||
info.outline = true;
|
info.outline = true;
|
||||||
info.outline_color = outline;
|
info.outline_color = outline;
|
||||||
|
info.outline_thickness = outline_thickness;
|
||||||
}
|
}
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
static render_info_t make_info(const std::string_view texture, const color4 color, const color4 blend, const color4 outline = disabled)
|
static render_info_t make_info(const std::string_view texture, const color4 color, const color4 blend, const color4 outline = disabled,
|
||||||
|
float outline_thickness = 1.25f)
|
||||||
{
|
{
|
||||||
render_info_t info{texture, color, blend};
|
render_info_t info{texture, color, blend};
|
||||||
if (outline != disabled)
|
if (outline != disabled)
|
||||||
{
|
{
|
||||||
info.outline = true;
|
info.outline = true;
|
||||||
info.outline_color = outline;
|
info.outline_color = outline;
|
||||||
|
info.outline_thickness = outline_thickness;
|
||||||
}
|
}
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
@ -169,10 +174,10 @@ namespace blt::gfx
|
||||||
using object_container = hashmap_t<std::string, std::vector<std::pair<render_info_t, T>>>;
|
using object_container = hashmap_t<std::string, std::vector<std::pair<render_info_t, T>>>;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unique_ptr<vertex_array_t> square_vao = nullptr;
|
std::unique_ptr<vertex_array_t> square_vao;
|
||||||
std::unique_ptr<vertex_array_t> line_vao = nullptr;
|
std::unique_ptr<vertex_array_t> line_vao;
|
||||||
std::unique_ptr<shader_t> square_shader = nullptr;
|
std::unique_ptr<shader_t> square_shader;
|
||||||
std::unique_ptr<shader_t> point_shader = nullptr;
|
std::unique_ptr<shader_t> point_shader;
|
||||||
resource_manager& resources;
|
resource_manager& resources;
|
||||||
matrix_state_manager& state;
|
matrix_state_manager& state;
|
||||||
// texture name -> draw info
|
// texture name -> draw info
|
||||||
|
@ -201,6 +206,10 @@ namespace blt::gfx
|
||||||
// called after draw_objects()
|
// called after draw_objects()
|
||||||
void post_reset();
|
void post_reset();
|
||||||
|
|
||||||
|
void draw_points(bool outlined, const f32 denominator);
|
||||||
|
void draw_lines(bool outlined, const f32 denominator);
|
||||||
|
void draw_rectangles(bool outlined, const f32 denominator);
|
||||||
|
|
||||||
void draw_objects();
|
void draw_objects();
|
||||||
|
|
||||||
inline void update_z_index(f32 z_index)
|
inline void update_z_index(f32 z_index)
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 9c0fc819690a99cbf8cdf923f1aeda22ff57ae9b
|
Subproject commit 12169a700195f23d5ebce54d0edb79bee4f8b0e1
|
|
@ -1 +1 @@
|
||||||
Subproject commit a1b06823fe2d964a62fda99385499b218cf5cea5
|
Subproject commit 231cbee0fc4f59dbe5b8b853a11b08dc84e57c65
|
|
@ -1 +1 @@
|
||||||
Subproject commit 6675317107257c2cc16c947b359d557821d85bf2
|
Subproject commit 111397c71a5f1c2c88e05da9c84edfdba2e472a4
|
|
@ -187,34 +187,85 @@ namespace blt::gfx
|
||||||
pre_reset();
|
pre_reset();
|
||||||
const f32 denominator = 1.0f / (draw.z_max - draw.z_min);
|
const f32 denominator = 1.0f / (draw.z_max - draw.z_min);
|
||||||
|
|
||||||
square_shader->bind();
|
glEnable(GL_STENCIL_TEST);
|
||||||
|
glClear(GL_STENCIL_BUFFER_BIT);
|
||||||
|
glStencilOp(GL_KEEP, GL_KEEP, GL_REPLACE);
|
||||||
|
glStencilMask(0xFF);
|
||||||
|
|
||||||
|
glStencilFunc(GL_ALWAYS, 1, 0xFF);
|
||||||
|
draw_points(false, denominator);
|
||||||
|
glStencilFunc(GL_NOTEQUAL, 1, 0xFF);
|
||||||
|
glStencilMask(0x00);
|
||||||
|
glDisable(GL_DEPTH_TEST);
|
||||||
|
draw_points(true, denominator);
|
||||||
|
glEnable(GL_DEPTH_TEST);
|
||||||
|
|
||||||
|
draw_rectangles(false, denominator);
|
||||||
|
draw_lines(false, denominator);
|
||||||
|
|
||||||
|
glDisable(GL_STENCIL_TEST);
|
||||||
|
|
||||||
|
post_reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
void batch_renderer_2d::render_reset()
|
||||||
|
{
|
||||||
|
draw.z_min = std::numeric_limits<f32>::max();
|
||||||
|
draw.z_max = std::numeric_limits<f32>::min();
|
||||||
|
}
|
||||||
|
|
||||||
|
void batch_renderer_2d::pre_reset()
|
||||||
|
{
|
||||||
|
draw.draw_count = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void batch_renderer_2d::post_reset()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void batch_renderer_2d::draw_points(const bool outlined, const f32 denominator)
|
||||||
|
{
|
||||||
|
point_shader->bind();
|
||||||
square_vao->bind();
|
square_vao->bind();
|
||||||
for (auto& [texture, objects] : draw.complex_rectangles)
|
for (auto& [texture, objects] : draw.complex_points)
|
||||||
{
|
{
|
||||||
// resource manager handles the check for empty string
|
// resource manager handles the check for empty string
|
||||||
if (auto val = resources.get(texture))
|
if (auto val = resources.get(texture))
|
||||||
val.value()->bind();
|
val.value()->bind();
|
||||||
for (auto& [render_info, object] : objects)
|
for (auto& [render_info, object] : objects)
|
||||||
{
|
{
|
||||||
auto& [z_index, rect] = object;
|
auto& [z_index, point] = object;
|
||||||
|
|
||||||
mat4x4 model;
|
mat4x4 model;
|
||||||
model.translate(rect.pos.x(), rect.pos.y(), 0.0f);
|
model.translate(point.pos.x(), point.pos.y(), 0.0f);
|
||||||
model.scale(rect.size.x(), rect.size.y(), 1);
|
if (outlined)
|
||||||
if (rect.rotation != 0)
|
{
|
||||||
model.rotateZ(toRadians(rect.rotation));
|
BLT_TRACE(render_info.outline_thickness);
|
||||||
|
model.scale(point.scale * render_info.outline_thickness, point.scale * render_info.outline_thickness, 1.0);
|
||||||
|
point_shader->setVec4("color", render_info.outline_color);
|
||||||
|
point_shader->setVec4("use_texture", blt::vec4{0,0,0,0});
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
model.scale(point.scale, point.scale, 1.0);
|
||||||
|
point_shader->setVec4("color", render_info.color);
|
||||||
|
point_shader->setVec4("use_texture", render_info.blend);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
point_shader->setVec4("outline_color", render_info.outline_color);
|
||||||
|
point_shader->setFloat("z_index", (z_index - draw.z_min) * denominator);
|
||||||
|
point_shader->setMatrix("model", model);
|
||||||
|
|
||||||
square_shader->setVec4("color", render_info.color);
|
|
||||||
square_shader->setVec4("use_texture", render_info.blend);
|
|
||||||
square_shader->setVec4("outline_color", render_info.outline_color);
|
|
||||||
square_shader->setFloat("z_index", (z_index - draw.z_min) * denominator);
|
|
||||||
square_shader->setMatrix("model", model);
|
|
||||||
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
||||||
draw.draw_count++;
|
draw.draw_count++;
|
||||||
}
|
}
|
||||||
objects.clear();
|
objects.clear();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void batch_renderer_2d::draw_lines(bool outlined, const f32 denominator)
|
||||||
|
{
|
||||||
mat4x4 empty_model;
|
mat4x4 empty_model;
|
||||||
square_shader->setMatrix("model", empty_model);
|
square_shader->setMatrix("model", empty_model);
|
||||||
line_vao->bind();
|
line_vao->bind();
|
||||||
|
@ -267,50 +318,47 @@ namespace blt::gfx
|
||||||
}
|
}
|
||||||
objects.clear();
|
objects.clear();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
point_shader->bind();
|
|
||||||
|
void batch_renderer_2d::draw_rectangles(bool outlined, const f32 denominator)
|
||||||
|
{
|
||||||
|
square_shader->bind();
|
||||||
square_vao->bind();
|
square_vao->bind();
|
||||||
for (auto& [texture, objects] : draw.complex_points)
|
for (auto& [texture, objects] : draw.complex_rectangles)
|
||||||
{
|
{
|
||||||
// resource manager handles the check for empty string
|
// resource manager handles the check for empty string
|
||||||
if (auto val = resources.get(texture))
|
if (auto val = resources.get(texture))
|
||||||
val.value()->bind();
|
val.value()->bind();
|
||||||
for (auto& [render_info, object] : objects)
|
for (auto& [render_info, object] : objects)
|
||||||
{
|
{
|
||||||
auto& [z_index, point] = object;
|
auto& [z_index, rect] = object;
|
||||||
|
|
||||||
mat4x4 model;
|
mat4x4 model;
|
||||||
model.translate(point.pos.x(), point.pos.y(), 0.0f);
|
if (outlined) {
|
||||||
model.scale(point.scale, point.scale, 1.0);
|
auto nsx = rect.size.x() * render_info.outline_thickness;
|
||||||
|
auto nsy = rect.size.y() * render_info.outline_thickness;
|
||||||
point_shader->setVec4("color", render_info.color);
|
auto ns = blt::vec2(nsx, nsy);
|
||||||
point_shader->setVec4("use_texture", render_info.blend);
|
auto s = (rect.size - ns) / 2.0f;
|
||||||
point_shader->setVec4("outline_color", render_info.outline_color);
|
model.translate(rect.pos - s);
|
||||||
point_shader->setFloat("z_index", (z_index - draw.z_min) * denominator);
|
model.scale(ns);
|
||||||
point_shader->setMatrix("model", model);
|
square_shader->setVec4("color", render_info.outline_color);
|
||||||
|
square_shader->setVec4("use_texture", {0,0,0,0});
|
||||||
|
} else {
|
||||||
|
model.translate(rect.pos);
|
||||||
|
model.scale(rect.size);
|
||||||
|
square_shader->setVec4("color", render_info.color);
|
||||||
|
square_shader->setVec4("use_texture", render_info.blend);
|
||||||
|
}
|
||||||
|
if (rect.rotation != 0)
|
||||||
|
model.rotateZ(toRadians(rect.rotation));
|
||||||
|
|
||||||
|
square_shader->setVec4("outline_color", render_info.outline_color);
|
||||||
|
square_shader->setFloat("z_index", (z_index - draw.z_min) * denominator);
|
||||||
|
square_shader->setMatrix("model", model);
|
||||||
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
||||||
draw.draw_count++;
|
draw.draw_count++;
|
||||||
}
|
}
|
||||||
objects.clear();
|
objects.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
post_reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
void batch_renderer_2d::render_reset()
|
|
||||||
{
|
|
||||||
draw.z_min = std::numeric_limits<f32>::max();
|
|
||||||
draw.z_max = std::numeric_limits<f32>::min();
|
|
||||||
}
|
|
||||||
|
|
||||||
void batch_renderer_2d::pre_reset()
|
|
||||||
{
|
|
||||||
draw.draw_count = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void batch_renderer_2d::post_reset()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue