X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fstyle.cpp;h=acbdff54febbda18dce5df7a7cc265fb16e2a647;hb=b4a3d651f57c46507aaa99a71a14fea15f0e430d;hp=0138ec2af1a20f401b262b2b7d1bffefeac2a6eb;hpb=2b70e8801c43875ed3f4135bdd0141265cff0312;p=libs%2Fgltk.git diff --git a/source/style.cpp b/source/style.cpp index 0138ec2..acbdff5 100644 --- a/source/style.cpp +++ b/source/style.cpp @@ -1,3 +1,4 @@ +#include #include "resources.h" #include "style.h" @@ -6,47 +7,106 @@ using namespace std; namespace Msp { namespace GLtk { -Style::Style(Resources &r): - font(&r.get_default_font()) +Style::Style(): + font(0), + font_size(0), + sampler(0) { } +const GL::Font &Style::get_font() const +{ + if(!font) + throw logic_error("!font"); + return *font; +} + +const GL::Color &Style::get_font_color(State s) const +{ + if(s>=N_STATES_) + throw invalid_argument("Style::get_font_color"); + + return font_color[s]; +} + +const GL::Sampler &Style::get_sampler() const +{ + if(!sampler) + throw logic_error("!sampler"); + return *sampler; +} + const Part *Style::get_part(const string &name) const { - for(PartSeq::const_iterator i=parts.begin(); i!=parts.end(); ++i) - if(i->get_name()==name) - return &*i; + auto i = find_if(parts, [&name](const Part &p){ return p.get_name()==name; }); + return (i!=parts.end() ? &*i : 0); +} + +bool Style::compare_states(State s1, State s2) const +{ + if(s1>=N_STATES_ || s2>=N_STATES_) + throw invalid_argument("Style::compare_states"); + + const GL::Color &c1 = font_color[s1]; + const GL::Color &c2 = font_color[s2]; + if(c1.r!=c2.r || c1.g!=c2.g || c1.b!=c2.b) + return true; + + for(const Part &p: parts) + if(p.get_graphic(s1)!=p.get_graphic(s2)) + return true; - return 0; + return false; } Style::Loader::Loader(Style &s, Resources &r): - style(s), - res(r) + DataFile::CollectionObjectLoader(s, &r) { - add("font", &Style::font); + if(!obj.font) + { + obj.font = &get_collection().get_default_font(); + obj.font_size = obj.font->get_native_size(); + } + if(!obj.sampler) + obj.sampler = &get_collection().get("linear_clamp.samp"); + + add("font", &Loader::font); + add("font_color", &Loader::font_color_normal); add("font_color", &Loader::font_color); - add("part", static_cast(&Loader::part)); - add("part", static_cast(&Loader::part)); - // Deprecated alias - add("special", static_cast(&Loader::part)); + add("font_size", &Style::font_size); + add("part", &Loader::part); + add("part", &Loader::unnamed_part); + add("sampler", &Style::sampler); } -void Style::Loader::font_color(float r, float g, float b) +void Style::Loader::font(const string &n) { - style.font_color = GL::Color(r, g, b); + obj.font = &get_collection().get(n); + obj.font_size = obj.font->get_native_size(); } -void Style::Loader::part() +void Style::Loader::font_color_normal(float r, float g, float b) { - part(string()); + font_color(NORMAL, r, g, b); +} + +void Style::Loader::font_color(State s, float r, float g, float b) +{ + for(unsigned i=0; i