Merge remote-tracking branch 'upstream/master' into pair_symbols_tool

This commit is contained in:
jonyrock
2014-05-01 20:15:28 +04:00
1282 changed files with 468897 additions and 2817 deletions

View File

@ -26,47 +26,69 @@
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
#include "progress_bar.h"
Size2 ProgressBar::get_minimum_size() const {
Ref<StyleBox> bg = get_stylebox("bg");
Ref<Font> font = get_font("font");
Size2 ms=bg->get_minimum_size()+bg->get_center_size();
ms.height=MAX(ms.height,bg->get_minimum_size().height+font->get_height());
return ms;
}
void ProgressBar::_notification(int p_what) {
if (p_what==NOTIFICATION_DRAW) {
Ref<StyleBox> bg = get_stylebox("bg");
Ref<StyleBox> fg = get_stylebox("fg");
Ref<Font> font = get_font("font");
Color font_color=get_color("font_color");
Color font_color_shadow=get_color("font_color_shadow");
draw_style_box(bg,Rect2(Point2(),get_size()));
float r = get_unit_value();
int mp = fg->get_minimum_size().width;
int p = r*get_size().width-mp;
if (p>0) {
draw_style_box(fg,Rect2(Point2(),Size2(p+fg->get_minimum_size().width,get_size().height)));
}
int fh=font->get_height();
String txt=itos(int(get_unit_value()*100))+"%";
font->draw_halign(get_canvas_item(),Point2(0,font->get_ascent()+(get_size().height-font->get_height())/2),HALIGN_CENTER,get_size().width,txt,font_color);
}
}
ProgressBar::ProgressBar() {
set_v_size_flags(0);
}
#include "progress_bar.h"
Size2 ProgressBar::get_minimum_size() const {
Ref<StyleBox> bg = get_stylebox("bg");
Ref<Font> font = get_font("font");
Size2 ms=bg->get_minimum_size()+bg->get_center_size();
ms.height=MAX(ms.height,bg->get_minimum_size().height+font->get_height());
return ms;
}
void ProgressBar::_notification(int p_what) {
if (p_what==NOTIFICATION_DRAW) {
Ref<StyleBox> bg = get_stylebox("bg");
Ref<StyleBox> fg = get_stylebox("fg");
Ref<Font> font = get_font("font");
Color font_color=get_color("font_color");
Color font_color_shadow=get_color("font_color_shadow");
draw_style_box(bg,Rect2(Point2(),get_size()));
float r = get_unit_value();
int mp = fg->get_minimum_size().width;
int p = r*get_size().width-mp;
if (p>0) {
draw_style_box(fg,Rect2(Point2(),Size2(p+fg->get_minimum_size().width,get_size().height)));
}
if (percent_visible) {
int fh=font->get_height();
String txt=itos(int(get_unit_value()*100))+"%";
font->draw_halign(get_canvas_item(),Point2(0,font->get_ascent()+(get_size().height-font->get_height())/2),HALIGN_CENTER,get_size().width,txt,font_color);
}
}
}
void ProgressBar::set_percent_visible(bool p_visible) {
percent_visible=p_visible;
update();
}
bool ProgressBar::is_percent_visible() const{
return percent_visible;
}
void ProgressBar::_bind_methods() {
ObjectTypeDB::bind_method(_MD("set_percent_visible","visible"),&ProgressBar::set_percent_visible);
ObjectTypeDB::bind_method(_MD("is_percent_visible"),&ProgressBar::is_percent_visible);
ADD_PROPERTY(PropertyInfo(Variant::BOOL,"percent/visible"),_SCS("set_percent_visible"),_SCS("is_percent_visible"));
}
ProgressBar::ProgressBar() {
set_v_size_flags(0);
percent_visible=true;
}

View File

@ -26,22 +26,27 @@
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
#ifndef PROGRESS_BAR_H
#define PROGRESS_BAR_H
#include "scene/gui/range.h"
class ProgressBar : public Range {
OBJ_TYPE( ProgressBar, Range );
protected:
void _notification(int p_what);
public:
Size2 get_minimum_size() const;
ProgressBar();
};
#endif // PROGRESS_BAR_H
#ifndef PROGRESS_BAR_H
#define PROGRESS_BAR_H
#include "scene/gui/range.h"
class ProgressBar : public Range {
OBJ_TYPE( ProgressBar, Range );
bool percent_visible;
protected:
void _notification(int p_what);
static void _bind_methods();
public:
void set_percent_visible(bool p_visible);
bool is_percent_visible() const;
Size2 get_minimum_size() const;
ProgressBar();
};
#endif // PROGRESS_BAR_H

View File

@ -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);

View File

@ -225,7 +225,10 @@ public:
virtual void set_flags(uint32_t p_flags);
virtual uint32_t get_flags() const;
void add_piece(const Point2& p_offset,const Ref<Texture>& p_texture);
int add_piece(const Point2& p_offset,const Ref<Texture>& p_texture);
void set_piece_offset(int p_idx, const Point2& p_offset);
void set_piece_texture(int p_idx, const Ref<Texture>& p_texture);
void set_size(const Size2& p_size);
void clear();