back to scratko.xyz
aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorscratko <m@scratko.xyz>2024-11-26 15:15:52 +0300
committerscratko <m@scratko.xyz>2024-11-26 20:18:15 +0300
commit4f64ac2f9265fe216e8d62f0d73a6f3b3389fbb1 (patch)
tree254d6ebaa0f7411033f8cbaf050e4ae1704d1a1f
parente93ba1ef36e5aa8e13a0d448fc465ac9b517e4d3 (diff)
downloadpicture-puzzle-master.tar.gz
picture-puzzle-master.tar.bz2
picture-puzzle-master.zip
Renaming and changed README fileHEADmaster
-rw-r--r--README.md43
-rw-r--r--image_converter/converter.c4
-rw-r--r--img_handler.cpp27
-rw-r--r--img_handler.hpp9
-rw-r--r--puzzle.hpp3
-rw-r--r--puzzle.pngbin0 -> 114081 bytes
6 files changed, 72 insertions, 14 deletions
diff --git a/README.md b/README.md
index 76bbeb7..1e87112 100644
--- a/README.md
+++ b/README.md
@@ -1,2 +1,43 @@
-<a href="https://scratko.xyz/games/puzzle.exe" target="_blank">Download Windows
+# Picture puzzle
+
+<img src="puzzle.png" />
+
+A desktop game similar to the standard widget in windows 7. The game is written
+in C++ (including C++17 standard). FLTK was used as a graphics library. This
+library is not as heavy as Qt, and allows to quickly create an application with
+graphical widgets.
+
+The essence of the game should be clear: to collect the image in its original
+form, moving one puzzle per move.
+
+The application has the following features:
+
+- *upload your image in any format and resolution. The program itself will
+ resize, cut into puzzles, create the appropriate directory and save them in
+ it.*
+
+- *showing the complete solution of the puzzle using the optimization algorithm
+ A\*.*
+
+- *the game is distributed in a single executable file by embedding the original
+ standard image (toucan image) in the executable file. The image data is stored
+ in an array in an object file (resources.o)*
+
+- *support for \*unix and Windows platforms*
+
+## Building
+
+For \*nix platform, you need to install FLTK library and then do the following:
+
+```
+git clone https://git.scratko.xyz/picture-puzzle
+cd picture-puzzle
+make
+./main
+```
+
+## For Windows platform
+
+The built executable file (under x86_64) is available at the link: <a
+href="https://scratko.xyz/games/puzzle.exe" target="_blank">Download Windows
version</a>
diff --git a/image_converter/converter.c b/image_converter/converter.c
index 4252e71..cccb9ad 100644
--- a/image_converter/converter.c
+++ b/image_converter/converter.c
@@ -1,3 +1,7 @@
+/*
+ * Embedding standard image data into a file resources.cpp
+ */
+
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
diff --git a/img_handler.cpp b/img_handler.cpp
index 921f639..6c62728 100644
--- a/img_handler.cpp
+++ b/img_handler.cpp
@@ -1,3 +1,8 @@
+/*
+ * Processing of images uploaded by the user
+ * (resizing, cropping, saving)
+ */
+
#include "img_handler.hpp"
#include "puzzle.hpp"
@@ -14,7 +19,7 @@
#include <iostream>
#include <string>
-ImageHandler::ImageHandler(const char *p) : path_to_file(p) {
+ImageHandler::ImageHandler(const char *p) : source_path(p) {
img_data = nullptr;
resized_data = nullptr;
/*
@@ -25,24 +30,24 @@ ImageHandler::ImageHandler(const char *p) : path_to_file(p) {
std::filesystem::create_directory(res_path);
#if defined(_WIN32)
- auto it = path_to_file.find_last_of('\\');
+ auto it = source_path.find_last_of('\\');
#else
- auto it = path_to_file.find_last_of('/');
+ auto it = source_path.find_last_of('/');
#endif
- std::string file_name = path_to_file.substr(it + 1);
+ std::string file_name = source_path.substr(it + 1);
std::string fn_withot_ext =
file_name.substr(0, file_name.find_first_of('.'));
#if defined(_WIN32)
- path_to_save = "resources\\" + fn_withot_ext + "\\";
+ destination_directory = "resources\\" + fn_withot_ext + "\\";
#else
- path_to_save = "resources/" + fn_withot_ext + '/';
+ destination_directory = "resources/" + fn_withot_ext + '/';
#endif
- std::filesystem::create_directory(path_to_save);
+ std::filesystem::create_directory(destination_directory);
}
void ImageHandler::load_img()
{
- img_data = stbi_load(path_to_file.c_str(), &in_width, &in_height,
+ img_data = stbi_load(source_path.c_str(), &in_width, &in_height,
&channel, 0);
}
@@ -62,11 +67,11 @@ void ImageHandler::save_img()
for(j = 0; j < puzzles_per_side; ++j, ++k) {
x = i * puzzle_size;
y = j * puzzle_size;
- std::string tmp_name =
- path_to_save +
+ std::string tmp_path =
+ destination_directory +
std::to_string(k / puzzles_per_side) +
std::to_string(k % puzzles_per_side) + ".png";
- stbi_write_png(tmp_name.c_str(), puzzle_size, puzzle_size, channel,
+ stbi_write_png(tmp_path.c_str(), puzzle_size, puzzle_size, channel,
resized_data + channel * (x + y * width),
width * channel);
}
diff --git a/img_handler.hpp b/img_handler.hpp
index 8c5754a..cb53807 100644
--- a/img_handler.hpp
+++ b/img_handler.hpp
@@ -1,3 +1,8 @@
+/*
+ * Processing of images uploaded by the user
+ * (resizing, cropping, saving)
+ */
+
#ifndef IMG_HANDLER_HPP_SENTRY
#define IMG_HANDLER_HPP_SENTRY
@@ -12,8 +17,8 @@ class ImageHandler {
int channel;
int in_width;
int in_height;
- std::string path_to_file;
- std::string path_to_save;
+ std::string source_path;
+ std::string destination_directory;
unsigned char *img_data;
unsigned char *resized_data;
public:
diff --git a/puzzle.hpp b/puzzle.hpp
index 11c5fae..6e8d666 100644
--- a/puzzle.hpp
+++ b/puzzle.hpp
@@ -43,6 +43,9 @@ private:
coordinates empty_box;
std::vector<std::unique_ptr<Puzzle>> puzzles;
Fl_Window *win;
+ /*
+ * selecting the current directory where the user image is stored
+ */
std::string cur_directory;
GameParams(Fl_Window *a_win = nullptr)
diff --git a/puzzle.png b/puzzle.png
new file mode 100644
index 0000000..30dd62b
--- /dev/null
+++ b/puzzle.png
Binary files differ