7#ifndef EXT_RMANPKG_PLUGIN_RENDERMAN_PLUGIN_HD_PRMAN_VOLUME_H
8#define EXT_RMANPKG_PLUGIN_RENDERMAN_PLUGIN_HD_PRMAN_VOLUME_H
11#include "hdPrman/gprim.h"
12#include "pxr/imaging/hd/field.h"
13#include "pxr/imaging/hd/volume.h"
17PXR_NAMESPACE_OPEN_SCOPE
19class HdPrman_Field final :
public HdField
25 HdDirtyBits *dirtyBits)
override;
38 HF_MALLOC_TAG_NEW(
"new HdPrman_Volume");
40 HdPrman_Volume(
SdfPath const&
id,
const bool isMeshLight);
45 HdDirtyBits *dirtyBits,
46 TfToken const &reprToken)
override;
50 HdDirtyBits GetInitialDirtyBitsMask()
const override;
69 using HdPrman_VolumeTypeEmitter =
72 HdVolumeFieldDescriptorVector
const& fields,
73 RtPrimVarList* primvars);
78 static bool AddVolumeTypeEmitter(
TfToken const& fieldPrimType,
79 HdPrman_VolumeTypeEmitter emitterFunc,
80 bool overrideExisting =
false);
100 static void DeclareFieldPrimvar(RtPrimVarList* primvars,
101 RtUString
const& fieldName,
105 bool _ConvertGeometry(
106 HdPrman_RenderParam *renderParam,
110 RtPrimVarList *primvars,
111 std::vector<HdGeomSubset> *geomSubsets,
112 std::vector<RtPrimVarList> *geomSubsetPrimvars)
override;
114 void _AddPrimvars(RtPrimVarList*)
const override;
116 const std::vector<riley::CoordinateSystemId>&
117 _GetAdditionalCoordSysIds()
const override;
120 _GetFallbackMaterial(HdPrman_RenderParam *renderParam)
override {
121 return renderParam->GetFallbackVolumeMaterialId();
124 bool _PrototypeOnly()
override;
126 using _VolumeEmitterMap = std::map<TfToken, HdPrman_VolumeTypeEmitter>;
127 static _VolumeEmitterMap& _GetVolumeEmitterMap();
131 SdfPathVector _volumeFilterPaths;
132 std::vector<RtUString> _volumeFilterNodeNames;
133 std::vector<riley::VolumeFilterId> _volumeFilterIds;
134 std::vector<riley::CoordinateSystemId> _volumeFilterCoordSysIds;
137PXR_NAMESPACE_CLOSE_SCOPE
virtual HD_API void Finalize(HdRenderParam *renderParam)
Finalizes object resources.
virtual HdDirtyBits GetInitialDirtyBitsMask() const =0
Returns the minimal set of dirty bits to place in the change tracker for use in the first sync of thi...
virtual void Sync(HdSceneDelegate *sceneDelegate, HdRenderParam *renderParam, HdDirtyBits *dirtyBits)=0
Synchronizes state from the delegate to this object.
Hydra schema for a USD field primitive.
A mix-in template that adds shared gprim behavior to support various HdRprim types.
The HdRenderParam is an opaque (to core Hydra) handle, to an object that is obtained from the render ...
Adapter class providing data exchange with the client scene graph.
A path value used to locate objects in layers or scenegraphs.
Token for efficient comparison, assignment, and hashing of known strings.