Fixes incorrectly joining batch items from earlier z_index layers
Batching across z_index layers was not preserving the batch_break flag, which determines whether to not join the previous item. This is fixed by storing the flag in RenderItemState and preserving it across canvas_render_items calls.
This commit is contained in:
parent
cb1366f006
commit
a9ae0fac86
2 changed files with 10 additions and 4 deletions
|
@ -1620,7 +1620,8 @@ void RasterizerCanvasGLES2::join_items(Item *p_item_list, int p_z) {
|
|||
|
||||
// join is whether to join to the previous batch.
|
||||
// batch_break is whether to PREVENT the next batch from joining with us
|
||||
bool batch_break = false;
|
||||
// batch_break must be preserved over z_indices,
|
||||
// so is stored in _render_item_state.join_batch_break
|
||||
|
||||
while (p_item_list) {
|
||||
|
||||
|
@ -1628,7 +1629,7 @@ void RasterizerCanvasGLES2::join_items(Item *p_item_list, int p_z) {
|
|||
|
||||
bool join;
|
||||
|
||||
if (batch_break) {
|
||||
if (_render_item_state.join_batch_break) {
|
||||
// always start a new batch for this item
|
||||
join = false;
|
||||
|
||||
|
@ -1637,9 +1638,9 @@ void RasterizerCanvasGLES2::join_items(Item *p_item_list, int p_z) {
|
|||
// even though we know join is false.
|
||||
// also we need to run try_join_item for every item because it keeps the state up to date,
|
||||
// if we didn't run it the state would be out of date.
|
||||
try_join_item(ci, _render_item_state, batch_break);
|
||||
try_join_item(ci, _render_item_state, _render_item_state.join_batch_break);
|
||||
} else {
|
||||
join = try_join_item(ci, _render_item_state, batch_break);
|
||||
join = try_join_item(ci, _render_item_state, _render_item_state.join_batch_break);
|
||||
}
|
||||
|
||||
// assume the first item will always return no join
|
||||
|
@ -1720,6 +1721,10 @@ void RasterizerCanvasGLES2::canvas_render_items_begin(const Color &p_modulate, L
|
|||
_render_item_state.item_group_modulate = p_modulate;
|
||||
_render_item_state.item_group_light = p_light;
|
||||
_render_item_state.item_group_base_transform = p_base_transform;
|
||||
|
||||
// batch break must be preserved over the different z indices,
|
||||
// to prevent joining to an item on a previous index if not allowed
|
||||
_render_item_state.join_batch_break = false;
|
||||
}
|
||||
|
||||
void RasterizerCanvasGLES2::canvas_render_items_end() {
|
||||
|
|
|
@ -200,6 +200,7 @@ class RasterizerCanvasGLES2 : public RasterizerCanvasBaseGLES2 {
|
|||
|
||||
// used for joining items only
|
||||
BItemJoined *joined_item;
|
||||
bool join_batch_break;
|
||||
|
||||
// 'item group' is data over a single call to canvas_render_items
|
||||
int item_group_z;
|
||||
|
|
Loading…
Reference in a new issue