Rerun C++ SDK
Loading...
Searching...
No Matches
visible_time_ranges.hpp
1// DO NOT EDIT! This file was auto-generated by crates/build/re_types_builder/src/codegen/cpp/mod.rs
2// Based on "crates/store/re_types/definitions/rerun/blueprint/archetypes/visible_time_ranges.fbs".
3
4#pragma once
5
6#include "../../blueprint/components/visible_time_range.hpp"
7#include "../../collection.hpp"
8#include "../../component_batch.hpp"
9#include "../../component_column.hpp"
10#include "../../result.hpp"
11
12#include <cstdint>
13#include <optional>
14#include <utility>
15#include <vector>
16
17namespace rerun::blueprint::archetypes {
18 /// **Archetype**: Configures what range of each timeline is shown on a view.
19 ///
20 /// Whenever no visual time range applies, queries are done with "latest-at" semantics.
21 /// This means that the view will, starting from the time cursor position,
22 /// query the latest data available for each component type.
23 ///
24 /// The default visual time range depends on the type of view this property applies to:
25 /// - For time series views, the default is to show the entire timeline.
26 /// - For any other view, the default is to apply latest-at semantics.
27 ///
28 /// ⚠ **This type is _unstable_ and may change significantly in a way that the data won't be backwards compatible.**
29 ///
31 /// The time ranges to show for each timeline unless specified otherwise on a per-entity basis.
32 ///
33 /// If a timeline is specified more than once, the first entry will be used.
34 std::optional<ComponentBatch> ranges;
35
36 public:
37 /// The name of the archetype as used in `ComponentDescriptor`s.
38 static constexpr const char ArchetypeName[] =
39 "rerun.blueprint.archetypes.VisibleTimeRanges";
40
41 /// `ComponentDescriptor` for the `ranges` field.
42 static constexpr auto Descriptor_ranges = ComponentDescriptor(
43 ArchetypeName, "VisibleTimeRanges:ranges",
45 );
46
47 public:
48 VisibleTimeRanges() = default;
49 VisibleTimeRanges(VisibleTimeRanges&& other) = default;
50 VisibleTimeRanges(const VisibleTimeRanges& other) = default;
51 VisibleTimeRanges& operator=(const VisibleTimeRanges& other) = default;
52 VisibleTimeRanges& operator=(VisibleTimeRanges&& other) = default;
53
54 explicit VisibleTimeRanges(
56 )
57 : ranges(ComponentBatch::from_loggable(std::move(_ranges), Descriptor_ranges)
58 .value_or_throw()) {}
59
60 /// Update only some specific fields of a `VisibleTimeRanges`.
62 return VisibleTimeRanges();
63 }
64
65 /// Clear all the fields of a `VisibleTimeRanges`.
67
68 /// The time ranges to show for each timeline unless specified otherwise on a per-entity basis.
69 ///
70 /// If a timeline is specified more than once, the first entry will be used.
73 ) && {
74 ranges = ComponentBatch::from_loggable(_ranges, Descriptor_ranges).value_or_throw();
75 return std::move(*this);
76 }
77
78 /// Partitions the component data into multiple sub-batches.
79 ///
80 /// Specifically, this transforms the existing `ComponentBatch` data into `ComponentColumn`s
81 /// instead, via `ComponentBatch::partitioned`.
82 ///
83 /// This makes it possible to use `RecordingStream::send_columns` to send columnar data directly into Rerun.
84 ///
85 /// The specified `lengths` must sum to the total length of the component batch.
87
88 /// Partitions the component data into unit-length sub-batches.
89 ///
90 /// This is semantically similar to calling `columns` with `std::vector<uint32_t>(n, 1)`,
91 /// where `n` is automatically guessed.
93 };
94
95} // namespace rerun::blueprint::archetypes
96
97namespace rerun {
98 /// \private
99 template <typename T>
100 struct AsComponents;
101
102 /// \private
103 template <>
104 struct AsComponents<blueprint::archetypes::VisibleTimeRanges> {
105 /// Serialize all set component batches.
106 static Result<Collection<ComponentBatch>> as_batches(
108 );
109 };
110} // namespace rerun
Generic collection of elements that are roughly contiguous in memory.
Definition collection.hpp:49
A class for representing either a usable value, or an error.
Definition result.hpp:14
All Rerun C++ types and functions are in the rerun namespace or one of its nested namespaces.
Definition rerun.hpp:23
Arrow-encoded data of a single batch of components together with a component descriptor.
Definition component_batch.hpp:28
static Result< ComponentBatch > from_loggable(const rerun::Collection< T > &components, const ComponentDescriptor &descriptor)
Creates a new component batch from a collection of component instances.
Definition component_batch.hpp:46
A ComponentDescriptor fully describes the semantics of a column of data.
Definition component_descriptor.hpp:16
The Loggable trait is used by all built-in implementation of rerun::AsComponents to serialize a colle...
Definition loggable.hpp:11
Archetype: Configures what range of each timeline is shown on a view.
Definition visible_time_ranges.hpp:30
Collection< ComponentColumn > columns(const Collection< uint32_t > &lengths_)
Partitions the component data into multiple sub-batches.
std::optional< ComponentBatch > ranges
The time ranges to show for each timeline unless specified otherwise on a per-entity basis.
Definition visible_time_ranges.hpp:34
static constexpr auto Descriptor_ranges
ComponentDescriptor for the ranges field.
Definition visible_time_ranges.hpp:42
static VisibleTimeRanges clear_fields()
Clear all the fields of a VisibleTimeRanges.
static constexpr const char ArchetypeName[]
The name of the archetype as used in ComponentDescriptors.
Definition visible_time_ranges.hpp:38
static VisibleTimeRanges update_fields()
Update only some specific fields of a VisibleTimeRanges.
Definition visible_time_ranges.hpp:61
VisibleTimeRanges with_ranges(const Collection< rerun::blueprint::components::VisibleTimeRange > &_ranges) &&
The time ranges to show for each timeline unless specified otherwise on a per-entity basis.
Definition visible_time_ranges.hpp:71
Collection< ComponentColumn > columns()
Partitions the component data into unit-length sub-batches.