Jetson Linux API 参考文档

32.7.4 版本
BufferStream.h
前往此文件的文档。
1 /*
2  * 版权所有 (c) 2017-2018, NVIDIA CORPORATION。保留所有权利。
3  *
4  * 允许以源代码和二进制形式再分发和使用,无论是否
5  * 修改,但须满足以下条件
6  * :
7  * * 源代码的再分发必须保留上述版权
8  * 声明、此条件列表和以下免责声明。
9  * * 二进制形式的再分发必须在上述版权
10  * 声明、此条件列表和以下免责声明中再现
11  * 文档和/或随发行版提供的其他材料。
12  * * 未经事先明确书面许可,不得使用 NVIDIA CORPORATION 的名称或其
13  * 贡献者的姓名来认可或推广衍生产品
14  * 来自本软件。
15  *
16  * 本软件由版权持有者“按原样”提供,并且不作任何明示或暗示的
17  * 担保,包括但不限于
18  * 对适销性和针对特定用途适用性的默示担保。
19  * 在任何情况下,版权所有者或
20  * 贡献者均不对任何直接、间接、附带、特殊、
21  * 惩戒性或后果性损害(包括但不限于
22  * 替代商品或服务的采购;使用、数据或
23  * 利润损失;或业务中断)承担责任,无论其原因和任何理论
24  * 的责任,无论是合同、严格责任还是侵权行为
25  * (包括疏忽或其他原因)以任何方式因使用
26  * 本软件而引起,即使已被告知可能发生此类损害。
27  */
28 
36 #ifndef _ARGUS_BUFFER_STREAM_H
37 #define _ARGUS_BUFFER_STREAM_H
38 
39 namespace Argus
40 {
41 
76 DEFINE_UUID(StreamType, STREAM_TYPE_BUFFER, c723d960,5231,11e7,9598,18,00,20,0c,9a,66);
77 
88 DEFINE_NAMED_UUID_CLASS(BufferType);
89 DEFINE_UUID(BufferType, BUFFER_TYPE_NONE, c723d961,5231,11e7,9598,18,00,20,0c,9a,66);
90 
101 DEFINE_NAMED_UUID_CLASS(SyncType);
102 DEFINE_UUID(SyncType, SYNC_TYPE_NONE, c723d962,5231,11e7,9598,18,00,20,0c,9a,66);
103 
123 class Buffer : public InterfaceProvider, public Destructable
124 {
125 protected
126  ~Buffer() {}
127 };
128 
142 {
143 protected
145 };
146 
154 DEFINE_UUID(InterfaceID, IID_BUFFER_OUTPUT_STREAM_SETTINGS,
155  c723d963,5231,11e7,9598,18,00,20,0c,9a,66);
157 {
158 public
159  static const InterfaceID& id() { return IID_BUFFER_OUTPUT_STREAM_SETTINGS; }
160 
170  virtual Status setBufferType(const BufferType& type) = 0;
171 
175  virtual BufferType getBufferType() const = 0;
176 
188  virtual Status setSyncType(const SyncType& type) = 0;
189 
193  virtual SyncType getSyncType() const = 0;
194 
202  virtual void setMetadataEnable(bool enable) = 0;
203 
207  virtual bool getMetadataEnable() const = 0;
208 
209 protected
211 };
212 
220 DEFINE_UUID(InterfaceID, IID_BUFFER_OUTPUT_STREAM, c723d964,5231,11e7,9598,18,00,20,0c,9a,66);
222 {
223 public
224  static const InterfaceID& id() { return IID_BUFFER_OUTPUT_STREAM; }
225 
229  virtual BufferType getBufferType() const = 0;
230 
234  virtual SyncType getSyncType() const = 0;
235 
247  virtual BufferSettings* createBufferSettings(Status* status = NULL) = 0;
248 
263  virtual Buffer* createBuffer(const BufferSettings* settings, Status* status = NULL) = 0;
264 
296  virtual Buffer* acquireBuffer(uint64_t timeout = TIMEOUT_INFINITE, Status* status = NULL) = 0;
297 
324  virtual Status releaseBuffer(Buffer* buffer) = 0;
325 
340  virtual Status endOfStream() = 0;
341 
342 protected
344 };
345 
353 DEFINE_UUID(InterfaceID, IID_BUFFER, c723d965,5231,11e7,9598,18,00,20,0c,9a,66);
354 class IBuffer : public Interface
355 {
356 public
357  static const InterfaceID& id() { return IID_BUFFER; }
358 
362  virtual BufferType getBufferType() const = 0;
363 
367  virtual SyncType getSyncType() const = 0;
368 
378  virtual void setClientData(const void* clientData) = 0;
379 
383  virtual const void* getClientData() const = 0;
384 
400  virtual const CaptureMetadata* getMetadata() const = 0;
401 
402 protected
403  ~IBuffer() {}
404 };
405 
406 } // namespace Argus
407 
408 #endif // _ARGUS_BUFFER_STREAM_H
Argus::IBufferOutputStream::getSyncType
virtual SyncType getSyncType() const =0
Argus::IBufferOutputStream::getBufferType
virtual BufferType getBufferType() const =0
Returns the BufferType of the stream.
Argus::DEFINE_NAMED_UUID_CLASS
DEFINE_NAMED_UUID_CLASS(BufferType)
Argus::TIMEOUT_INFINITE
const uint64_t TIMEOUT_INFINITE
Constant used for infinite timeouts.
Definition: Types.h:88
Argus::BufferSettings::~BufferSettings
~BufferSettings()
Definition: BufferStream.h:144
Argus::IBuffer::getMetadata
virtual const CaptureMetadata * getMetadata() const =0
Returns the CaptureMetadata object that was attached to this Buffer when it was last output to the st...
Argus::DEFINE_UUID
DEFINE_UUID(ExtensionName, EXT_BAYER_AVERAGE_MAP, 12c3de20, 64c5, 11e6, bdf4, 08, 00, 20, 0c, 9a, 66)
Argus::IBufferOutputStream
Definition: BufferStream.h:221
Argus::IBufferOutputStream::createBufferSettings
virtual BufferSettings * createBufferSettings(Status *status=NULL)=0
Creates a BufferSettings object.
Argus::Buffer::~Buffer
~Buffer()
Definition: BufferStream.h:126
Argus::IBuffer::getBufferType
virtual BufferType getBufferType() const =0
Returns the BufferType of the Buffer.
Argus
Definition: BayerAverageMap.h:39
Argus::CaptureMetadata
Definition: CaptureMetadata.h:48
Argus::IBufferOutputStream::endOfStream
virtual Status endOfStream()=0
Signals the end of the stream.
Argus::Interface
The top-level interface class.
Definition: Types.h:346
Argus::IBufferOutputStreamSettings
Definition: BufferStream.h:156
Argus::IBufferOutputStream::releaseBuffer
virtual Status releaseBuffer(Buffer *buffer)=0
Release a Buffer back to the stream to make it available for a future capture request.
Argus::IBufferOutputStream::~IBufferOutputStream
~IBufferOutputStream()
Definition: BufferStream.h:343
Argus::IBufferOutputStreamSettings::getMetadataEnable
virtual bool getMetadataEnable() const =0
Returns the metadata enable.
Argus::IBuffer::setClientData
virtual void setClientData(const void *clientData)=0
Sets the client data for the Buffer.
Argus::InterfaceID
A unique identifier for a libargus Interface.
Definition: Types.h:356
Argus::IBufferOutputStreamSettings::getBufferType
virtual BufferType getBufferType() const =0
Returns the BufferType to be used for the stream.
Argus::IBufferOutputStreamSettings::~IBufferOutputStreamSettings
~IBufferOutputStreamSettings()
Definition: BufferStream.h:210
Argus::InterfaceProvider
The base interface for a class that provides libargus Interfaces.
Definition: Types.h:377
Argus::IBuffer::~IBuffer
~IBuffer()
Definition: BufferStream.h:403
Argus::IBufferOutputStream::acquireBuffer
virtual Buffer * acquireBuffer(uint64_t timeout=TIMEOUT_INFINITE, Status *status=NULL)=0
Acquires a Buffer from the stream that was written to by a libargus capture request.
Argus::IBufferOutputStreamSettings::setBufferType
virtual Status setBufferType(const BufferType &type)=0
Sets the BufferType for the stream.
Argus::IBufferOutputStream::createBuffer
virtual Buffer * createBuffer(const BufferSettings *settings, Status *status=NULL)=0
Creates a Buffer object.
Argus::IBuffer::id
static const InterfaceID & id()
Definition: BufferStream.h:357
Argus::IBufferOutputStream::id
static const InterfaceID & id()
Definition: BufferStream.h:224
Argus::IBuffer::getSyncType
virtual SyncType getSyncType() const =0
Returns the SyncType of the Buffer.
Argus::Buffer
Definition: BufferStream.h:123
Argus::IBufferOutputStreamSettings::setMetadataEnable
virtual void setMetadataEnable(bool enable)=0
Sets the metadata enable for the stream.
Argus::BufferSettings
Definition: BufferStream.h:141
Argus::IBufferOutputStreamSettings::getSyncType
virtual SyncType getSyncType() const =0
Returns the SyncType to be used for the stream.
Argus::Destructable
A top level object class for libargus objects that are created and owned by the client.
Definition: Types.h:414
Argus::IBuffer::getClientData
virtual const void * getClientData() const =0
Returns the client data from the Buffer.
Argus::IBufferOutputStreamSettings::setSyncType
virtual Status setSyncType(const SyncType &type)=0
Sets the SyncType for the stream.
Argus::Status
Status
Status values returned by API function calls.
Definition: Types.h:93
Argus::IBuffer
Definition: BufferStream.h:354
Argus::IBufferOutputStreamSettings::id
static const InterfaceID & id()
Definition: BufferStream.h:159
. All rights reserved.