diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.cpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.cpp index fb5f7311..c771ed49 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.cpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.cpp @@ -113,7 +113,7 @@ void TileSheetEditorImGui::keyStateChanged(turbine::Key key, bool down) { auto const popupOpen = m_subsheetEditor.isOpen() && m_exportMenu.isOpen(); auto const pal = m_model.pal(); if (!popupOpen) { - const auto colorCnt = pal.pages[m_model.palettePage()].size(); + auto const colorCnt = pal.pages[m_model.palettePage()].size(); if (key == turbine::Key::Alpha_D) { m_tool = Tool::Draw; setCopyEnabled(false); @@ -137,7 +137,7 @@ void TileSheetEditorImGui::keyStateChanged(turbine::Key key, bool down) { static_cast(key - turbine::Key::Num_1), m_model.pal().pages.size() - 1); m_model.setPalettePage(idx); } else if (key <= turbine::Key::Num_0 + colorCnt) { - auto idx = ox::min(static_cast(key - turbine::Key::Num_1), colorCnt - 1); + auto const idx = ox::min(static_cast(key - turbine::Key::Num_1), colorCnt - 1); m_view.setPalIdx(idx); } } else if (key == turbine::Key::Num_0) { @@ -146,7 +146,7 @@ void TileSheetEditorImGui::keyStateChanged(turbine::Key key, bool down) { static_cast(key - turbine::Key::Num_1 + 9), m_model.pal().pages.size() - 1); m_model.setPalettePage(idx); } else if (colorCnt >= 10) { - auto idx = ox::min( + auto const idx = ox::min( static_cast(key - turbine::Key::Num_1 + 9), colorCnt - 1); m_view.setPalIdx(idx); } @@ -155,9 +155,9 @@ void TileSheetEditorImGui::keyStateChanged(turbine::Key key, bool down) { } void TileSheetEditorImGui::draw(turbine::Context&) noexcept { - const auto paneSize = ImGui::GetContentRegionAvail(); - const auto tileSheetParentSize = ImVec2(paneSize.x - m_palViewWidth, paneSize.y); - const auto fbSize = ox::Vec2(tileSheetParentSize.x - 16, tileSheetParentSize.y - 16); + auto const paneSize = ImGui::GetContentRegionAvail(); + auto const tileSheetParentSize = ImVec2(paneSize.x - m_palViewWidth, paneSize.y); + auto const fbSize = ox::Vec2(tileSheetParentSize.x - 16, tileSheetParentSize.y - 16); ImGui::BeginChild("TileSheetView", tileSheetParentSize, true); { drawTileSheet(fbSize); @@ -166,10 +166,10 @@ void TileSheetEditorImGui::draw(turbine::Context&) noexcept { ImGui::SameLine(); ImGui::BeginChild("Controls", ImVec2(m_palViewWidth - 8, paneSize.y), true); { - const auto controlsSize = ImGui::GetContentRegionAvail(); + auto const controlsSize = ImGui::GetContentRegionAvail(); ImGui::BeginChild("ToolBox", ImVec2(m_palViewWidth - 24, 30), true); { - const auto btnSz = ImVec2(45, 14); + auto const btnSz = ImVec2(45, 14); if (ImGui::Selectable("Select", m_tool == Tool::Select, 0, btnSz)) { m_tool = Tool::Select; } @@ -185,7 +185,7 @@ void TileSheetEditorImGui::draw(turbine::Context&) noexcept { } } ImGui::EndChild(); - const auto ySize = controlsSize.y - 38; + auto const ySize = controlsSize.y - 38; // draw palette/color picker ImGui::BeginChild("Palette", ImVec2(m_palViewWidth - 24, ySize / 2.f), true); { @@ -195,17 +195,17 @@ void TileSheetEditorImGui::draw(turbine::Context&) noexcept { ImGui::BeginChild("SubSheets", ImVec2(m_palViewWidth - 24, ySize / 2.f), true); { static constexpr auto btnHeight = 18; - const auto btnSize = ImVec2(18, btnHeight); + auto const btnSize = ImVec2(18, btnHeight); if (ImGui::Button("+", btnSize)) { auto insertOnIdx = m_model.activeSubSheetIdx(); - const auto &parent = *m_model.activeSubSheet(); + auto const&parent = m_model.activeSubSheet(); m_model.addSubsheet(insertOnIdx); insertOnIdx.emplace_back(parent.subsheets.size() - 1); m_model.setActiveSubsheet(insertOnIdx); } ImGui::SameLine(); if (ImGui::Button("-", btnSize)) { - const auto &activeSubsheetIdx = m_model.activeSubSheetIdx(); + auto const&activeSubsheetIdx = m_model.activeSubSheetIdx(); if (!activeSubsheetIdx.empty()) { m_model.rmSubsheet(activeSubsheetIdx); } @@ -243,14 +243,14 @@ void TileSheetEditorImGui::drawSubsheetSelector(TileSheet::SubSheet &subsheet, T using Str = ox::BasicString<100>; auto pathStr = ox::join("##", path).value; auto lbl = ox::sfmt("{}##{}", subsheet.name, pathStr); - const auto rowSelected = path == m_model.activeSubSheetIdx(); - const auto flags = ImGuiTreeNodeFlags_SpanFullWidth + auto const rowSelected = path == m_model.activeSubSheetIdx(); + auto const flags = ImGuiTreeNodeFlags_SpanFullWidth | ImGuiTreeNodeFlags_OpenOnArrow | ImGuiTreeNodeFlags_DefaultOpen | (subsheet.subsheets.empty() ? ImGuiTreeNodeFlags_Leaf : 0) | (rowSelected ? ImGuiTreeNodeFlags_Selected : 0); ImGui::TableNextColumn(); - const auto open = ImGui::TreeNodeEx(lbl.c_str(), flags); + auto const open = ImGui::TreeNodeEx(lbl.c_str(), flags); ImGui::SameLine(); if (ImGui::IsItemClicked()) { m_model.setActiveSubsheet(path); @@ -298,11 +298,11 @@ ox::Error TileSheetEditorImGui::saveItem() noexcept { } void TileSheetEditorImGui::showSubsheetEditor() noexcept { - const auto sheet = m_model.activeSubSheet(); - if (!sheet->subsheets.empty()) { - m_subsheetEditor.show(sheet->name, -1, -1); + auto const&sheet = m_model.activeSubSheet(); + if (!sheet.subsheets.empty()) { + m_subsheetEditor.show(sheet.name, -1, -1); } else { - m_subsheetEditor.show(sheet->name, sheet->columns, sheet->rows); + m_subsheetEditor.show(sheet.name, sheet.columns, sheet.rows); } } @@ -310,7 +310,7 @@ ox::Error TileSheetEditorImGui::exportSubhseetToPng(int scale) noexcept { oxRequire(path, studio::saveFile({{"PNG", "png"}})); // subsheet to png auto const&img = m_model.img(); - auto const&s = *m_model.activeSubSheet(); + auto const&s = m_model.activeSubSheet(); auto const&pal = m_model.pal(); auto const width = s.columns * TileWidth; auto const height = s.rows * TileHeight; @@ -423,7 +423,7 @@ void TileSheetEditorImGui::drawPaletteSelector() noexcept { ImGui::SetNextItemWidth(ImGui::GetContentRegionAvail().x - comboWidthSub); if (ImGui::BeginCombo("Page", numStr.data(), 0)) { for (auto n = 0u; n < pages; ++n) { - const auto selected = (m_model.palettePage() == n); + auto const selected = (m_model.palettePage() == n); ox_itoa(n + 1, numStr.data()); if (ImGui::Selectable(numStr.data(), selected) && m_model.palettePage() != n) { m_model.setPalettePage(n); @@ -448,8 +448,8 @@ void TileSheetEditorImGui::drawPaletteSelector() noexcept { ImGui::PushID(static_cast(i)); // Column: color idx ImGui::TableNextColumn(); - const auto label = ox::BString<8>() + (i + 1); - const auto rowSelected = i == m_view.palIdx(); + auto const label = ox::BString<8>() + (i + 1); + auto const rowSelected = i == m_view.palIdx(); if (ImGui::Selectable(label.c_str(), rowSelected, ImGuiSelectableFlags_SpanAllColumns)) { m_view.setPalIdx(i); } @@ -473,10 +473,10 @@ ox::Error TileSheetEditorImGui::updateActiveSubsheet(ox::StringView const&name, } ox::Error TileSheetEditorImGui::setPaletteSelection() noexcept { - const auto &palPath = m_model.palPath(); + auto const&palPath = m_model.palPath(); auto &sctx = *applicationData(m_ctx); - const auto &palList = sctx.project->fileList(core::FileExt_npal); - for (std::size_t i = 0; const auto &pal : palList) { + auto const&palList = sctx.project->fileList(core::FileExt_npal); + for (std::size_t i = 0; auto const&pal : palList) { if (palPath == pal) { m_selectedPaletteIdx = i; break; @@ -498,8 +498,8 @@ void TileSheetEditorImGui::SubSheetEditor::draw() noexcept { return; } ImGui::OpenPopup(popupName); - const auto modSize = m_cols > 0; - const auto popupHeight = modSize ? 125.f : 80.f; + auto const modSize = m_cols > 0; + auto const popupHeight = modSize ? 125.f : 80.f; ImGui::SetNextWindowSize(ImVec2(235, popupHeight)); if (ImGui::BeginPopupModal(popupName, &m_show, modalFlags)) { ImGui::InputText("Name", m_name.data(), m_name.cap()); diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.hpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.hpp index 657a9d45..eacf35f9 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.hpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditor-imgui.hpp @@ -27,6 +27,7 @@ class TileSheetEditorImGui: public studio::Editor { private: class SubSheetEditor { + private: ox::BString<100> m_name; int m_cols = 0; int m_rows = 0; @@ -45,8 +46,9 @@ class TileSheetEditorImGui: public studio::Editor { inline bool isOpen() const noexcept { return m_show; } }; class ExportMenu { - int m_scale = 0; - bool m_show = false; + private: + int m_scale = 0; + bool m_show = false; public: ox::Signal inputSubmitted; constexpr void show() noexcept { diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.cpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.cpp index 1484738c..b82a932a 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.cpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.cpp @@ -44,12 +44,12 @@ TileSheetEditorModel::TileSheetEditorModel(turbine::Context &ctx, ox::StringView void TileSheetEditorModel::cut() { TileSheetClipboard blankCb; auto cb = ox::make_unique(); - const auto s = activeSubSheet(); + const auto &s = activeSubSheet(); for (int y = m_selectionBounds.y; y <= m_selectionBounds.y2(); ++y) { for (int x = m_selectionBounds.x; x <= m_selectionBounds.x2(); ++x) { auto pt = ox::Point(x, y); - const auto idx = core::idx(*s, pt); - const auto c = getPixel(*s, m_img.bpp, idx); + const auto idx = core::idx(s, pt); + const auto c = getPixel(s, m_img.bpp, idx); pt.x -= m_selectionBounds.x; pt.y -= m_selectionBounds.y; cb->addPixel(pt, c); @@ -57,7 +57,7 @@ void TileSheetEditorModel::cut() { } } const auto pt1 = m_selectionOrigin == ox::Point(-1, -1) ? ox::Point(0, 0) : m_selectionOrigin; - const auto pt2 = ox::Point(s->columns * TileWidth, s->rows * TileHeight); + const auto pt2 = ox::Point(s.columns * TileWidth, s.rows * TileHeight); turbine::setClipboardObject(m_ctx, std::move(cb)); pushCommand(ox::make(CommandId::Cut, m_img, m_activeSubsSheetIdx, pt1, pt2, blankCb)); } @@ -67,9 +67,9 @@ void TileSheetEditorModel::copy() { for (int y = m_selectionBounds.y; y <= m_selectionBounds.y2(); ++y) { for (int x = m_selectionBounds.x; x <= m_selectionBounds.x2(); ++x) { auto pt = ox::Point(x, y); - const auto s = activeSubSheet(); - const auto idx = core::idx(*s, pt); - const auto c = getPixel(*s, m_img.bpp, idx); + const auto &s = activeSubSheet(); + const auto idx = core::idx(s, pt); + const auto c = getPixel(s, m_img.bpp, idx); pt.x -= m_selectionBounds.x; pt.y -= m_selectionBounds.y; cb->addPixel(pt, c); @@ -85,9 +85,9 @@ void TileSheetEditorModel::paste() { oxErrf("Could not read clipboard: {}", toStr(err)); return; } - const auto s = activeSubSheet(); + const auto &s = activeSubSheet(); const auto pt1 = m_selectionOrigin == ox::Point(-1, -1) ? ox::Point(0, 0) : m_selectionOrigin; - const auto pt2 = ox::Point(s->columns * TileWidth, s->rows * TileHeight); + const auto pt2 = ox::Point(s.columns * TileWidth, s.rows * TileHeight); pushCommand(ox::make(CommandId::Paste, m_img, m_activeSubsSheetIdx, pt1, pt2, *cb)); } @@ -206,10 +206,10 @@ void TileSheetEditorModel::select(ox::Point const&pt) noexcept { void TileSheetEditorModel::completeSelection() noexcept { m_selectionOngoing = false; - auto s = activeSubSheet(); + auto &s = activeSubSheet(); auto pt = m_selectionBounds.pt2(); - pt.x = ox::min(s->columns * TileWidth, pt.x); - pt.y = ox::min(s->rows * TileHeight, pt.y); + pt.x = ox::min(s.columns * TileWidth, pt.x); + pt.y = ox::min(s.rows * TileHeight, pt.y); m_selectionBounds.setPt2(pt); } @@ -254,13 +254,13 @@ ox::Error TileSheetEditorModel::saveFile() noexcept { } bool TileSheetEditorModel::pixelSelected(std::size_t idx) const noexcept { - const auto s = activeSubSheet(); - const auto pt = idxToPt(static_cast(idx), s->columns); + const auto &s = activeSubSheet(); + const auto pt = idxToPt(static_cast(idx), s.columns); return m_selectionBounds.contains(pt); } void TileSheetEditorModel::getFillPixels(bool *pixels, ox::Point const&pt, int oldColor) const noexcept { - const auto &activeSubSheet = *this->activeSubSheet(); + const auto &activeSubSheet = this->activeSubSheet(); const auto tileIdx = [activeSubSheet](const ox::Point &pt) noexcept { return ptToIdx(pt, activeSubSheet.columns) / PixelsPerTile; }; diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.hpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.hpp index d3069b9b..361d2006 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.hpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditormodel.hpp @@ -84,15 +84,13 @@ class TileSheetEditorModel: public ox::SignalHandler { void setActiveSubsheet(TileSheet::SubSheetIdx const&) noexcept; [[nodiscard]] - const TileSheet::SubSheet *activeSubSheet() const noexcept { - auto &activeSubSheet = getSubSheet(m_img, m_activeSubsSheetIdx); - return &activeSubSheet; + TileSheet::SubSheet const&activeSubSheet() const noexcept { + return getSubSheet(m_img, m_activeSubsSheetIdx); } [[nodiscard]] - TileSheet::SubSheet *activeSubSheet() noexcept { - auto &activeSubSheet = getSubSheet(m_img, m_activeSubsSheetIdx); - return &activeSubSheet; + TileSheet::SubSheet &activeSubSheet() noexcept { + return getSubSheet(m_img, m_activeSubsSheetIdx); } [[nodiscard]] diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditorview.cpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditorview.cpp index 0bfd5b7f..b9f4ec8e 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditorview.cpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheeteditorview.cpp @@ -28,9 +28,10 @@ void TileSheetEditorView::draw() noexcept { } void TileSheetEditorView::scrollV(ox::Vec2 const&paneSz, float wheel, bool zoomMod) noexcept { - const auto pixelSize = m_pixelsDrawer.pixelSize(paneSz); - const ImVec2 sheetSize(pixelSize.x * static_cast(m_model.activeSubSheet()->columns) * TileWidth, - pixelSize.y * static_cast(m_model.activeSubSheet()->rows) * TileHeight); + auto const&s = m_model.activeSubSheet(); + auto const pixelSize = m_pixelsDrawer.pixelSize(paneSz); + ImVec2 const sheetSize(pixelSize.x * static_cast(s.columns) * TileWidth, + pixelSize.y * static_cast(s.rows) * TileHeight); if (zoomMod) { m_pixelSizeMod = ox::clamp(m_pixelSizeMod + wheel * 0.02f, 0.55f, 2.f); m_pixelsDrawer.setPixelSizeMod(m_pixelSizeMod); @@ -45,39 +46,40 @@ void TileSheetEditorView::scrollV(ox::Vec2 const&paneSz, float wheel, bool zoomM } void TileSheetEditorView::scrollH(ox::Vec2 const&paneSz, float wheelh) noexcept { - const auto pixelSize = m_pixelsDrawer.pixelSize(paneSz); - const ImVec2 sheetSize(pixelSize.x * static_cast(m_model.activeSubSheet()->columns) * TileWidth, - pixelSize.y * static_cast(m_model.activeSubSheet()->rows) * TileHeight); + auto const&s = m_model.activeSubSheet(); + auto const pixelSize = m_pixelsDrawer.pixelSize(paneSz); + ImVec2 const sheetSize(pixelSize.x * static_cast(s.columns) * TileWidth, + pixelSize.y * static_cast(s.rows) * TileHeight); m_scrollOffset.x += wheelh * 0.1f; m_scrollOffset.x = ox::clamp(m_scrollOffset.x, -(sheetSize.x / 2), 0.f); } void TileSheetEditorView::insertTile(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) noexcept { - const auto pt = clickPoint(paneSize, clickPos); - const auto s = m_model.activeSubSheet(); - const auto tileIdx = ptToIdx(pt, s->columns) / PixelsPerTile; + auto const pt = clickPoint(paneSize, clickPos); + auto const&s = m_model.activeSubSheet(); + auto const tileIdx = ptToIdx(pt, s.columns) / PixelsPerTile; m_model.insertTiles(m_model.activeSubSheetIdx(), tileIdx, 1); } void TileSheetEditorView::deleteTile(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) noexcept { - const auto pt = clickPoint(paneSize, clickPos); - const auto s = m_model.activeSubSheet(); - const auto tileIdx = ptToIdx(pt, s->columns) / PixelsPerTile; + auto const pt = clickPoint(paneSize, clickPos); + auto const&s = m_model.activeSubSheet(); + auto const tileIdx = ptToIdx(pt, s.columns) / PixelsPerTile; m_model.deleteTiles(m_model.activeSubSheetIdx(), tileIdx, 1); } void TileSheetEditorView::clickDraw(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) noexcept { - const auto pt = clickPoint(paneSize, clickPos); + auto const pt = clickPoint(paneSize, clickPos); m_model.drawCommand(pt, m_palIdx); } void TileSheetEditorView::clickSelect(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) noexcept { - const auto pt = clickPoint(paneSize, clickPos); + auto const pt = clickPoint(paneSize, clickPos); m_model.select(pt); } void TileSheetEditorView::clickFill(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) noexcept { - const auto pt = clickPoint(paneSize, clickPos); + auto const pt = clickPoint(paneSize, clickPos); m_model.fill(pt, static_cast(m_palIdx)); } @@ -103,13 +105,13 @@ ox::Error TileSheetEditorView::markUpdated() noexcept { void TileSheetEditorView::ackUpdate() noexcept { m_updated = false; m_pixelsDrawer.update(m_viewSize); - m_pixelGridDrawer.update(m_viewSize, *m_model.activeSubSheet()); + m_pixelGridDrawer.update(m_viewSize, m_model.activeSubSheet()); m_model.ackUpdate(); } void TileSheetEditorView::initView() noexcept { m_pixelsDrawer.initBufferSet(m_viewSize); - m_pixelGridDrawer.initBufferSet(m_viewSize, *m_model.activeSubSheet()); + m_pixelGridDrawer.initBufferSet(m_viewSize, m_model.activeSubSheet()); } ox::Point TileSheetEditorView::clickPoint(ox::Vec2 const&paneSize, ox::Vec2 const&clickPos) const noexcept { diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixelgrid.cpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixelgrid.cpp index 42f5fc9f..bd68bff1 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixelgrid.cpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixelgrid.cpp @@ -15,9 +15,9 @@ void TileSheetGrid::setPixelSizeMod(float sm) noexcept { } ox::Error TileSheetGrid::buildShader() noexcept { - const auto pixelLineVshad = ox::sfmt(VShad, gl::GlslVersion); - const auto pixelLineFshad = ox::sfmt(FShad, gl::GlslVersion); - const auto pixelLineGshad = ox::sfmt(GShad, gl::GlslVersion); + auto const pixelLineVshad = ox::sfmt(VShad, gl::GlslVersion); + auto const pixelLineFshad = ox::sfmt(FShad, gl::GlslVersion); + auto const pixelLineGshad = ox::sfmt(GShad, gl::GlslVersion); return glutils::buildShaderProgram(pixelLineVshad, pixelLineFshad, pixelLineGshad).moveTo(m_shader); } @@ -28,7 +28,7 @@ void TileSheetGrid::draw(bool update, ox::Vec2 const&scroll) noexcept { if (update) { glutils::sendVbo(m_bufferSet); } - const auto uniformScroll = glGetUniformLocation(m_shader, "gScroll"); + auto const uniformScroll = glGetUniformLocation(m_shader, "gScroll"); glUniform2f(uniformScroll, scroll.x, scroll.y); glDrawArrays(GL_POINTS, 0, static_cast(m_bufferSet.vertices.size() / VertexVboRowLength)); glBindVertexArray(0); @@ -44,14 +44,14 @@ void TileSheetGrid::initBufferSet(ox::Vec2 const&paneSize, TileSheet::SubSheet c setBufferObjects(paneSize, subsheet); glutils::sendVbo(m_bufferSet); // vbo layout - const auto pt1Attr = static_cast(glGetAttribLocation(m_shader, "vPt1")); + auto const pt1Attr = static_cast(glGetAttribLocation(m_shader, "vPt1")); glEnableVertexAttribArray(pt1Attr); glVertexAttribPointer(pt1Attr, 2, GL_FLOAT, GL_FALSE, VertexVboRowLength * sizeof(float), nullptr); - const auto pt2Attr = static_cast(glGetAttribLocation(m_shader, "vPt2")); + auto const pt2Attr = static_cast(glGetAttribLocation(m_shader, "vPt2")); glEnableVertexAttribArray(pt2Attr); glVertexAttribPointer(pt2Attr, 2, GL_FLOAT, GL_FALSE, VertexVboRowLength * sizeof(float), std::bit_cast(uintptr_t{2 * sizeof(float)})); - const auto colorAttr = static_cast(glGetAttribLocation(m_shader, "vColor")); + auto const colorAttr = static_cast(glGetAttribLocation(m_shader, "vColor")); glEnableVertexAttribArray(colorAttr); glVertexAttribPointer(colorAttr, 3, GL_FLOAT, GL_FALSE, VertexVboRowLength * sizeof(float), std::bit_cast(uintptr_t{4 * sizeof(float)})); @@ -64,27 +64,32 @@ void TileSheetGrid::update(ox::Vec2 const&paneSize, TileSheet::SubSheet const&su glutils::sendEbo(m_bufferSet); } -void TileSheetGrid::setBufferObject(ox::Point pt1, ox::Point pt2, Color32 c, float *vbo, ox::Vec2 const&pixSize) noexcept { - const auto x1 = static_cast(pt1.x) * pixSize.x - 1.f; - const auto y1 = 1.f - static_cast(pt1.y) * pixSize.y; - const auto x2 = static_cast(pt2.x) * pixSize.x - 1.f; - const auto y2 = 1.f - static_cast(pt2.y) * pixSize.y; +void TileSheetGrid::setBufferObject( + ox::Point pt1, + ox::Point pt2, + Color32 c, + float *vbo, + ox::Vec2 const&pixSize) noexcept { + auto const x1 = static_cast(pt1.x) * pixSize.x - 1.f; + auto const y1 = 1.f - static_cast(pt1.y) * pixSize.y; + auto const x2 = static_cast(pt2.x) * pixSize.x - 1.f; + auto const y2 = 1.f - static_cast(pt2.y) * pixSize.y; // don't worry, this memcpy gets optimized to something much more ideal - const ox::Array vertices = {x1, y1, x2, y2, redf(c), greenf(c), bluef(c)}; + ox::Array const vertices = {x1, y1, x2, y2, redf(c), greenf(c), bluef(c)}; memcpy(vbo, vertices.data(), sizeof(vertices)); } void TileSheetGrid::setBufferObjects(ox::Vec2 const&paneSize, TileSheet::SubSheet const&subsheet) noexcept { - const auto pixSize = pixelSize(paneSize); - const auto set = [&](std::size_t i, ox::Point pt1, ox::Point pt2, Color32 c) { - const auto vbo = &m_bufferSet.vertices[i * VertexVboLength]; + auto const pixSize = pixelSize(paneSize); + auto const set = [&](std::size_t i, ox::Point pt1, ox::Point pt2, Color32 c) { + auto const vbo = &m_bufferSet.vertices[i * VertexVboLength]; setBufferObject(pt1, pt2, c, vbo, pixSize); }; // set buffer length - const auto width = subsheet.columns * TileWidth; - const auto height = subsheet.rows * TileHeight; - const auto tileCnt = static_cast(subsheet.columns + subsheet.rows); - const auto pixelCnt = static_cast(width + height); + auto const width = subsheet.columns * TileWidth; + auto const height = subsheet.rows * TileHeight; + auto const tileCnt = static_cast(subsheet.columns + subsheet.rows); + auto const pixelCnt = static_cast(width + height); m_bufferSet.vertices.resize(static_cast(tileCnt + pixelCnt + 4) * VertexVboLength); // set buffer std::size_t i = 0; @@ -111,9 +116,9 @@ void TileSheetGrid::setBufferObjects(ox::Vec2 const&paneSize, TileSheet::SubShee } ox::Vec2 TileSheetGrid::pixelSize(ox::Vec2 const&paneSize) const noexcept { - const auto [sw, sh] = paneSize; + auto const [sw, sh] = paneSize; constexpr float ymod = 0.35f / 10.0f; - const auto xmod = ymod * sh / sw; + auto const xmod = ymod * sh / sw; return {xmod * m_pixelSizeMod, ymod * m_pixelSizeMod}; } diff --git a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixels.cpp b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixels.cpp index 89537be2..db62fb73 100644 --- a/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixels.cpp +++ b/src/nostalgia/modules/core/src/studio/tilesheeteditor/tilesheetpixels.cpp @@ -94,17 +94,17 @@ void TileSheetPixels::setPixelBufferObject( void TileSheetPixels::setBufferObjects(ox::Vec2 const&paneSize) noexcept { // set buffer lengths - auto const subSheet = m_model.activeSubSheet(); + auto const&subSheet = m_model.activeSubSheet(); auto const&pal = m_model.pal(); - auto const width = subSheet->columns * TileWidth; - auto const height = subSheet->rows * TileHeight; + auto const width = subSheet.columns * TileWidth; + auto const height = subSheet.rows * TileHeight; auto const pixels = static_cast(width) * static_cast(height); m_bufferSet.vertices.resize(pixels * VertexVboLength); m_bufferSet.elements.resize(pixels * VertexEboLength); // set pixels - walkPixels(*subSheet, m_model.img().bpp, [&](std::size_t i, uint8_t p) { + walkPixels(subSheet, m_model.img().bpp, [&](std::size_t i, uint8_t p) { auto color = core::color(pal, m_model.palettePage(), p); - auto const pt = idxToPt(static_cast(i), subSheet->columns); + auto const pt = idxToPt(static_cast(i), subSheet.columns); auto const fx = static_cast(pt.x); auto const fy = static_cast(pt.y); auto const vbo = &m_bufferSet.vertices[i * VertexVboLength];