7#ifndef PXR_IMAGING_HD_RETAINEDDATASOURCE_H
8#define PXR_IMAGING_HD_RETAINEDDATASOURCE_H
12#include "pxr/imaging/hd/api.h"
13#include "pxr/imaging/hd/dataSource.h"
15#include "pxr/usd/sdf/pathExpression.h"
20PXR_NAMESPACE_OPEN_SCOPE
42 const HdDataSourceBaseHandle *values);
47 const HdDataSourceBaseHandle &value1);
52 const HdDataSourceBaseHandle &value1,
54 const HdDataSourceBaseHandle &value2);
59 const HdDataSourceBaseHandle &value1,
61 const HdDataSourceBaseHandle &value2,
63 const HdDataSourceBaseHandle &value3);
68 const HdDataSourceBaseHandle &value1,
70 const HdDataSourceBaseHandle &value2,
72 const HdDataSourceBaseHandle &value3,
74 const HdDataSourceBaseHandle &value4);
79 const HdDataSourceBaseHandle &value1,
81 const HdDataSourceBaseHandle &value2,
83 const HdDataSourceBaseHandle &value3,
85 const HdDataSourceBaseHandle &value4,
87 const HdDataSourceBaseHandle &value5);
92 const HdDataSourceBaseHandle &value1,
94 const HdDataSourceBaseHandle &value2,
96 const HdDataSourceBaseHandle &value3,
98 const HdDataSourceBaseHandle &value4,
100 const HdDataSourceBaseHandle &value5,
102 const HdDataSourceBaseHandle &value6);
123 HdSampledDataSource::Time startTime,
124 HdSampledDataSource::Time endTime,
125 std::vector<HdSampledDataSource::Time> *outSampleTimes)
override
159 HdSampledDataSource::Time startTime,
160 HdSampledDataSource::Time endTime,
161 std::vector<HdSampledDataSource::Time> *outSampleTimes)
override
207 HD_DECLARE_DATASOURCE(HdRetainedTypedMultisampledDataSource<T>);
209 HdRetainedTypedMultisampledDataSource(
211 HdSampledDataSource::Time *sampleTimes,
215 HdSampledDataSource::Time startTime,
216 HdSampledDataSource::Time endTime,
217 std::vector<HdSampledDataSource::Time> *outSampleTimes)
override;
224 T
GetTypedValue(HdSampledDataSource::Time shutterOffset)
override;
227 typedef std::pair<HdSampledDataSource::Time, T> _SamplePair;
232HdRetainedTypedMultisampledDataSource<T>::HdRetainedTypedMultisampledDataSource(
234 HdSampledDataSource::Time *sampleTimes,
241 for (
size_t i = 0; i < count; ++i) {
242 _sampledValues.emplace_back(sampleTimes[i], sampleValues[i]);
248HdRetainedTypedMultisampledDataSource<T>::GetContributingSampleTimesForInterval(
249 HdSampledDataSource::Time startTime,
250 HdSampledDataSource::Time endTime,
251 std::vector<HdSampledDataSource::Time> *outSampleTimes)
253 if (_sampledValues.size() < 2) {
257 if (outSampleTimes) {
258 outSampleTimes->clear();
261 outSampleTimes->reserve(_sampledValues.size());
263 for (
const auto & iter : _sampledValues) {
264 outSampleTimes->push_back(iter.first);
273HdRetainedTypedMultisampledDataSource<T>::GetTypedValue(
274 HdSampledDataSource::Time shutterOffset)
276 if (_sampledValues.empty()) {
280 const HdSampledDataSource::Time epsilon = 0.0001;
282 for (
size_t i = 0, e = _sampledValues.size(); i < e; ++i) {
284 const HdSampledDataSource::Time & sampleTime = _sampledValues[i].first;
286 if (sampleTime > shutterOffset) {
290 return _sampledValues[i].second;
294 const HdSampledDataSource::Time delta =
295 sampleTime - shutterOffset;
298 if (delta < epsilon) {
299 return _sampledValues[i].second;
305 const HdSampledDataSource::Time previousDelta =
306 shutterOffset - _sampledValues[i - 1].first;
308 if (previousDelta <= delta) {
309 return _sampledValues[i - 1].second;
311 return _sampledValues[i].second;
315 if (fabs(sampleTime - shutterOffset) < epsilon) {
316 return _sampledValues[i].second;
322 return _sampledValues.back().second;
342 const HdDataSourceBaseHandle *values);
361HdSampledDataSourceHandle
362HdCreateTypedRetainedDataSource(
VtValue const &v);
367HdDataSourceBaseHandle
368HdMakeStaticCopy(HdDataSourceBaseHandle
const &ds);
373HdContainerDataSourceHandle
374HdMakeStaticCopy(HdContainerDataSourceHandle
const &ds);
376PXR_NAMESPACE_CLOSE_SCOPE
A datasource representing structured (named, hierarchical) data, for example a geometric primitive or...
A retained container data source is a data source whose data are available locally,...
A retained data source for sampled data.
bool GetContributingSampleTimesForInterval(HdSampledDataSource::Time startTime, HdSampledDataSource::Time endTime, std::vector< HdSampledDataSource::Time > *outSampleTimes) override
Given a shutter window of interest (startTime and endTime relative to the current frame),...
VtValue GetValue(HdSampledDataSource::Time shutterOffset) override
Returns the value of this data source at frame-relative time shutterOffset.
A retained data source version of HdVectorDataSource.
HD_API HdDataSourceBaseHandle GetElement(size_t element) override
Return the element at position element in this datasource.
HD_API size_t GetNumElements() override
Return the number of elements in this datasource.
Similar to HdRetainedSampledDataSource but provides strongly typed semantics.
bool GetContributingSampleTimesForInterval(HdSampledDataSource::Time startTime, HdSampledDataSource::Time endTime, std::vector< HdSampledDataSource::Time > *outSampleTimes) override
Given a shutter window of interest (startTime and endTime relative to the current frame),...
VtValue GetValue(HdSampledDataSource::Time shutterOffset) override
Returns the value of this data source at frame-relative time shutterOffset.
T GetTypedValue(HdSampledDataSource::Time shutterOffset) override
Returns the value of this data source at frame-relative time shutterOffset, as type T.
A datasource representing time-sampled values.
virtual bool GetContributingSampleTimesForInterval(Time startTime, Time endTime, std::vector< Time > *outSampleTimes)=0
Given a shutter window of interest (startTime and endTime relative to the current frame),...
virtual VtValue GetValue(Time shutterOffset)=0
Returns the value of this data source at frame-relative time shutterOffset.
A datasource representing a concretely-typed sampled value.
virtual T GetTypedValue(Time shutterOffset)=0
Returns the value of this data source at frame-relative time shutterOffset, as type T.
A datasource representing indexed data.
This is a small-vector class with local storage optimization, the local storage can be specified via ...
void reserve(size_type newCapacity)
Reserve storage for newCapacity entries.
Token for efficient comparison, assignment, and hashing of known strings.
Provides a container which may hold any type, and provides introspection and iteration over array typ...