2024-01-30 19:04:15 +02:00
|
|
|
/*
|
|
|
|
* PenroseTiling.h, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../GameConstants.h"
|
|
|
|
#include "../CRandomGenerator.h"
|
|
|
|
#include <boost/geometry.hpp>
|
|
|
|
#include <boost/geometry/geometries/point_xy.hpp>
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2024-02-02 11:37:08 +02:00
|
|
|
using namespace boost::geometry;
|
2024-01-30 19:04:15 +02:00
|
|
|
typedef std::array<uint32_t, 3> TIndices;
|
|
|
|
|
2024-02-02 15:27:32 +02:00
|
|
|
const float PI_CONSTANT = 3.141592f;
|
|
|
|
|
2024-02-02 11:37:08 +02:00
|
|
|
class Point2D : public model::d2::point_xy<float>
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
using point_xy::point_xy;
|
|
|
|
|
|
|
|
Point2D operator * (float scale) const;
|
2024-05-08 12:16:42 +02:00
|
|
|
Point2D operator / (float scale) const;
|
2024-02-02 11:37:08 +02:00
|
|
|
Point2D operator + (const Point2D& other) const;
|
2024-05-08 12:16:42 +02:00
|
|
|
Point2D operator - (const Point2D& other) const;
|
2024-02-02 11:37:08 +02:00
|
|
|
Point2D rotated(float radians) const;
|
2024-02-02 15:27:32 +02:00
|
|
|
|
|
|
|
bool operator < (const Point2D& other) const;
|
2024-05-08 15:51:42 +02:00
|
|
|
bool operator == (const Point2D& other) const;
|
2024-03-24 18:25:30 +02:00
|
|
|
|
|
|
|
std::string toString() const;
|
2024-02-02 11:37:08 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
Point2D rotatePoint(const Point2D& point, double radians, const Point2D& origin);
|
|
|
|
|
2024-01-30 19:04:15 +02:00
|
|
|
class Triangle
|
|
|
|
{
|
|
|
|
public:
|
2024-02-02 15:27:32 +02:00
|
|
|
~Triangle();
|
|
|
|
|
2024-01-30 19:04:15 +02:00
|
|
|
const bool tiling;
|
|
|
|
TIndices indices;
|
|
|
|
|
|
|
|
std::vector<Triangle *> subTriangles;
|
|
|
|
|
|
|
|
Triangle(bool t_123, const TIndices & inds);
|
|
|
|
};
|
|
|
|
|
|
|
|
class PenroseTiling
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
const float PHI = 1.0 / ((1.0 + std::sqrt(5.0)) / 2);
|
2024-02-02 16:50:33 +02:00
|
|
|
const uint32_t POLY = 10; // Number of symmetries?
|
2024-01-30 19:04:15 +02:00
|
|
|
|
2024-02-02 16:50:33 +02:00
|
|
|
const float BASE_SIZE = 1.25f;
|
2024-04-14 07:25:52 +02:00
|
|
|
const uint32_t DEPTH = 8; //Recursion depth
|
2024-01-30 19:04:15 +02:00
|
|
|
|
|
|
|
const bool P2 = false; // Tiling type
|
|
|
|
|
2024-02-02 15:27:32 +02:00
|
|
|
std::set<Point2D> generatePenroseTiling(size_t numZones, CRandomGenerator * rand);
|
2024-01-30 19:04:15 +02:00
|
|
|
|
|
|
|
private:
|
2024-02-02 11:37:08 +02:00
|
|
|
void split(Triangle& p, std::vector<Point2D>& points, std::array<std::vector<uint32_t>, 5>& indices, uint32_t depth);
|
2024-01-30 19:04:15 +02:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|