diff options
author | Adrian Kummerlaender | 2021-05-17 00:15:33 +0200 |
---|---|---|
committer | Adrian Kummerlaender | 2021-05-17 00:15:33 +0200 |
commit | 4ec94c97879aafef15f7663135745e4ba61e62cf (patch) | |
tree | 322ae3f003892513f529842ff0b3fd100573b680 /tangle/util/noise.h | |
download | LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar.gz LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar.bz2 LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar.lz LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar.xz LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.tar.zst LiterateLB-4ec94c97879aafef15f7663135745e4ba61e62cf.zip |
Extract first public LiterateLB version
Diffstat (limited to 'tangle/util/noise.h')
-rw-r--r-- | tangle/util/noise.h | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/tangle/util/noise.h b/tangle/util/noise.h new file mode 100644 index 0000000..22ad548 --- /dev/null +++ b/tangle/util/noise.h @@ -0,0 +1,39 @@ +#pragma once +#include "assets.h" +#include "texture.h" + +#include <imgui.h> +#include <imgui-SFML.h> +#include <SFML/Graphics.hpp> + +struct NoiseSource { + const assets::File* current; + sf::Texture texture; + + NoiseSource(cudaSurfaceObject_t& noise) { + current = &assets::noise::files[0]; + texture.loadFromMemory(current->data, current->size); + noise = bindTextureToCuda(texture); + } + + void interact(); +}; + +void NoiseSource::interact() { + ImGui::Image(texture, sf::Vector2f(32,20)); + ImGui::SameLine(); + if (ImGui::BeginCombo("Noise", current->name.c_str())) { + for (unsigned i=0; i < assets::noise::file_count; ++i) { + bool is_selected = (current == &assets::noise::files[i]); + if (ImGui::Selectable(assets::noise::files[i].name.c_str(), is_selected)) { + current = &assets::noise::files[i]; + texture.loadFromMemory(current->data, current->size); + break; + } + if (is_selected) { + ImGui::SetItemDefaultFocus(); + } + } + ImGui::EndCombo(); + } +} |