godot_voxel/engine/priority_dependency.h

39 lines
1.4 KiB
C++

#ifndef PRIORITY_DEPENDENCY_H
#define PRIORITY_DEPENDENCY_H
#include "../util/tasks/task_priority.h"
#include <core/math/vector3.h>
#include <memory>
#include <vector>
namespace zylann::voxel {
// Information to calculate the priority of a voxel task having a specific location
struct PriorityDependency {
struct ViewersData {
// These positions are written by the main thread and read by block processing threads.
// Order doesn't matter.
// It's only used to adjust task priority so using a lock isn't worth it. In worst case scenario,
// a task will run much sooner or later than expected, but it will run in any case.
// No resizing should happen concurrently. If it happens, a new instance will be made for future tasks,
// while old tasks will keep referencing the previous version.
std::vector<Vector3> viewers;
float highest_view_distance = 999999;
};
std::shared_ptr<ViewersData> shared;
// Position relative to the same space as viewers.
// TODO Won't update while in queue. Can it be bad?
// TODO May not be worth storing with double precision
Vector3 world_position;
// If the closest viewer is further away than this distance, the request can be cancelled as not worth it
float drop_distance_squared;
TaskPriority evaluate(uint8_t lod_index, uint8_t band2_priority, float *out_closest_distance_sq);
};
} // namespace zylann::voxel
#endif // PRIORITY_DEPENDENCY_H