#ifndef TILING_WAVE_FORM_COLLAPSE_H #define TILING_WAVE_FORM_COLLAPSE_H #include "array_2d.h" #include "core/vector.h" #include "wave_form_collapse.h" struct Tile { enum Symmetry { SYMMETRY_X = 0, SYMMETRY_T, SYMMETRY_I, SYMMETRY_L, SYMMETRY_BACKSLASH, SYMMETRY_P }; struct ActionMap { Vector map[8]; void set_size(int size) { for (int i = 0; i < 8; ++i) { map[i].resize(size); } } }; static const uint8_t rotation_map[6][9]; static const uint8_t reflection_map[6][9]; Vector> data; Symmetry symmetry; double weight; static ActionMap generate_action_map(const Symmetry &symmetry); static Vector> generate_oriented(Array2D data, Symmetry symmetry); Tile(const Vector> &p_data, Symmetry p_symmetry, double p_weight); Tile(const Array2D &p_data, Symmetry p_symmetry, double p_weight); }; class TilingWaveFormCollapse : public WaveFormCollapse { GDCLASS(TilingWaveFormCollapse, WaveFormCollapse); public: struct NeighbourData { int data[4]; NeighbourData() { for (int i = 0; i < 4; ++i) { data[i] = 0; } } }; struct DensePropagatorHelper { Vector directions[4]; void resize(const int size) { for (int i = 0; i < 4; ++i) { directions[i].resize(size); directions[i].fill(false); } } }; struct IdToTilePair { int id; int oriented_tile; IdToTilePair() { id = 0; oriented_tile = 0; } IdToTilePair(int p_id, int p_oriented_tile) { id = p_id; oriented_tile = p_oriented_tile; } }; public: void set_tiles(const Vector &p_tiles); void set_neighbours(const Vector &p_neighbors); void generate_oriented_tile_ids(); void generate_propagator(); static Vector get_tiles_weights(const Vector &tiles); void set_tile(int tile_id, int i, int j); bool set_tile(int tile_id, int orientation, int i, int j); Array2D do_run(); Array2D id_to_tiling(Array2D ids); void initialize(); TilingWaveFormCollapse(); ~TilingWaveFormCollapse(); protected: static void _bind_methods(); private: void generate_propagator_add_helper(Tile::ActionMap *action_map1, Tile::ActionMap *action_map2, Vector *dense_propagator, const NeighbourData &neighbour, int action, int direction); Vector tiles; Vector neighbors; Vector id_to_oriented_tile; Vector> oriented_tile_ids; }; #endif // FAST_WFC_TILING_WFC_HPP_