1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
// Copyright 2009 Intel Corporation
// SPDX-License-Identifier: Apache-2.0
#ifdef OSPRAY_ENABLE_VOLUMES
#pragma once
#include "Volume.h"
#include "common/FeatureFlagsEnum.h"
#include "openvkl/openvkl.h"
// comment break to prevent clang-format from reordering openvkl includes
#include "openvkl/device/openvkl.h"
#include "transferFunction/TransferFunction.h"
// ispc shared
#include "volume/VolumetricModelShared.h"
namespace ospray {
struct OSPRAY_SDK_INTERFACE VolumetricModel
: public AddStructShared<ISPCDeviceObject, ispc::VolumetricModel>
{
VolumetricModel(api::ISPCDevice &device, Volume *geometry);
~VolumetricModel() override;
std::string toString() const override;
void commit() override;
RTCGeometry embreeGeometryHandle() const;
box3f bounds() const;
Ref<Volume> getVolume() const;
FeatureFlags getFeatureFlags() const;
private:
box3f volumeBounds;
Ref<Volume> volume;
Ref<TransferFunction> transferFunction;
const Ref<Volume> volumeAPI;
VKLIntervalIteratorContext vklIntervalContext = VKLIntervalIteratorContext();
FeatureFlagsOther featureFlagsOther{FFO_VOLUME_IN_SCENE};
};
OSPTYPEFOR_SPECIALIZATION(VolumetricModel *, OSP_VOLUMETRIC_MODEL);
inline FeatureFlags VolumetricModel::getFeatureFlags() const
{
FeatureFlags ff = volume->getFeatureFlags();
ff.other |= featureFlagsOther;
return ff;
}
} // namespace ospray
#endif
|