Correctly flip texture src region
This commit is contained in:
parent
f9e9cc94cd
commit
f73e1fae37
2 changed files with 12 additions and 1 deletions
|
@ -925,7 +925,7 @@ void ItemList::_notification(int p_what) {
|
||||||
current_columns = max_columns;
|
current_columns = max_columns;
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
//repeat util all fits
|
//repeat until all fits
|
||||||
bool all_fit = true;
|
bool all_fit = true;
|
||||||
Vector2 ofs;
|
Vector2 ofs;
|
||||||
int col = 0;
|
int col = 0;
|
||||||
|
|
|
@ -680,11 +680,22 @@ void VisualServerCanvas::canvas_item_add_texture_rect_region(RID p_item, const R
|
||||||
rect->flags |= RasterizerCanvas::CANVAS_RECT_FLIP_H;
|
rect->flags |= RasterizerCanvas::CANVAS_RECT_FLIP_H;
|
||||||
rect->rect.size.x = -rect->rect.size.x;
|
rect->rect.size.x = -rect->rect.size.x;
|
||||||
}
|
}
|
||||||
|
if (p_src_rect.size.x < 0) {
|
||||||
|
|
||||||
|
rect->flags ^= RasterizerCanvas::CANVAS_RECT_FLIP_H;
|
||||||
|
rect->source.size.x = -rect->source.size.x;
|
||||||
|
}
|
||||||
if (p_rect.size.y < 0) {
|
if (p_rect.size.y < 0) {
|
||||||
|
|
||||||
rect->flags |= RasterizerCanvas::CANVAS_RECT_FLIP_V;
|
rect->flags |= RasterizerCanvas::CANVAS_RECT_FLIP_V;
|
||||||
rect->rect.size.y = -rect->rect.size.y;
|
rect->rect.size.y = -rect->rect.size.y;
|
||||||
}
|
}
|
||||||
|
if (p_src_rect.size.y < 0) {
|
||||||
|
|
||||||
|
rect->flags ^= RasterizerCanvas::CANVAS_RECT_FLIP_V;
|
||||||
|
rect->source.size.y = -rect->source.size.y;
|
||||||
|
}
|
||||||
|
|
||||||
if (p_transpose) {
|
if (p_transpose) {
|
||||||
rect->flags |= RasterizerCanvas::CANVAS_RECT_TRANSPOSE;
|
rect->flags |= RasterizerCanvas::CANVAS_RECT_TRANSPOSE;
|
||||||
SWAP(rect->rect.size.x, rect->rect.size.y);
|
SWAP(rect->rect.size.x, rect->rect.size.y);
|
||||||
|
|
Loading…
Reference in a new issue