| /* |
| * Copyright 2025 The WebRTC project authors. All rights reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef VIDEO_CORRUPTION_DETECTION_EVALUATION_TEST_CLIP_H_ |
| #define VIDEO_CORRUPTION_DETECTION_EVALUATION_TEST_CLIP_H_ |
| |
| #include <string> |
| |
| #include "absl/strings/string_view.h" |
| #include "api/video_codecs/video_codec.h" |
| |
| namespace webrtc { |
| |
| // Identifies a test clip. |
| // If the clip is a YUV video, the user should use the `CreateYuvClip` method. |
| // Hence, the user should also give information about the resolution and |
| // framerate of the video. If the clip is a Y4M video, the resolution and |
| // framerate are derived from the file header, by using the `CreateY4mClip` |
| // method. |
| class TestClip { |
| public: |
| static TestClip CreateYuvClip(absl::string_view filename, |
| int width, |
| int height, |
| int framerate, |
| VideoCodecMode codec_mode); |
| |
| static TestClip CreateY4mClip(absl::string_view filename, |
| VideoCodecMode codec_mode); |
| |
| // Returns the path to the video with the '.yuv' or '.y4m' extension. |
| // Observe that this path can only be reached as long as the `TestClip` |
| // instance is alive. |
| absl::string_view clip_path() const { return clip_path_with_extension_; } |
| VideoCodecMode codec_mode() const { return codec_mode_; } |
| int width() const { return width_; } |
| int height() const { return height_; } |
| int framerate() const { return framerate_; } |
| bool is_yuv() const { return is_yuv_; } |
| |
| private: |
| TestClip(absl::string_view clip_path_with_extension, |
| int width, |
| int height, |
| int framerate, |
| VideoCodecMode codec_mode, |
| bool is_yuv) |
| : clip_path_with_extension_(std::string(clip_path_with_extension)), |
| codec_mode_(codec_mode), |
| width_(width), |
| height_(height), |
| framerate_(framerate), |
| is_yuv_(is_yuv) {} |
| |
| // The path to the video with the '.yuv' or '.y4m' extension. |
| const std::string clip_path_with_extension_; |
| // Specifies whether the video is a real time or a screensharing video. It |
| // is used to initialize the encoder properly. |
| const VideoCodecMode codec_mode_; |
| const int width_ = 0; |
| const int height_ = 0; |
| const int framerate_ = 0; |
| const bool is_yuv_ = false; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // VIDEO_CORRUPTION_DETECTION_EVALUATION_TEST_CLIP_H_ |