2013-11-11 14:42:11 +00:00
|
|
|
#include "FluidMediumManager.h"
|
|
|
|
|
|
|
|
#include "SoftwareRenderer.h"
|
|
|
|
#include "FluidMediumInterface.h"
|
2015-10-15 22:28:07 +00:00
|
|
|
#include "Color.h"
|
2013-11-11 14:42:11 +00:00
|
|
|
|
|
|
|
FluidMediumManager::FluidMediumManager(SoftwareRenderer* renderer):
|
|
|
|
renderer(renderer)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
FluidMediumManager::~FluidMediumManager()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void FluidMediumManager::clearMedia()
|
|
|
|
{
|
|
|
|
media.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
void FluidMediumManager::registerMedium(FluidMediumInterface *medium)
|
|
|
|
{
|
|
|
|
media.push_back(medium);
|
|
|
|
}
|
|
|
|
|
|
|
|
Color FluidMediumManager::applyTraversal(const Vector3 &eye, const Vector3 &location, const Color &color) const
|
|
|
|
{
|
|
|
|
// Collect potential segments
|
|
|
|
SpaceSegment ray(eye, location);
|
|
|
|
int max_segments = media.size();
|
|
|
|
FluidMediumSegment* segments;
|
|
|
|
segments = new FluidMediumSegment[max_segments];
|
2015-08-13 21:59:27 +00:00
|
|
|
getTraversedMedia(segments, ray, max_segments);
|
2013-11-11 14:42:11 +00:00
|
|
|
|
|
|
|
delete[] segments;
|
|
|
|
return color;
|
|
|
|
}
|
|
|
|
|
|
|
|
int FluidMediumManager::getTraversedMedia(FluidMediumSegment segments[], const SpaceSegment &ray, int max_segments) const
|
|
|
|
{
|
|
|
|
int added = 0;
|
|
|
|
for (auto &medium : media)
|
|
|
|
{
|
|
|
|
SpaceSegment ray_inter(ray);
|
|
|
|
if (added < max_segments and medium->checkInfluence(ray_inter))
|
|
|
|
{
|
|
|
|
// The medium intersect with the ray
|
|
|
|
segments[added++] = {medium, ray_inter};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return added;
|
|
|
|
}
|