8#include "libxr_type.hpp"
双缓冲区管理类 / Double buffer manager class
int active_
当前活动缓冲区编号 / Index of active buffer
bool FillActive(const uint8_t *data, size_t len)
向当前使用的缓冲区直接写入数据 Fills the active buffer directly
bool HasPending() const
判断是否有待切换的缓冲区 Checks whether a pending buffer is ready
size_t PendingLength() const
获取 pending 缓冲区中准备好的数据长度 Gets the size of valid data in pending buffer
bool FillPending(const uint8_t *data, size_t len)
向备用缓冲区写入数据(不可重入) Fills the pending buffer with data (non-reentrant)
size_t size_
单个缓冲区大小 / Size of each buffer
uint8_t * ActiveBuffer()
获取当前正在使用的缓冲区指针 Returns the currently active buffer
bool pending_valid_
标记备用区是否准备好 / Whether pending buffer is ready
DoubleBuffer(const LibXR::RawData &raw_data)
构造函数,使用连续内存构造两个缓冲区 Constructs a double buffer using one continuous memory block
size_t pending_len_
备用缓冲区有效数据长度 / Length of pending data
void Switch()
切换到备用缓冲区(若其有效) Switches to the pending buffer if it's valid
uint8_t * PendingBuffer()
获取备用缓冲区的指针 Returns the pending (inactive) buffer
void EnablePending()
手动启用 pending 状态 Manually sets the pending state to true
size_t Size() const
获取每个缓冲区的大小(单位:字节) Gets the size of each buffer in bytes
uint8_t * buffer_[2]
双缓冲区指针 / Double buffer pointers
原始数据封装类。 A class for encapsulating raw data.
void * addr_
数据存储地址。 The storage address of the data.