mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-27 04:35:34 +08:00
[feat] use encode thread to encode frame
This commit is contained in:
@@ -5,94 +5,40 @@
|
||||
|
||||
VideoFrame::VideoFrame() {}
|
||||
|
||||
VideoFrame::VideoFrame(size_t size) {
|
||||
buffer_ = new uint8_t[size];
|
||||
VideoFrame::VideoFrame(size_t size) : buffer_(size) {
|
||||
size_ = size;
|
||||
width_ = 0;
|
||||
height_ = 0;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(size_t size, uint32_t width, uint32_t height) {
|
||||
buffer_ = new uint8_t[size];
|
||||
VideoFrame::VideoFrame(size_t size, uint32_t width, uint32_t height)
|
||||
: buffer_(size) {
|
||||
size_ = size;
|
||||
width_ = width;
|
||||
height_ = height;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(const uint8_t *buffer, size_t size) {
|
||||
buffer_ = new uint8_t[size];
|
||||
memcpy(buffer_, buffer, size);
|
||||
VideoFrame::VideoFrame(const uint8_t *buffer, size_t size)
|
||||
: buffer_(buffer, size) {
|
||||
size_ = size;
|
||||
width_ = 0;
|
||||
height_ = 0;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(const uint8_t *buffer, size_t size, uint32_t width,
|
||||
uint32_t height) {
|
||||
buffer_ = new uint8_t[size];
|
||||
memcpy(buffer_, buffer, size);
|
||||
uint32_t height)
|
||||
: buffer_(buffer, size) {
|
||||
size_ = size;
|
||||
width_ = width;
|
||||
height_ = height;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(const VideoFrame &video_frame) {
|
||||
if (video_frame.size_ > 0) {
|
||||
buffer_ = new uint8_t[video_frame.size_];
|
||||
memcpy(buffer_, video_frame.buffer_, video_frame.size_);
|
||||
size_ = video_frame.size_;
|
||||
width_ = video_frame.width_;
|
||||
height_ = video_frame.height_;
|
||||
}
|
||||
}
|
||||
VideoFrame::VideoFrame(const VideoFrame &video_frame) = default;
|
||||
|
||||
VideoFrame::VideoFrame(VideoFrame &&video_frame)
|
||||
: buffer_((uint8_t *)std::move(video_frame.buffer_)),
|
||||
size_(video_frame.size_),
|
||||
width_(video_frame.width_),
|
||||
height_(video_frame.height_) {
|
||||
video_frame.buffer_ = nullptr;
|
||||
video_frame.size_ = 0;
|
||||
video_frame.width_ = 0;
|
||||
video_frame.height_ = 0;
|
||||
}
|
||||
VideoFrame::VideoFrame(VideoFrame &&video_frame) = default;
|
||||
|
||||
VideoFrame &VideoFrame::operator=(const VideoFrame &video_frame) {
|
||||
if (&video_frame != this) {
|
||||
if (buffer_) {
|
||||
delete buffer_;
|
||||
buffer_ = nullptr;
|
||||
}
|
||||
buffer_ = new uint8_t[video_frame.size_];
|
||||
memcpy(buffer_, video_frame.buffer_, video_frame.size_);
|
||||
size_ = video_frame.size_;
|
||||
width_ = video_frame.width_;
|
||||
height_ = video_frame.height_;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
VideoFrame &VideoFrame::operator=(const VideoFrame &video_frame) = default;
|
||||
|
||||
VideoFrame &VideoFrame::operator=(VideoFrame &&video_frame) {
|
||||
if (&video_frame != this) {
|
||||
buffer_ = std::move(video_frame.buffer_);
|
||||
video_frame.buffer_ = nullptr;
|
||||
size_ = video_frame.size_;
|
||||
video_frame.size_ = 0;
|
||||
width_ = video_frame.width_;
|
||||
video_frame.width_ = 0;
|
||||
height_ = video_frame.height_;
|
||||
video_frame.height_ = 0;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
VideoFrame &VideoFrame::operator=(VideoFrame &&video_frame) = default;
|
||||
|
||||
VideoFrame::~VideoFrame() {
|
||||
if (buffer_) {
|
||||
delete buffer_;
|
||||
buffer_ = nullptr;
|
||||
}
|
||||
|
||||
size_ = 0;
|
||||
width_ = 0;
|
||||
height_ = 0;
|
||||
}
|
||||
VideoFrame::~VideoFrame() = default;
|
||||
Reference in New Issue
Block a user