diff options
author | jonyrock <ilms@live.ru> | 2014-05-01 20:15:28 +0400 |
---|---|---|
committer | jonyrock <ilms@live.ru> | 2014-05-01 20:15:28 +0400 |
commit | 209eaf6fa06eba8a05e5222bdab418cd0f20c91c (patch) | |
tree | 94eac56be6ad254a7c09e13d5e14bd843626232c /scene/resources/texture.cpp | |
parent | 34aea718b11e105d30c938ad34e474b1bd8b5d63 (diff) | |
parent | 6572d5128856b2ec55a2c417c92e584899f4906f (diff) |
Merge remote-tracking branch 'upstream/master' into pair_symbols_tool
Diffstat (limited to 'scene/resources/texture.cpp')
-rw-r--r-- | scene/resources/texture.cpp | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/scene/resources/texture.cpp b/scene/resources/texture.cpp index be3b921bad..baf6fa9d8d 100644 --- a/scene/resources/texture.cpp +++ b/scene/resources/texture.cpp @@ -648,15 +648,31 @@ uint32_t LargeTexture::get_flags() const{ } -void LargeTexture::add_piece(const Point2& p_offset,const Ref<Texture>& p_texture) { +int LargeTexture::add_piece(const Point2& p_offset,const Ref<Texture>& p_texture) { - ERR_FAIL_COND(p_texture.is_null()); + ERR_FAIL_COND_V(p_texture.is_null(), -1); Piece p; p.offset=p_offset; p.texture=p_texture; pieces.push_back(p); + + return pieces.size() - 1; } +void LargeTexture::set_piece_offset(int p_idx, const Point2& p_offset) { + + ERR_FAIL_INDEX(p_idx, pieces.size()); + pieces[p_idx].offset = p_offset; +}; + +void LargeTexture::set_piece_texture(int p_idx, const Ref<Texture>& p_texture) { + + ERR_FAIL_INDEX(p_idx, pieces.size()); + pieces[p_idx].texture = p_texture; +}; + + + void LargeTexture::set_size(const Size2& p_size){ size=p_size; @@ -709,6 +725,8 @@ Ref<Texture> LargeTexture::get_piece_texture(int p_idx) const{ void LargeTexture::_bind_methods() { ObjectTypeDB::bind_method(_MD("add_piece","ofs","texture:Texture"),&LargeTexture::add_piece); + ObjectTypeDB::bind_method(_MD("set_piece_offset", "idx", "ofs"),&LargeTexture::set_piece_offset); + ObjectTypeDB::bind_method(_MD("set_piece_texture","idx", "texture:Texture"),&LargeTexture::set_piece_texture); ObjectTypeDB::bind_method(_MD("set_size","size"),&LargeTexture::set_size); ObjectTypeDB::bind_method(_MD("clear"),&LargeTexture::clear); |