micro improvements

This commit is contained in:
Kueffner, Maximilian
2025-05-23 15:15:01 +02:00
parent 436a61790c
commit 167dc1f9d4
7 changed files with 19 additions and 13 deletions
+1
View File
@@ -1,4 +1,5 @@
build/ build/
out/ out/
.vs/ .vs/
.cache/
*~ *~
+5 -2
View File
@@ -1,15 +1,18 @@
#include "Image.hpp" #include "Image.hpp"
#include <filesystem> #include <filesystem>
#include <format>
#include <memory>
#include <opencv2/imgcodecs.hpp> #include <opencv2/imgcodecs.hpp>
#include <stdexcept> #include <stdexcept>
#include <string_view>
pixelarium::imaging::Image::Image(const std::string& uri) pixelarium::imaging::Image::Image(const std::string& uri)
{ {
if (!std::filesystem::exists(uri)) if (!std::filesystem::exists(uri))
{ {
throw std::runtime_error("File not found"); throw std::runtime_error(std::format("File not {} found", uri));
} }
this->_img = cv::imread(uri); this->_img = std::make_unique<cv::Mat>(cv::imread(uri));
} }
+6 -7
View File
@@ -1,10 +1,7 @@
#pragma once #pragma once
#include <filesystem>
#include <memory> #include <memory>
#include <opencv2/core/mat.hpp> #include <opencv2/core/mat.hpp>
#include <opencv2/imgproc.hpp>
#include <opencv2/opencv.hpp>
#include <string> #include <string>
namespace pixelarium::imaging namespace pixelarium::imaging
@@ -17,16 +14,18 @@ class Image
// get back the defaults // get back the defaults
Image() = default; Image() = default;
Image(const Image& other) = default; // we cannot copy an Image since this conflicts with the _img field
Image(const Image& other) = delete;
Image(Image&& other) noexcept = default; Image(Image&& other) noexcept = default;
Image& operator=(const Image& other) = default; // requires a copy ctor which we don't have
Image& operator=(const Image& other) = delete;
Image& operator=(Image&& other) noexcept = default; Image& operator=(Image&& other) noexcept = default;
~Image() = default; ~Image() = default;
const cv::Mat& GetImage() const { return this->_img; } const cv::Mat& GetImage() const { return *this->_img.get(); }
private: private:
cv::Mat _img; std::unique_ptr<cv::Mat> _img;
}; };
} // namespace pixelarium::imaging } // namespace pixelarium::imaging
+3 -1
View File
@@ -7,15 +7,17 @@
#include <tuple> #include <tuple>
#include <utility> #include <utility>
#include "imaging/Image.hpp" #include "imaging/Image.hpp"
#include <opencv2/imgproc.hpp>
using namespace pixelarium::imaging; using namespace pixelarium::imaging;
pixelarium::render::CvMatRender::CvMatRender(const std::shared_ptr<Image>& img) pixelarium::render::CvMatRender::CvMatRender(const std::shared_ptr<Image>& img)
: _base(img), _texture(0) : _base(img), _texture(0)
{ {
this->_img = this->_base->GetImage().clone(); // this->_img = this->_base->GetImage().clone();
// // storing a copy of the to-be-rendered image with a "well-behaved" // // storing a copy of the to-be-rendered image with a "well-behaved"
// cv::cvtColor(this->_img, this->_img, cv::COLOR_BGR2RGBA); // cv::cvtColor(this->_img, this->_img, cv::COLOR_BGR2RGBA);
this->_img = this->_base->GetImage().clone();
} }
/*static*/ void pixelarium::render::matToTexture(const cv::Mat& image, /*static*/ void pixelarium::render::matToTexture(const cv::Mat& image,
+1 -1
View File
@@ -1,5 +1,5 @@
#pragma once #pragma once
// windows. must come before GL/GL.h here. // windows.h must come before GL/GL.h here.
// clang format would change this, effectively rendering the build broken. // clang format would change this, effectively rendering the build broken.
// clang-format off // clang-format off
#include <memory> #include <memory>
+1 -1
View File
@@ -221,7 +221,7 @@ void pixelarium::ui::AppGLFW::LoadImageProt()
// __FUNCTION__); // __FUNCTION__);
if (this->_logger) if (this->_logger)
{ {
this->_logger->Warn("Creating image"); this->_logger->Warn(std::format("Creating image {}", p));
} }
// this->_img = Image(p); // this->_img = Image(p);
this->_img = std::make_shared<Image>(p); this->_img = std::make_shared<Image>(p);
+2 -1
View File
@@ -4,6 +4,7 @@
#include "AppGLFW.hpp" #include "AppGLFW.hpp"
#include "utilities/ILog.hpp" #include "utilities/ILog.hpp"
#include "utilities/SpdLogger.hpp" #include "utilities/SpdLogger.hpp"
#include "uiresources.h"
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
@@ -16,7 +17,7 @@ int main(int argc, char** argv)
auto app = pixelarium::ui::AppGLFW(logger); auto app = pixelarium::ui::AppGLFW(logger);
// auto app = pixelarium::ui::AppGLFW(); // auto app = pixelarium::ui::AppGLFW();
logger->Info("Starting Application"); logger->Info(std::format("Starting Application {}", PIXELARIUM_TITLE));
logger->Error("Starting Application"); logger->Error("Starting Application");
return app.Run(); return app.Run();
} }