made the editor work by debugging on windows
This commit is contained in:
@@ -163,7 +163,7 @@ void TSE::Texture::SetChanels(const byte &ch)
|
||||
chanels = ch;
|
||||
}
|
||||
|
||||
uint TSE::Texture::GetTextureId() const
|
||||
TSE::uint TSE::Texture::GetTextureId() const
|
||||
{
|
||||
return TextureID;
|
||||
}
|
||||
|
||||
@@ -2,10 +2,10 @@
|
||||
|
||||
#include "BehaviourScriptRegistry.hpp"
|
||||
|
||||
TSE::EDITOR::EditorSubsystem::EditorSubsystem() : sv(nullptr), rt({10,10}), editorLayer("")
|
||||
TSE::EDITOR::EditorSubsystem::EditorSubsystem() : sv(nullptr), editorLayer("")
|
||||
{
|
||||
rt = TSE::GLFW::RenderTexture({100,100});
|
||||
sv = SceneView(&rt);
|
||||
rt = new TSE::GLFW::RenderTexture({100,100});
|
||||
sv = SceneView(rt);
|
||||
|
||||
controller.AddGuiElement("Scene", &sv);
|
||||
controller.AddGuiElement("Consol", &cv);
|
||||
@@ -27,7 +27,7 @@ TSE::EDITOR::EditorSubsystem::EditorSubsystem() : sv(nullptr), rt({10,10}), edit
|
||||
Transformable* editorCamera = new Transformable(".EditorCamera");
|
||||
|
||||
Camera* editorCam = new Camera();
|
||||
editorCam->SetRenderTarget(&rt);
|
||||
editorCam->SetRenderTarget(rt);
|
||||
editorCamera->AddBehaviourScript(editorCam);
|
||||
|
||||
// basicCameraControls controls = basicCameraControls();
|
||||
|
||||
@@ -20,7 +20,7 @@ namespace TSE::EDITOR
|
||||
HirearchieView hv = HirearchieView(nullptr);
|
||||
PropertiesView pv;
|
||||
CameraView camv;
|
||||
TSE::GLFW::RenderTexture rt;
|
||||
TSE::GLFW::RenderTexture* rt;
|
||||
SceneView sv;
|
||||
Layer editorLayer;
|
||||
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
#include "ViewportController.hpp"
|
||||
#include "imgui/imgui.h"
|
||||
|
||||
#include <chrono>
|
||||
|
||||
extern "C" {
|
||||
#include "tinyfiledialogs.h"
|
||||
|
||||
@@ -1,7 +1,9 @@
|
||||
#include "CameraView.hpp"
|
||||
|
||||
TSE::EDITOR::CameraView::CameraView() : GuiWindow("Camera", ImGuiWindowFlags_NoScrollWithMouse | ImGuiWindowFlags_NoCollapse | ImGuiWindowFlags_NoScrollbar)
|
||||
, fb({100,100}) { }
|
||||
{
|
||||
fb = new TSE::GLFW::RenderTexture({100,100});
|
||||
}
|
||||
|
||||
void TSE::EDITOR::CameraView::Define()
|
||||
{
|
||||
@@ -11,18 +13,17 @@ void TSE::EDITOR::CameraView::Define()
|
||||
currentCamera->SetRenderTarget(nullptr);
|
||||
currentCamera = Camera::mainCamera;
|
||||
if(currentCamera != nullptr)
|
||||
currentCamera->SetRenderTarget(&fb);
|
||||
currentCamera->SetRenderTarget(fb);
|
||||
}
|
||||
|
||||
ImGuiWindowFlags flags2 = ImGuiWindowFlags_NoScrollWithMouse | ImGuiWindowFlags_NoCollapse | ImGuiWindowFlags_NoScrollbar;
|
||||
if(ImGui::BeginChild("##SceneChild", {0,0}, ImGuiChildFlags_None, flags2))
|
||||
{
|
||||
float w = fb.width();
|
||||
ImGui::Image(fb.GetTextureId(), {fb.width(), fb.height()},{0,1}, {1,0});
|
||||
ImGui::Image(fb->GetTextureId(), {fb->width(), fb->height()},{0,1}, {1,0});
|
||||
auto vec2 = ImGui::GetWindowSize();
|
||||
if(fb.width() != vec2.x || fb.height() != vec2.y)
|
||||
if(fb->width() != vec2.x || fb->height() != vec2.y)
|
||||
{
|
||||
fb.SetSize({vec2.x, vec2.y});
|
||||
fb->SetSize({vec2.x, vec2.y});
|
||||
}
|
||||
}
|
||||
ImGui::EndChild();
|
||||
|
||||
@@ -10,7 +10,7 @@ namespace TSE::EDITOR
|
||||
{
|
||||
private:
|
||||
Camera* currentCamera = nullptr;
|
||||
TSE::GLFW::RenderTexture fb;
|
||||
TSE::GLFW::RenderTexture* fb;
|
||||
public:
|
||||
CameraView();
|
||||
void Define() override;
|
||||
|
||||
@@ -10,6 +10,8 @@
|
||||
#include "PathHelper.hpp"
|
||||
#include "elements/Texture.hpp"
|
||||
#include "TextureHelperOpenGL.hpp"
|
||||
#include "interfaces/IRenderer.hpp"
|
||||
#include "BehaviourScripts/Camera.hpp"
|
||||
|
||||
TSE::GLFW::OpenGLRenderingBackend::OpenGLRenderingBackend(Color _backgroundColor, bool _vsync)
|
||||
: OpenGLRenderingBackend(_backgroundColor, _vsync, 0, false){ }
|
||||
@@ -140,7 +142,13 @@ void TSE::GLFW::OpenGLRenderingBackend::onUpdate() const
|
||||
|
||||
void TSE::GLFW::OpenGLRenderingBackend::onClear() const
|
||||
{
|
||||
//cameras
|
||||
for (int i = 0; i < IRenderer::camerasToRenderWith.size(); i++)
|
||||
{
|
||||
IRenderer::camerasToRenderWith[i]->Bind();
|
||||
IRenderer::camerasToRenderWith[i]->UpdateRenderTarget();
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
IRenderer::camerasToRenderWith[i]->Unbind();
|
||||
}
|
||||
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
if(useseImGui)
|
||||
@@ -153,7 +161,12 @@ void TSE::GLFW::OpenGLRenderingBackend::onClear() const
|
||||
|
||||
void TSE::GLFW::OpenGLRenderingBackend::onClearDepthBuffer() const
|
||||
{
|
||||
//cameras
|
||||
for (int i = 0; i < IRenderer::camerasToRenderWith.size(); i++)
|
||||
{
|
||||
IRenderer::camerasToRenderWith[i]->Bind();
|
||||
glClear(GL_DEPTH_BUFFER_BIT);
|
||||
IRenderer::camerasToRenderWith[i]->Unbind();
|
||||
}
|
||||
|
||||
glClear(GL_DEPTH_BUFFER_BIT);
|
||||
}
|
||||
|
||||
@@ -25,7 +25,7 @@ float TSE::GLFW::RenderTexture::height() const
|
||||
return buffer.GetSize().y;
|
||||
}
|
||||
|
||||
uint TSE::GLFW::RenderTexture::GetTextureId() const
|
||||
TSE::uint TSE::GLFW::RenderTexture::GetTextureId() const
|
||||
{
|
||||
return buffer.GetTextureId();
|
||||
}
|
||||
|
||||
@@ -3,7 +3,8 @@
|
||||
|
||||
TSE::GLFW::FrameBuffer::FrameBuffer(const Vector2 &size)
|
||||
{
|
||||
this->size = size;
|
||||
width = size.x;
|
||||
height = size.y;
|
||||
CreateFBTexture();
|
||||
for (auto const& i : objectsToResize)
|
||||
{
|
||||
@@ -14,16 +15,12 @@ TSE::GLFW::FrameBuffer::FrameBuffer(const Vector2 &size)
|
||||
|
||||
void TSE::GLFW::FrameBuffer::Bind()
|
||||
{
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, depthRboID);
|
||||
glBindTexture(GL_TEXTURE_2D, textureID);
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, bufferID);
|
||||
}
|
||||
|
||||
void TSE::GLFW::FrameBuffer::Unbind()
|
||||
{
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||
glBindTexture(GL_TEXTURE_2D, 0);
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, 0);
|
||||
}
|
||||
|
||||
TSE::GLFW::FrameBuffer::~FrameBuffer()
|
||||
@@ -35,7 +32,8 @@ TSE::GLFW::FrameBuffer::~FrameBuffer()
|
||||
|
||||
void TSE::GLFW::FrameBuffer::Resize(Vector2 size)
|
||||
{
|
||||
this->size = size;
|
||||
width = size.x;
|
||||
height = size.y;
|
||||
shouldResize = true;
|
||||
}
|
||||
|
||||
@@ -46,7 +44,7 @@ void TSE::GLFW::FrameBuffer::Update()
|
||||
CreateFBTexture();
|
||||
for (auto const& i : objectsToResize)
|
||||
{
|
||||
i->OnResize(size.x, size.y, this);
|
||||
i->OnResize(width, height, this);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -57,7 +55,7 @@ TSE::uint TSE::GLFW::FrameBuffer::GetTextureId() const
|
||||
|
||||
TSE::Vector2 TSE::GLFW::FrameBuffer::GetSize() const
|
||||
{
|
||||
return size;
|
||||
return {width, height};
|
||||
}
|
||||
|
||||
void TSE::GLFW::FrameBuffer::Initialize()
|
||||
@@ -73,14 +71,12 @@ void TSE::GLFW::FrameBuffer::Initialize()
|
||||
TSE_LOG(std::to_string(glGetError()));
|
||||
}
|
||||
Unbind();
|
||||
glBindTexture(GL_TEXTURE_2D, 0);
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, 0);
|
||||
}
|
||||
|
||||
void TSE::GLFW::FrameBuffer::LoadFBTexture()
|
||||
{
|
||||
glBindTexture(GL_TEXTURE_2D, textureID);
|
||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, size.x, size.y, 0, GL_RGBA, GL_UNSIGNED_BYTE, nullptr);
|
||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, width, height, 0, GL_RGBA, GL_UNSIGNED_BYTE, nullptr);
|
||||
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||
@@ -88,12 +84,12 @@ void TSE::GLFW::FrameBuffer::LoadFBTexture()
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
|
||||
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, depthRboID);
|
||||
glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT24, size.x, size.y);
|
||||
glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT24, width, height);
|
||||
}
|
||||
|
||||
void TSE::GLFW::FrameBuffer::CreateFBTexture()
|
||||
{
|
||||
glViewport(0,0, size.x, size.y);
|
||||
glViewport(0,0, width, height);
|
||||
//resize
|
||||
if(textureID == 0)
|
||||
glGenTextures(1, &textureID);
|
||||
|
||||
@@ -11,7 +11,6 @@ namespace TSE::GLFW
|
||||
private:
|
||||
uint textureID = 0;
|
||||
uint depthRboID = 0;
|
||||
Vector2 size;
|
||||
bool shouldResize = false;
|
||||
|
||||
public:
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
#define SHADER_PACKAGE_SIZE (sizeof(float) * (3 + 4 + 2 + 1))
|
||||
|
||||
TSE::GLFW::BasicTextureShader* TSE::GLFW::BasicTextureShader::instance = nullptr;
|
||||
std::map<uint, float> TSE::GLFW::BasicTextureShader::textureSlots;
|
||||
std::map<TSE::uint, float> TSE::GLFW::BasicTextureShader::textureSlots;
|
||||
|
||||
TSE::GLFW::BasicTextureShader *TSE::GLFW::BasicTextureShader::Instance()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user