fix atlas texture algo
This commit is contained in:
parent
bc4e37b132
commit
61179e82c7
|
@ -580,27 +580,22 @@ void AtlasTexture::draw_rect_region(RID p_canvas_item,const Rect2& p_rect, const
|
||||||
Vector2 ofs = (src_c.pos-src.pos);
|
Vector2 ofs = (src_c.pos-src.pos);
|
||||||
|
|
||||||
Vector2 scale = p_rect.size / p_src_rect.size;
|
Vector2 scale = p_rect.size / p_src_rect.size;
|
||||||
|
if(scale.x < 0)
|
||||||
if(scale.x >= 0 && scale.y >= 0)
|
|
||||||
{
|
{
|
||||||
|
float mx = (margin.size.width - margin.pos.x);
|
||||||
|
mx -= margin.pos.x;
|
||||||
|
ofs.x = -(ofs.x + mx);
|
||||||
|
}
|
||||||
|
if(scale.y < 0)
|
||||||
|
{
|
||||||
|
float my = margin.size.height - margin.pos.y;
|
||||||
|
my -= margin.pos.y;
|
||||||
|
ofs.y = -(ofs.y + my);
|
||||||
|
}
|
||||||
Rect2 dr( p_rect.pos+ofs*scale,src_c.size*scale );
|
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);
|
|
||||||
}
|
|
||||||
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);
|
VS::get_singleton()->canvas_item_add_texture_rect_region(p_canvas_item,dr,atlas->get_rid(),src_c,p_modulate);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
AtlasTexture::AtlasTexture() {
|
AtlasTexture::AtlasTexture() {
|
||||||
|
|
Loading…
Reference in New Issue