comenzado a crear paneles con imgui para controlar/debugear la ejecucion
This commit is contained in:
6
.idea/misc.xml
generated
6
.idea/misc.xml
generated
@@ -4,4 +4,10 @@
|
||||
<option name="pythonIntegrationState" value="YES" />
|
||||
</component>
|
||||
<component name="CMakeWorkspace" PROJECT_DIR="$PROJECT_DIR$" />
|
||||
<component name="CidrRootsConfiguration">
|
||||
<libraryRoots>
|
||||
<file path="$PROJECT_DIR$/vendor" />
|
||||
<file path="$PROJECT_DIR$/vendor/imgui" />
|
||||
</libraryRoots>
|
||||
</component>
|
||||
</project>
|
||||
@@ -1,10 +1,13 @@
|
||||
add_executable(${PROJECT_NAME}
|
||||
add_executable(${PROJECT_NAME})
|
||||
target_sources(${PROJECT_NAME} PRIVATE main.cpp
|
||||
bitops.h
|
||||
Graphics.cpp
|
||||
Graphics.h
|
||||
Chip8.cpp
|
||||
Chip8.h
|
||||
Interpreter.cpp
|
||||
Interpreter.h)
|
||||
target_sources(${PROJECT_NAME} PRIVATE main.cpp
|
||||
Graphics.cpp
|
||||
Graphics.h
|
||||
Interpreter.h
|
||||
Chip8ControlPanel.cpp
|
||||
Chip8ControlPanel.h
|
||||
)
|
||||
target_link_libraries(${PROJECT_NAME} PRIVATE vendor)
|
||||
41
src/Chip8ControlPanel.cpp
Normal file
41
src/Chip8ControlPanel.cpp
Normal file
@@ -0,0 +1,41 @@
|
||||
#include "Chip8ControlPanel.h"
|
||||
|
||||
#include <format>
|
||||
|
||||
#include "imgui.h"
|
||||
|
||||
void Chip8ControlPanel::render() {
|
||||
constexpr auto full_width = ImVec2(-FLT_MIN, 0.0f);
|
||||
|
||||
if (ImGui::Begin("Chip-8 - Controls")) {
|
||||
ImGui::Button("Load Rom", full_width);
|
||||
if (ImGui::Button(run ? "Pause" : "Run", full_width)) {
|
||||
run = !run;
|
||||
}
|
||||
|
||||
ImGui::Text("Status: %s", "Stopped");
|
||||
|
||||
ImGui::SeparatorText("Debug");
|
||||
|
||||
ImGui::Button("Step One", full_width);
|
||||
ImGui::Button(std::format("Step +{}", steps).data(), full_width);
|
||||
ImGui::PushItemWidth(ImGui::GetContentRegionAvail().x);
|
||||
ImGui::InputInt("##steps", &steps);
|
||||
ImGui::PopItemWidth();
|
||||
|
||||
|
||||
ImGui::SeparatorText("Emulation speed (IPS)");
|
||||
|
||||
ImGui::PushItemWidth(ImGui::GetContentRegionAvail().x);
|
||||
ImGui::InputInt("##speed", &speed);
|
||||
ImGui::PopItemWidth();
|
||||
|
||||
ImGui::SeparatorText("");
|
||||
|
||||
ImGui::Button("Reset", full_width);
|
||||
ImGui::Button("Reload ROM", full_width);
|
||||
}
|
||||
|
||||
|
||||
ImGui::End();
|
||||
}
|
||||
14
src/Chip8ControlPanel.h
Normal file
14
src/Chip8ControlPanel.h
Normal file
@@ -0,0 +1,14 @@
|
||||
#ifndef CHIP8CONTROLPANEL_H
|
||||
#define CHIP8CONTROLPANEL_H
|
||||
|
||||
|
||||
class Chip8ControlPanel {
|
||||
bool run = false;
|
||||
int steps = 10;
|
||||
int speed = 700;
|
||||
public:
|
||||
void render();
|
||||
};
|
||||
|
||||
|
||||
#endif //CHIP8CONTROLPANEL_H
|
||||
@@ -3,6 +3,7 @@
|
||||
//
|
||||
|
||||
#include "Graphics.h"
|
||||
#include "Chip8ControlPanel.h"
|
||||
|
||||
#include <array>
|
||||
#include <iostream>
|
||||
@@ -32,6 +33,7 @@ Graphics::Graphics(std::shared_ptr<MachineState> machine_state): machine_state{s
|
||||
chip8_width(64),
|
||||
chip8_height(32),
|
||||
main_scale(1.0f) {}
|
||||
|
||||
bool Graphics::init_sdl() {
|
||||
SDL_SetAppMetadata("CHIP-8 Emulator", "0.0.1", "fun.skrd.chip8");
|
||||
|
||||
@@ -104,7 +106,6 @@ void Graphics::draw() {
|
||||
|
||||
build_chip8_texture();
|
||||
|
||||
|
||||
ImGuiIO& io = ImGui::GetIO();
|
||||
|
||||
ImGui_ImplSDLRenderer3_NewFrame();
|
||||
@@ -113,6 +114,7 @@ void Graphics::draw() {
|
||||
ImGui::DockSpaceOverViewport(0, ImGui::GetMainViewport());
|
||||
|
||||
draw_chip8_widget();
|
||||
ctrPanel.render();
|
||||
|
||||
ImGui::Render();
|
||||
SDL_SetRenderScale(renderer.get(), io.DisplayFramebufferScale.x, io.DisplayFramebufferScale.y);
|
||||
@@ -153,20 +155,19 @@ void Graphics::build_chip8_texture() {
|
||||
}
|
||||
|
||||
void Graphics::draw_chip8_widget() {
|
||||
ImGui::Begin("CHIP-8");
|
||||
ImGui::Begin("CHIP-8 - Display");
|
||||
|
||||
const ImVec2 available_size = ImGui::GetContentRegionAvail();
|
||||
|
||||
int scale_x = static_cast<int>(available_size.x / chip8_width);
|
||||
int scale_y = static_cast<int>(available_size.y / chip8_height);
|
||||
int scale = std::max(1, std::min(scale_x, scale_y));
|
||||
ImVec2 scaled_size(chip8_width * scale, chip8_height * scale);
|
||||
const int scale_x = static_cast<int>(static_cast<float>(available_size.x) / static_cast<float>(chip8_width));
|
||||
const int scale_y = static_cast<int>(static_cast<float>(available_size.y) / static_cast<float>(chip8_height));
|
||||
const int scale = std::max(1, std::min(scale_x, scale_y));
|
||||
const ImVec2 scaled_size(static_cast<float>(chip8_width * scale), static_cast<float>(chip8_height * scale));
|
||||
|
||||
ImVec2 cursor_pos = ImGui::GetCursorPos();
|
||||
ImVec2 center_offset((available_size.x - scaled_size.x) / 2, (available_size.y - scaled_size.y) / 2);
|
||||
const ImVec2 cursor_pos = ImGui::GetCursorPos();
|
||||
const ImVec2 center_offset((available_size.x - scaled_size.x) / 2, (available_size.y - scaled_size.y) / 2);
|
||||
ImGui::SetCursorPos(ImVec2(cursor_pos.x + center_offset.x, cursor_pos.y + center_offset.y));
|
||||
|
||||
ImGui::Image((ImTextureID)(intptr_t)texture.get(), scaled_size);
|
||||
ImGui::Image(static_cast<ImTextureID>(reinterpret_cast<intptr_t>(texture.get())), scaled_size);
|
||||
ImGui::End();
|
||||
}
|
||||
|
||||
|
||||
@@ -7,6 +7,7 @@
|
||||
#include <bitset>
|
||||
#include <memory>
|
||||
|
||||
#include "Chip8ControlPanel.h"
|
||||
#include "imgui.h"
|
||||
#include "MachineState.h"
|
||||
#include "SDL3/SDL.h"
|
||||
@@ -28,6 +29,8 @@ class Graphics {
|
||||
std::unique_ptr<SDL_Renderer, SDLRendererDestroyer> renderer;
|
||||
std::unique_ptr<SDL_Texture, SDLTextureDestroyer> texture;
|
||||
|
||||
Chip8ControlPanel ctrPanel;
|
||||
|
||||
int window_width;
|
||||
int window_height;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user