Chromium Code Reviews| Index: media/base/video_frame.cc |
| diff --git a/media/base/video_frame.cc b/media/base/video_frame.cc |
| index f58e4abd660c03b45219918e934e929a5777a6db..d459f6ed364723d9d97f2bb062144e8ab6a7618e 100644 |
| --- a/media/base/video_frame.cc |
| +++ b/media/base/video_frame.cc |
| @@ -45,6 +45,35 @@ static std::string ConfigToString(const VideoPixelFormat format, |
| visible_rect.ToString().c_str(), natural_size.ToString().c_str()); |
| } |
| +static std::string StorageTypeToString( |
| + const VideoFrame::StorageType storage_type) { |
| + switch (storage_type) { |
| + case VideoFrame::STORAGE_UNKNOWN: |
| + return "UNKNOWN"; |
| + case VideoFrame::STORAGE_OPAQUE: |
| + return "OPAQUE"; |
| + case VideoFrame::STORAGE_UNOWNED_MEMORY: |
| + return "UNOWNED_MEMORY"; |
| + case VideoFrame::STORAGE_OWNED_MEMORY: |
| + return "OWNED_MEMORY"; |
| + case VideoFrame::STORAGE_SHMEM: |
| + return "SHMEM"; |
| +#if defined(OS_LINUX) |
| + case VideoFrame::STORAGE_DMABUFS: |
| + return "DMABUFS"; |
| +#endif |
| +#if defined(VIDEO_HOLE) |
| + case VideoFrame::STORAGE_HOLE: |
| + return "HOLE"; |
| +#endif |
| + case VideoFrame::STORAGE_GPU_MEMORY_BUFFERS: |
| + return "GPU_MEMORY_BUFFERS"; |
| + } |
| + |
| + NOTREACHED() << "Invalid StorageType provided: " << storage_type; |
| + return "??"; |
| +} |
| + |
| // Returns true if |plane| is a valid plane index for the given |format|. |
| static bool IsValidPlane(size_t plane, VideoPixelFormat format) { |
| DCHECK_LE(VideoFrame::NumPlanes(format), |
| @@ -818,6 +847,28 @@ void VideoFrame::UpdateReleaseSyncToken(SyncTokenClient* client) { |
| client->GenerateSyncToken(&release_sync_token_); |
| } |
| +std::string VideoFrame::AsHumanReadableString() { |
| + if (metadata()->IsTrue(media::VideoFrameMetadata::END_OF_STREAM)) |
| + return "end of stream"; |
| + |
| + std::ostringstream s; |
| + s << "format: " << VideoPixelFormatToString(format_) |
| + << " storage_type: " << StorageTypeToString(storage_type_) |
| + << " coded_size: " << coded_size_.ToString() |
| + << " visible_rect: " << visible_rect_.ToString() |
| + << " natural_size: " << natural_size_.ToString() << " strides: "; |
| + for (size_t i = 0; i < NumPlanes(format_); ++i) |
| + s << strides_[i] << " "; |
| + s << "rows: "; |
| + for (size_t i = 0; i < NumPlanes(format_); ++i) |
| + s << rows(i) << " "; |
| + s << "row_bytes: "; |
| + for (size_t i = 0; i < NumPlanes(format_); ++i) |
| + s << row_bytes(i) << " "; |
|
xhwang
2015/12/18 23:07:43
rows and strides are no as important as other fiel
jrummell
2015/12/22 01:30:43
Removed.
|
| + s << "timestamp: " << timestamp_.InMicroseconds(); |
| + return s.str(); |
| +} |
| + |
| // static |
| scoped_refptr<VideoFrame> VideoFrame::WrapExternalStorage( |
| VideoPixelFormat format, |