Chromium Code Reviews| Index: services/video_capture/public/interfaces/video_capture_format_traits.cc |
| diff --git a/services/video_capture/public/interfaces/video_capture_format_traits.cc b/services/video_capture/public/interfaces/video_capture_format_traits.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7ab8a9e65763e9e55be1986ab525b7ec3a17e25a |
| --- /dev/null |
| +++ b/services/video_capture/public/interfaces/video_capture_format_traits.cc |
| @@ -0,0 +1,84 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "services/video_capture/public/interfaces/video_capture_format_traits.h" |
| + |
| +#include "ui/gfx/geometry/mojo/geometry.mojom.h" |
| +#include "ui/gfx/geometry/mojo/geometry_struct_traits.h" |
| + |
| +namespace mojo { |
| + |
| +// static |
| +gfx::Size StructTraits< |
| + video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>::frame_size(const media::VideoCaptureFormat& r) { |
|
chfremer
2016/10/03 16:26:59
Why "r"?
Even though this may come from one of the
mcasas
2016/10/03 21:19:07
Done.
|
| + return gfx::Size(r.frame_size.width(), r.frame_size.height()); |
| +} |
| + |
| +// static |
| +float StructTraits< |
| + video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>::frame_rate(const media::VideoCaptureFormat& r) { |
| + return r.frame_rate; |
| +} |
| + |
| +// static |
| +media::mojom::VideoFormat StructTraits< |
| + video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>::pixel_format(const media::VideoCaptureFormat& |
| + r) { |
| + return media::mojom::VideoFormat(r.pixel_format); |
| +} |
| + |
| +// static |
| +bool StructTraits<video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>:: |
| + Read(video_capture::mojom::VideoCaptureFormatDataView data, |
| + media::VideoCaptureFormat* out) { |
| + if (!data.ReadFrameSize(&out->frame_size)) |
| + return false; |
| + out->frame_rate = data.frame_rate(); |
| + |
| + // Since there are static_asserts in place in |
| + // media/mojo/common/media_type_converters.cc to guarantee equality of the |
| + // underlying representations, we can simply static_cast to convert. |
| + out->pixel_format = |
| + static_cast<media::VideoPixelFormat>(data.pixel_format()); |
| + if (!data.ReadPixelStorage(&out->pixel_storage)) |
| + return false; |
| + return true; |
| +} |
| + |
| +//static |
| +video_capture::mojom::VideoPixelStorage |
| +EnumTraits<video_capture::mojom::VideoPixelStorage, media::VideoPixelStorage>:: |
| + ToMojom(media::VideoPixelStorage video_pixel_storage) { |
| + switch (video_pixel_storage) { |
| + case media::PIXEL_STORAGE_CPU: |
| + return video_capture::mojom::VideoPixelStorage::CPU; |
| + case media::PIXEL_STORAGE_GPUMEMORYBUFFER: |
| + return video_capture::mojom::VideoPixelStorage::GPUMEMORYBUFFER; |
| + } |
| + NOTREACHED(); |
| + return video_capture::mojom::VideoPixelStorage::CPU; |
| +} |
| + |
| +//static |
| +bool EnumTraits<video_capture::mojom::VideoPixelStorage, |
| + media::VideoPixelStorage>:: |
| + FromMojom(video_capture::mojom::VideoPixelStorage input, |
| + media::VideoPixelStorage* out) { |
| + switch (input) { |
| + case video_capture::mojom::VideoPixelStorage::CPU: |
| + *out = media::PIXEL_STORAGE_CPU; |
| + return true; |
| + case video_capture::mojom::VideoPixelStorage::GPUMEMORYBUFFER: |
| + *out = media::PIXEL_STORAGE_GPUMEMORYBUFFER; |
| + return true; |
| + } |
| + NOTREACHED(); |
| + return false; |
| +} |
| + |
| +} // namespace mojo |