Blender V5.0
field.cpp
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2022 NVIDIA Corporation
2 * SPDX-FileCopyrightText: 2022 Blender Foundation
3 *
4 * SPDX-License-Identifier: Apache-2.0 */
5
6#include "hydra/field.h"
7
8#include "util/log.h"
9
10#ifdef WITH_OPENVDB
11# include "hydra/session.h"
12# include "scene/image_vdb.h"
13# include "scene/scene.h"
14#endif
15
16#include <pxr/imaging/hd/sceneDelegate.h>
17#include <pxr/usd/sdf/assetPath.h>
18
20
21#if PXR_VERSION < 2108
22// clang-format off
24 (fieldName)
25);
26// clang-format on
27#endif
28
29#ifdef WITH_OPENVDB
30class HdCyclesVolumeLoader : public VDBImageLoader {
31 public:
32 HdCyclesVolumeLoader(const std::string &filePath, const std::string &gridName)
33 : VDBImageLoader(gridName)
34 {
35 /* Disable delay loading and file copying, this has poor performance on network drives. */
36 const bool delay_load = false;
37 try {
38 openvdb::io::File file(filePath);
39# ifdef OPENVDB_USE_DELAYED_LOADING
40 file.setCopyMaxBytes(0);
41# endif
42 if (file.open(delay_load)) {
43 grid = file.readGrid(gridName);
44 }
45 }
46 catch (const openvdb::IoError &e) {
47 LOG_ERROR << "Error loading OpenVDB file: " << e.what();
48 }
49 catch (...) {
50 LOG_ERROR << "Error loading OpenVDB file: Unknown error";
51 }
52 }
53};
54#endif
55
56HdCyclesField::HdCyclesField(const SdfPath &bprimId, const TfToken & /*typeId*/) : HdField(bprimId)
57{
58}
59
61
63{
64 return DirtyBits::DirtyParams;
65}
66
67void HdCyclesField::Sync(HdSceneDelegate *sceneDelegate,
68 HdRenderParam *renderParam,
69 HdDirtyBits *dirtyBits)
70{
71#ifdef WITH_OPENVDB
72 VtValue value;
73 const SdfPath &id = GetId();
74
75 if (*dirtyBits & DirtyBits::DirtyParams) {
76 value = sceneDelegate->Get(id, HdFieldTokens->filePath);
77 if (value.IsHolding<SdfAssetPath>()) {
78 std::string filename = value.UncheckedGet<SdfAssetPath>().GetResolvedPath();
79 if (filename.empty()) {
80 filename = value.UncheckedGet<SdfAssetPath>().GetAssetPath();
81 }
82
83# if PXR_VERSION >= 2108
84 value = sceneDelegate->Get(id, HdFieldTokens->fieldName);
85# else
86 value = sceneDelegate->Get(id, _tokens->fieldName);
87# endif
88 if (value.IsHolding<TfToken>()) {
89 unique_ptr<ImageLoader> loader = make_unique<HdCyclesVolumeLoader>(
90 filename, value.UncheckedGet<TfToken>().GetString());
91
92 const SceneLock lock(renderParam);
93
95 params.frame = 0.0f;
96
97 _handle = lock.scene->image_manager->add_image(std::move(loader), params, false);
98 }
99 }
100 }
101#else
102 (void)sceneDelegate;
103 (void)renderParam;
104#endif
105
106 *dirtyBits = DirtyBits::Clean;
107}
108
volatile int lock
ATTR_WARN_UNUSED_RESULT const BMVert const BMEdge * e
~HdCyclesField() override
void Sync(PXR_NS::HdSceneDelegate *sceneDelegate, PXR_NS::HdRenderParam *renderParam, PXR_NS::HdDirtyBits *dirtyBits) override
Definition field.cpp:67
HdCyclesField(const PXR_NS::SdfPath &bprimId, const PXR_NS::TfToken &typeId)
Definition field.cpp:56
PXR_NS::HdDirtyBits GetInitialDirtyBitsMask() const override
Definition field.cpp:62
HDCYCLES_NAMESPACE_OPEN_SCOPE TF_DEFINE_PRIVATE_TOKENS(_tokens,(fieldName))
#define HDCYCLES_NAMESPACE_CLOSE_SCOPE
uiWidgetBaseParameters params[MAX_WIDGET_BASE_BATCH]
#define LOG_ERROR
Definition log.h:101