Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(462)

Unified Diff: services/video_capture/public/interfaces/video_capture_format_traits.h

Issue 2379253003: Video Capture Service: typemap video_capture's and media's VideoCaptureFormat (Closed)
Patch Set: Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: services/video_capture/public/interfaces/video_capture_format_traits.h
diff --git a/services/video_capture/public/interfaces/video_capture_format_traits.h b/services/video_capture/public/interfaces/video_capture_format_traits.h
new file mode 100644
index 0000000000000000000000000000000000000000..e55ed927cea74185adba77db11fb31021bcc59b3
--- /dev/null
+++ b/services/video_capture/public/interfaces/video_capture_format_traits.h
@@ -0,0 +1,55 @@
+// 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.
+
+#ifndef SERVICES_VIDEO_CAPTURE_PUBLIC_INTERFACES_VIDEO_CAPTURE_FORMAT_TYPEMAP_H_
+#define SERVICES_VIDEO_CAPTURE_PUBLIC_INTERFACES_VIDEO_CAPTURE_FORMAT_TYPEMAP_H_
+
+#include "media/base/video_capture_types.h"
+#include "mojo/common/common_custom_types_struct_traits.h"
+#include "services/video_capture/public/interfaces/video_capture_format.mojom.h"
+#include "ui/gfx/geometry/mojo/geometry.mojom.h"
+#include "ui/gfx/geometry/mojo/geometry_struct_traits.h"
+
+namespace mojo {
+
+template <>
+struct StructTraits<video_capture::mojom::VideoCaptureFormatDataView,
+ media::VideoCaptureFormat> {
+
+ static gfx::Size frame_size(const media::VideoCaptureFormat& r) {
+ return gfx::Size(r.frame_size.width(), r.frame_size.height());
+ }
+
+ static float frame_rate(const media::VideoCaptureFormat& r) {
+ return r.frame_rate;
+ }
+
+ static media::mojom::VideoFormat pixel_format(
+ const media::VideoCaptureFormat& r) {
+ return static_cast<media::mojom::VideoFormat>(r.pixel_format);
dcheng 2016/10/03 01:03:08 Mojo has EnumTraits for mapping enums. Example: ht
mcasas 2016/10/03 07:31:51 Using it for VideoPixelStorage in l.33, but re. th
chfremer 2016/10/03 16:26:59 In my take on using the typmapping, I ended up rem
dcheng 2016/10/03 20:45:53 My recollection is the //media code predated the a
+ }
+
+ static video_capture::mojom::VideoPixelStorage pixel_storage(
+ const media::VideoCaptureFormat& r) {
+ return static_cast<video_capture::mojom::VideoPixelStorage>(
+ r.pixel_storage);
+ }
+
+ static bool Read(video_capture::mojom::VideoCaptureFormatDataView data,
dcheng 2016/10/03 01:03:08 Nit: Out-of-line this.
mcasas 2016/10/03 07:31:51 Done.
+ media::VideoCaptureFormat* out) {
+ gfx::Size frame_size;
+ data.ReadFrameSize(&frame_size);
dcheng 2016/10/03 01:03:08 Nit: read directly into out->frame_size, and check
mcasas 2016/10/03 07:31:51 Done.
+ out->frame_size = frame_size;
+ out->frame_rate = data.frame_rate();
+ out->pixel_format =
+ static_cast<media::VideoPixelFormat>(data.pixel_format());
+ out->pixel_storage =
+ static_cast<media::VideoPixelStorage>(data.pixel_storage());
+ return true;
+ }
+};
+
+}
+
+#endif // SERVICES_VIDEO_CAPTURE_PUBLIC_INTERFACES_VIDEO_CAPTURE_FORMAT_TYPEMAP_H_

Powered by Google App Engine
This is Rietveld 408576698