resolve conflict
This commit is contained in:
parent
e34e38778e
commit
844d23b3fd
24
imgui.ini
24
imgui.ini
@ -1,24 +0,0 @@
|
|||||||
[Window][Debug##Default]
|
|
||||||
Pos=341,6
|
|
||||||
Size=400,400
|
|
||||||
Collapsed=0
|
|
||||||
|
|
||||||
[Window][viewport_container]
|
|
||||||
Size=1101,598
|
|
||||||
Collapsed=0
|
|
||||||
|
|
||||||
[Window][Editor]
|
|
||||||
Pos=33,52
|
|
||||||
Size=1118,634
|
|
||||||
Collapsed=0
|
|
||||||
|
|
||||||
[Window][Main]
|
|
||||||
Pos=0,0
|
|
||||||
Size=2560,1532
|
|
||||||
Collapsed=0
|
|
||||||
|
|
||||||
[Window][Help]
|
|
||||||
Pos=136,255
|
|
||||||
Size=177,114
|
|
||||||
Collapsed=0
|
|
||||||
|
|
80
main.cpp
80
main.cpp
@ -17,6 +17,7 @@
|
|||||||
#include "lib/backends/imgui_impl_sdl2.h"
|
#include "lib/backends/imgui_impl_sdl2.h"
|
||||||
#include "lib/imgui.h"
|
#include "lib/imgui.h"
|
||||||
#include "lib/imgui_internal.h"
|
#include "lib/imgui_internal.h"
|
||||||
|
#include <cstdint>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -52,14 +53,17 @@ struct Texture
|
|||||||
{
|
{
|
||||||
ImTextureID texture;
|
ImTextureID texture;
|
||||||
ImVec2 size;
|
ImVec2 size;
|
||||||
|
int channels;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static uint8_t* image = nullptr;
|
||||||
|
|
||||||
Texture LoadTexture(const char * path)
|
Texture LoadTexture(const char * path)
|
||||||
{
|
{
|
||||||
const int channelCount = 4;
|
const int channelCount = 4;
|
||||||
int imageFileChannelCount;
|
int imageFileChannelCount;
|
||||||
int width, height;
|
int width, height;
|
||||||
uint8_t *image = (uint8_t *)stbi_load(path, &width, &height, &imageFileChannelCount, channelCount);
|
image = (uint8_t *)stbi_load(path, &width, &height, &imageFileChannelCount, channelCount);
|
||||||
if (image == NULL)
|
if (image == NULL)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s\nFailed to open %s\n", stbi_failure_reason(), path);
|
fprintf(stderr, "%s\nFailed to open %s\n", stbi_failure_reason(), path);
|
||||||
@ -78,11 +82,62 @@ Texture LoadTexture(const char * path)
|
|||||||
Texture t;
|
Texture t;
|
||||||
t.texture = (void*)(uintptr_t)(textureHandle);
|
t.texture = (void*)(uintptr_t)(textureHandle);
|
||||||
t.size = ImVec2((float)width,(float)height);
|
t.size = ImVec2((float)width,(float)height);
|
||||||
|
t.channels = channelCount;
|
||||||
|
|
||||||
stbi_image_free(image);
|
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Texture ReloadTexture(ImTextureID id, int width, int height) {
|
||||||
|
GLuint tid = (GLuint)(uintptr_t)id;
|
||||||
|
glDeleteTextures((GLsizei)1, &tid);
|
||||||
|
|
||||||
|
GLenum dataFormat = GL_RGBA;
|
||||||
|
GLuint textureHandle;
|
||||||
|
glGenTextures(1, &textureHandle);
|
||||||
|
glBindTexture(GL_TEXTURE_2D, textureHandle);
|
||||||
|
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
||||||
|
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||||
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, width, height, 0, dataFormat, GL_UNSIGNED_BYTE, image);
|
||||||
|
|
||||||
|
Texture t;
|
||||||
|
t.texture = (void*)(uintptr_t)(textureHandle);
|
||||||
|
t.size = ImVec2((float)width,(float)height);
|
||||||
|
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rotate90()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void RotateImage(Texture t) {
|
||||||
|
int height = t.size.y;
|
||||||
|
int width = t.size.x;
|
||||||
|
int channels = t.channels;
|
||||||
|
|
||||||
|
const unsigned int sizeBuffer = width * height * channels;
|
||||||
|
unsigned char *tempBuffer = new unsigned char[sizeBuffer];
|
||||||
|
|
||||||
|
|
||||||
|
int nidx = 0;
|
||||||
|
for (int x = 0; x < width; x++)
|
||||||
|
{
|
||||||
|
for (int y = height - 1; y >= 0; y--)
|
||||||
|
{
|
||||||
|
int idx = (x + y * width) * channels;
|
||||||
|
for (int i = 0; i < channels; i++)
|
||||||
|
tempBuffer[nidx + i] = image[idx + i];
|
||||||
|
|
||||||
|
nidx = nidx + 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy rotated pixels
|
||||||
|
|
||||||
|
memcpy(image, tempBuffer, sizeBuffer);
|
||||||
|
delete[] tempBuffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static bool init = true;
|
static bool init = true;
|
||||||
static bool showHelp = false;
|
static bool showHelp = false;
|
||||||
@ -99,7 +154,7 @@ int main(int argc, char* argv[]) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool TOOLTIP_ENABLED = false;
|
bool TOOLTIP_ENABLED = false;
|
||||||
bool GRID_ENABLED = true;
|
bool GRID_ENABLED = false;
|
||||||
bool AA_ENABLED = true;
|
bool AA_ENABLED = true;
|
||||||
|
|
||||||
// Decide GL+GLSL versions
|
// Decide GL+GLSL versions
|
||||||
@ -222,6 +277,10 @@ int main(int argc, char* argv[]) {
|
|||||||
case SDL_SCANCODE_D:
|
case SDL_SCANCODE_D:
|
||||||
mode = (mode + 1) % 5;
|
mode = (mode + 1) % 5;
|
||||||
break;
|
break;
|
||||||
|
case SDL_SCANCODE_R:
|
||||||
|
RotateImage(t);
|
||||||
|
t = ReloadTexture(t.texture, t.size.y, t.size.x);
|
||||||
|
break;
|
||||||
case SDL_SCANCODE_Q:
|
case SDL_SCANCODE_Q:
|
||||||
done = true;
|
done = true;
|
||||||
break;
|
break;
|
||||||
@ -317,12 +376,21 @@ int main(int argc, char* argv[]) {
|
|||||||
if (ImGui::BeginPopup("HelpPopup")) {
|
if (ImGui::BeginPopup("HelpPopup")) {
|
||||||
ImGui::Text("tview Help");
|
ImGui::Text("tview Help");
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
|
ImGui::Text("r - rotate 90 deg clockwise");
|
||||||
ImGui::Text("g - toggle grid");
|
ImGui::Text("g - toggle grid");
|
||||||
ImGui::Text("a - toggle filtering");
|
ImGui::Text("a - toggle filtering");
|
||||||
ImGui::Text("t - toggle tooltip");
|
ImGui::Text("t - toggle tooltip");
|
||||||
ImGui::Text("d - cycle pixel detail mode");
|
ImGui::Text("d - cycle pixel detail mode");
|
||||||
ImGui::Text("q - quit");
|
ImGui::Separator();
|
||||||
|
ImGui::Text("modes:");
|
||||||
|
ImGui::Text("\tOff");
|
||||||
|
ImGui::Text("\tGradient Arrow");
|
||||||
|
ImGui::Text("\tHex Code");
|
||||||
|
ImGui::Text("\tRGB Values");
|
||||||
|
ImGui::Text("\tFloat Values");
|
||||||
|
ImGui::Separator();
|
||||||
ImGui::Text("h - show help popup");
|
ImGui::Text("h - show help popup");
|
||||||
|
ImGui::Text("q - quit");
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
ImGui::Text("click anywhere to continue");
|
ImGui::Text("click anywhere to continue");
|
||||||
ImGui::EndPopup();
|
ImGui::EndPopup();
|
||||||
@ -339,6 +407,10 @@ int main(int argc, char* argv[]) {
|
|||||||
SDL_GL_SwapWindow(window);
|
SDL_GL_SwapWindow(window);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (image != nullptr) {
|
||||||
|
stbi_image_free(image);
|
||||||
|
}
|
||||||
|
|
||||||
// Cleanup
|
// Cleanup
|
||||||
ImGui_ImplOpenGL3_Shutdown();
|
ImGui_ImplOpenGL3_Shutdown();
|
||||||
ImGui_ImplSDL2_Shutdown();
|
ImGui_ImplSDL2_Shutdown();
|
||||||
|
Loading…
Reference in New Issue
Block a user