summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsanikoyes <sanikoyes@163.com>2014-03-19 15:43:56 +0800
committersanikoyes <sanikoyes@163.com>2014-03-19 15:43:56 +0800
commit3037b3f6dcaea2de9de058d715a4e3dafc974039 (patch)
treee59db47e116a913aea9d4eef4d69a42876b0bea9
parente20e3c9525c2f0d5bb95e85138a8d88a0088d439 (diff)
fix render sprite used atlas texture position error
-rw-r--r--scene/resources/texture.cpp22
1 files changed, 19 insertions, 3 deletions
diff --git a/scene/resources/texture.cpp b/scene/resources/texture.cpp
index e5ac674784..8dbb73e23d 100644
--- a/scene/resources/texture.cpp
+++ b/scene/resources/texture.cpp
@@ -581,9 +581,25 @@ void AtlasTexture::draw_rect_region(RID p_canvas_item,const Rect2& p_rect, const
Vector2 scale = p_rect.size / p_src_rect.size;
- Rect2 dr( p_rect.pos+ofs*scale,src_c.size*scale );
-
- VS::get_singleton()->canvas_item_add_texture_rect_region(p_canvas_item,dr,atlas->get_rid(),src_c,p_modulate);
+ if(scale.x >= 0 && scale.y >= 0)
+ {
+ Rect2 dr(src_c.size*scale,p_rect.pos+ofs*scale);
+ VS::get_singleton()->canvas_item_add_texture_rect_region(p_canvas_item,dr,atlas->get_rid(),src_c,p_modulate);
+ }
+ else
+ {
+ Rect2 dr(Point2i(),src_c.size*scale);
+ if(scale.x > 0)
+ dr.pos.x = p_rect.pos.x+ofs.x*scale.x;
+ else
+ dr.pos.x = p_rect.pos.x-(margin.size.width-margin.pos.x)*scale.x;
+ if(scale.y > 0)
+ dr.pos.y = p_rect.pos.y+ofs.y*scale.y;
+ else
+ dr.pos.y = p_rect.pos.y-(margin.size.height-margin.pos.y)*scale.y;
+
+ VS::get_singleton()->canvas_item_add_texture_rect_region(p_canvas_item,dr,atlas->get_rid(),src_c,p_modulate);
+ }
}