X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Ftext_object.cpp;h=8f70da822ca537079cf2eb4975b8d5b64d5f4b1e;hb=75acd4b141f45e851a492f089aa9ad24a9552409;hp=5fbd47f0fc9086d444a81355b78cec686863ad47;hpb=07ddaed2a657e4d2a3d038fed223fc5827159caf;p=supertux.git diff --git a/src/object/text_object.cpp b/src/object/text_object.cpp index 5fbd47f0f..8f70da822 100644 --- a/src/object/text_object.cpp +++ b/src/object/text_object.cpp @@ -23,14 +23,17 @@ #include #include "resources.hpp" +#include "main.hpp" #include "video/drawing_context.hpp" -#include "scripting/wrapper_util.hpp" +#include "scripting/squirrel_util.hpp" #include "log.hpp" -TextObject::TextObject() - : fading(0), fadetime(0), visible(false) +TextObject::TextObject(std::string name) + : fading(0), fadetime(0), visible(false), anchor(ANCHOR_MIDDLE), + pos(0, 0) { - font = blue_text; + this->name = name; + font = normal_font; centered = false; } @@ -39,35 +42,35 @@ TextObject::~TextObject() } void -TextObject::expose(HSQUIRRELVM vm, int table_idx) +TextObject::expose(HSQUIRRELVM vm, SQInteger table_idx) { - Scripting::Text* interface = static_cast (this); - Scripting::expose_object(vm, table_idx, interface, "Text", false); + if (name.empty()) + return; + + Scripting::expose_object(vm, table_idx, dynamic_cast(this), name, false); } void -TextObject::unexpose(HSQUIRRELVM vm, int table_idx) +TextObject::unexpose(HSQUIRRELVM vm, SQInteger table_idx) { - Scripting::unexpose_object(vm, table_idx, "Text"); + if (name.empty()) + return; + + Scripting::unexpose_object(vm, table_idx, name); } void TextObject::set_font(const std::string& name) { - if(name == "gold") { - font = gold_text; - } else if(name == "white") { - font = white_text; - } else if(name == "blue") { - font = blue_text; - } else if(name == "gray") { - font = gray_text; + if(name == "normal") { + font = normal_font; } else if(name == "big") { - font = white_big_text; + font = big_font; } else if(name == "small") { - font = white_small_text; + font = small_font; } else { log_warning << "Unknown font '" << name << "'." << std::endl; + font = normal_font; } } @@ -118,12 +121,18 @@ TextObject::draw(DrawingContext& context) return; } - context.draw_filled_rect(Vector(125, 50), Vector(550, 120), - Color(0.6, 0.7, 0.8, 0.5), LAYER_GUI-50); + float width = 500; + float height = 70; + Vector spos = pos + get_anchor_pos(Rect(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT), + width, height, anchor); + + context.draw_filled_rect(spos, Vector(width, height), + Color(0.6f, 0.7f, 0.8f, 0.5f), LAYER_GUI-50); if (centered) { - context.draw_center_text(font, text, Vector(0, 50+35), LAYER_GUI-40); + context.draw_center_text(font, text, spos, LAYER_GUI-40, TextObject::default_color); + } else { + context.draw_text(font, text, spos + Vector(10, 10), ALIGN_LEFT, LAYER_GUI-40, TextObject::default_color); } - else context.draw_text(font, text, Vector(125+35, 50+35), LEFT_ALLIGN, LAYER_GUI-40); context.pop_transform(); } @@ -145,4 +154,3 @@ TextObject::update(float elapsed_time) } } } -