Merge branch 'main' into res-directories
This commit is contained in:
commit
be416ad9e7
@ -52,20 +52,23 @@ shared_ptr<UINode> create_main_menu_panel(Engine* engine) {
|
|||||||
|
|
||||||
Panel* worldsPanel = new Panel(vec2(390, 200), vec4(5.0f));
|
Panel* worldsPanel = new Panel(vec2(390, 200), vec4(5.0f));
|
||||||
worldsPanel->color(vec4(0.1f));
|
worldsPanel->color(vec4(0.1f));
|
||||||
for (auto const& entry : directory_iterator(enginefs::get_worlds_folder())) {
|
path worldsFolder = enginefs::get_worlds_folder();
|
||||||
string name = entry.path().filename().string();
|
if (std::filesystem::is_directory(worldsFolder)) {
|
||||||
Button* button = new Button(util::str2wstr_utf8(name),
|
for (auto const& entry : directory_iterator(worldsFolder)) {
|
||||||
vec4(10.0f, 8.0f, 10.0f, 8.0f));
|
string name = entry.path().filename().string();
|
||||||
button->color(vec4(0.5f));
|
Button* button = new Button(util::str2wstr_utf8(name),
|
||||||
button->listenAction([engine, panel, name](GUI*) {
|
vec4(10.0f, 8.0f, 10.0f, 8.0f));
|
||||||
EngineSettings& settings = engine->getSettings();
|
button->color(vec4(0.5f));
|
||||||
|
button->listenAction([engine, panel, name](GUI*) {
|
||||||
|
EngineSettings& settings = engine->getSettings();
|
||||||
|
|
||||||
auto folder = enginefs::get_worlds_folder()/u8path(name);
|
auto folder = enginefs::get_worlds_folder()/u8path(name);
|
||||||
World* world = new World(name, folder, 42, settings);
|
World* world = new World(name, folder, 42, settings);
|
||||||
auto screen = new LevelScreen(engine, world->load(settings));
|
auto screen = new LevelScreen(engine, world->load(settings));
|
||||||
engine->setScreen(shared_ptr<Screen>(screen));
|
engine->setScreen(shared_ptr<Screen>(screen));
|
||||||
});
|
});
|
||||||
worldsPanel->add(button);
|
worldsPanel->add(button);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
panel->add(worldsPanel);
|
panel->add(worldsPanel);
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user