2017-12-08 15:05:47 +01:00
|
|
|
// This code is in the public domain -- castano@gmail.com
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#ifndef NV_MESH_ATLASPACKER_H
|
|
|
|
#define NV_MESH_ATLASPACKER_H
|
|
|
|
|
|
|
|
#include "nvcore/RadixSort.h"
|
2017-12-20 00:15:52 +01:00
|
|
|
#include "nvmath/Vector.h"
|
|
|
|
#include "nvmath/Random.h"
|
2017-12-08 15:05:47 +01:00
|
|
|
#include "nvimage/BitMap.h"
|
|
|
|
#include "nvimage/Image.h"
|
|
|
|
|
|
|
|
#include "nvmesh/nvmesh.h"
|
|
|
|
|
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
namespace nv
|
|
|
|
{
|
|
|
|
class Atlas;
|
|
|
|
class Chart;
|
|
|
|
|
|
|
|
struct AtlasPacker
|
|
|
|
{
|
|
|
|
AtlasPacker(Atlas * atlas);
|
|
|
|
~AtlasPacker();
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
void packCharts(int quality, float texelArea, bool blockAligned, bool conservative);
|
|
|
|
float computeAtlasUtilization() const;
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
private:
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
void findChartLocation(int quality, const BitMap * bitmap, Vector2::Arg extents, int w, int h, int * best_x, int * best_y, int * best_w, int * best_h, int * best_r);
|
|
|
|
void findChartLocation_bruteForce(const BitMap * bitmap, Vector2::Arg extents, int w, int h, int * best_x, int * best_y, int * best_w, int * best_h, int * best_r);
|
|
|
|
void findChartLocation_random(const BitMap * bitmap, Vector2::Arg extents, int w, int h, int * best_x, int * best_y, int * best_w, int * best_h, int * best_r, int minTrialCount);
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
void drawChartBitmapDilate(const Chart * chart, BitMap * bitmap, int padding);
|
|
|
|
void drawChartBitmap(const Chart * chart, BitMap * bitmap, const Vector2 & scale, const Vector2 & offset);
|
|
|
|
|
|
|
|
bool canAddChart(const BitMap * bitmap, int w, int h, int x, int y, int r);
|
|
|
|
void addChart(const BitMap * bitmap, int w, int h, int x, int y, int r, Image * debugOutput);
|
|
|
|
//void checkCanAddChart(const Chart * chart, int w, int h, int x, int y, int r);
|
|
|
|
void addChart(const Chart * chart, int w, int h, int x, int y, int r, Image * debugOutput);
|
|
|
|
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
static bool checkBitsCallback(void * param, int x, int y, Vector3::Arg bar, Vector3::Arg dx, Vector3::Arg dy, float coverage);
|
|
|
|
static bool setBitsCallback(void * param, int x, int y, Vector3::Arg bar, Vector3::Arg dx, Vector3::Arg dy, float coverage);
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
private:
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
Atlas * m_atlas;
|
|
|
|
BitMap m_bitmap;
|
2017-12-20 00:25:03 +01:00
|
|
|
// -- GODOT start --
|
|
|
|
//Image m_debug_bitmap;
|
|
|
|
// -- GODOT end --
|
2017-12-20 00:15:52 +01:00
|
|
|
RadixSort m_radix;
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
uint m_width;
|
|
|
|
uint m_height;
|
|
|
|
|
|
|
|
MTRand m_rand;
|
|
|
|
|
|
|
|
};
|
2017-12-08 15:05:47 +01:00
|
|
|
|
2017-12-20 00:15:52 +01:00
|
|
|
} // nv namespace
|
2017-12-08 15:05:47 +01:00
|
|
|
|
|
|
|
#endif // NV_MESH_ATLASPACKER_H
|