]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/resources.cpp
Rework how widget ownership works in Container
[libs/gltk.git] / source / resources.cpp
index b7586e886ee41df0eb711230c1ebe4bfcba8402c..dc678a9480d74aa276039d65b5b0b5cf1c0ed8d5 100644 (file)
@@ -1,4 +1,6 @@
 #include <msp/fs/utils.h>
+#include <msp/strings/regex.h>
+#include <msp/strings/utils.h>
 #include "resources.h"
 
 using namespace std;
@@ -6,12 +8,25 @@ using namespace std;
 namespace Msp {
 namespace GLtk {
 
-Resources::Resources():
-       default_font(0)
+Resources::Resources()
 {
        add_type<Graphic>().keyword("graphic");
-       add_type<GL::Texture2D>().keyword("texture");
+       add_type<GL::Module>().creator([this](const string &n){ return create_module(n); });
+       add_type<GL::Sampler>().creator([this](const string &n){ return create_sampler(n); });
+       add_type<GL::Program>().creator([this](const string &n){ return create_program(n); });
+       add_type<GL::Texture2D>().keyword("texture").creator([this](const string &n){ return create_texture(n); });
        add_type<GL::Font>().keyword("font");
+       add_type<Style>().keyword("style");
+}
+
+Resources::Resources(const FS::Path &fn):
+       Resources()
+{
+       dir_src = make_unique<DataFile::DirectorySource>();
+       dir_src->add_directory(FS::dirname(fn));
+       add_source(*dir_src);
+
+       DataFile::load(*this, fn.str());
 }
 
 const GL::Font &Resources::get_default_font() const
@@ -22,6 +37,65 @@ const GL::Font &Resources::get_default_font() const
        return *default_font;
 }
 
+GL::Module *Resources::create_module(const string &name)
+{
+       if(name!="ui.glsl")
+               return nullptr;
+
+       unique_ptr<GL::Module> mod;
+       if(GL::get_backend_api()==GL::VULKAN)
+               mod = make_unique<GL::SpirVModule>();
+       else
+               mod = make_unique<GL::GlslModule>();
+
+       mod->set_source("import msp_interface; import common;\n"
+               "uniform sampler2D ui_tex;\n"
+               "#pragma MSP stage(fragment)\n"
+               "void main() { frag_color = texture(ui_tex, texcoord.xy)*color; }\n");
+
+       return mod.release();
+}
+
+GL::Program *Resources::create_program(const string &name)
+{
+       if(name!="ui.shader")
+               return nullptr;
+
+       return new GL::Program(get<GL::Module>("ui.glsl"));
+}
+
+GL::Sampler *Resources::create_sampler(const string &name)
+{
+       static const Regex r_name("^(linear|nearest)_clamp.samp$");
+       if(RegMatch m = r_name.match(name))
+       {
+               unique_ptr<GL::Sampler> sampler = make_unique<GL::Sampler>();
+               sampler->set_filter(lexical_cast<GL::TextureFilter>(toupper(m.group(1).str)));
+               sampler->set_wrap(GL::CLAMP_TO_EDGE);
+               return sampler.release();
+       }
+
+       return nullptr;
+}
+
+GL::Texture2D *Resources::create_texture(const string &name)
+{
+       string ext = FS::extpart(name);
+       if(ext==".png" || ext==".jpg")
+               if(auto io = unique_ptr<IO::Seekable>(open_raw(name)))
+               {
+                       Graphics::Image image;
+                       image.load_io(*io);
+                       io.reset();
+
+                       unique_ptr<GL::Texture2D> tex = make_unique<GL::Texture2D>();
+                       tex->image(image);
+                       return tex.release();
+               }
+
+       return nullptr;
+}
+
 
 Resources::Loader::Loader(Resources &r):
        Collection::Loader(r),
@@ -29,7 +103,6 @@ Resources::Loader::Loader(Resources &r):
 {
        add("default_font", &Loader::default_font);
        add("font", &Loader::font);
-       add("style", &Loader::style);
 }
 
 void Resources::Loader::default_font(const string &name)
@@ -39,7 +112,7 @@ void Resources::Loader::default_font(const string &name)
 
 void Resources::Loader::font(const string &name)
 {
-       RefPtr<GL::Font> fnt = new GL::Font;
+       unique_ptr<GL::Font> fnt = make_unique<GL::Font>();
        load_sub(*fnt, res);
        res.add(name, fnt.get());
        if(!res.default_font)
@@ -47,13 +120,5 @@ void Resources::Loader::font(const string &name)
        fnt.release();
 }
 
-void Resources::Loader::style(const string &name)
-{
-       RefPtr<Style> stl = new Style(res);
-       load_sub(*stl, res);
-       res.add(name, stl.get());
-       stl.release();
-}
-
 } // namespace GLtk
 } // namespace Msp