mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-27 04:35:34 +08:00
Use lambda to capture video decode result
This commit is contained in:
@@ -8,6 +8,17 @@ VideoFrame::VideoFrame(const uint8_t *buffer, size_t size) {
|
||||
buffer_ = new uint8_t[size];
|
||||
memcpy(buffer_, buffer, size);
|
||||
size_ = size;
|
||||
width_ = 0;
|
||||
height_ = 0;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(const uint8_t *buffer, size_t size, size_t width,
|
||||
size_t height) {
|
||||
buffer_ = new uint8_t[size];
|
||||
memcpy(buffer_, buffer, size);
|
||||
size_ = size;
|
||||
width_ = width;
|
||||
height_ = height;
|
||||
}
|
||||
|
||||
VideoFrame::VideoFrame(const VideoFrame &video_frame) {
|
||||
@@ -15,14 +26,20 @@ VideoFrame::VideoFrame(const VideoFrame &video_frame) {
|
||||
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(VideoFrame &&video_frame)
|
||||
: buffer_((uint8_t *)std::move(video_frame.buffer_)),
|
||||
size_(video_frame.size_) {
|
||||
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::operator=(const VideoFrame &video_frame) {
|
||||
@@ -34,6 +51,8 @@ VideoFrame &VideoFrame::operator=(const VideoFrame &video_frame) {
|
||||
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;
|
||||
}
|
||||
@@ -44,6 +63,10 @@ VideoFrame &VideoFrame::operator=(VideoFrame &&video_frame) {
|
||||
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;
|
||||
}
|
||||
@@ -55,4 +78,6 @@ VideoFrame::~VideoFrame() {
|
||||
}
|
||||
|
||||
size_ = 0;
|
||||
width_ = 0;
|
||||
height_ = 0;
|
||||
}
|
||||
@@ -7,6 +7,7 @@ class VideoFrame {
|
||||
public:
|
||||
VideoFrame();
|
||||
VideoFrame(const uint8_t *buffer, size_t size);
|
||||
VideoFrame(const uint8_t *buffer, size_t size, size_t width, size_t height);
|
||||
VideoFrame(const VideoFrame &video_frame);
|
||||
VideoFrame(VideoFrame &&video_frame);
|
||||
VideoFrame &operator=(const VideoFrame &video_frame);
|
||||
|
||||
Reference in New Issue
Block a user