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

Side by Side Diff: content/common/media/media_param_traits.cc

Issue 1204063005: Reland: Video Capture: extract storage info from pixel format in VideoCaptureFormat. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: dcheng@ second round of comments Created 5 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/common/media/media_param_traits.h" 5 #include "content/common/media/media_param_traits.h"
6 6
7 #include "base/strings/stringprintf.h" 7 #include "base/strings/stringprintf.h"
8 #include "ipc/ipc_message_utils.h"
8 #include "media/audio/audio_parameters.h" 9 #include "media/audio/audio_parameters.h"
9 #include "media/base/limits.h" 10 #include "media/base/limits.h"
10 #include "media/base/video_capture_types.h" 11 #include "media/base/video_capture_types.h"
12 #include "ui/gfx/ipc/gfx_param_traits.h"
11 13
12 using media::AudioParameters; 14 using media::AudioParameters;
13 using media::ChannelLayout; 15 using media::ChannelLayout;
14 using media::VideoCaptureFormat; 16 using media::VideoCaptureFormat;
15 using media::VideoPixelFormat;
16 17
17 namespace IPC { 18 namespace IPC {
18 19
20 IPC_ENUM_TRAITS_MAX_VALUE(media::VideoPixelFormat, media::PIXEL_FORMAT_MAX - 1)
21 IPC_ENUM_TRAITS_MAX_VALUE(media::VideoPixelStorage, media::PIXEL_STORAGE_MAX)
dcheng 2015/06/25 02:02:18 See https://codereview.chromium.org/1210743003/ fo
mcasas 2015/06/25 13:51:03 Done.
22
19 void ParamTraits<AudioParameters>::Write(Message* m, 23 void ParamTraits<AudioParameters>::Write(Message* m,
20 const AudioParameters& p) { 24 const AudioParameters& p) {
21 m->WriteInt(static_cast<int>(p.format())); 25 m->WriteInt(static_cast<int>(p.format()));
22 m->WriteInt(static_cast<int>(p.channel_layout())); 26 m->WriteInt(static_cast<int>(p.channel_layout()));
23 m->WriteInt(p.sample_rate()); 27 m->WriteInt(p.sample_rate());
24 m->WriteInt(p.bits_per_sample()); 28 m->WriteInt(p.bits_per_sample());
25 m->WriteInt(p.frames_per_buffer()); 29 m->WriteInt(p.frames_per_buffer());
26 m->WriteInt(p.channels()); 30 m->WriteInt(p.channels());
27 m->WriteInt(p.effects()); 31 m->WriteInt(p.effects());
28 } 32 }
29 33
30 bool ParamTraits<AudioParameters>::Read(const Message* m, 34 bool ParamTraits<AudioParameters>::Read(const Message* m,
31 base::PickleIterator* iter, 35 base::PickleIterator* iter,
32 AudioParameters* r) { 36 AudioParameters* r) {
33 int format, channel_layout, sample_rate, bits_per_sample, 37 int format, channel_layout, sample_rate, bits_per_sample,
34 frames_per_buffer, channels, effects; 38 frames_per_buffer, channels, effects;
35 39
36 if (!iter->ReadInt(&format) || 40 if (!iter->ReadInt(&format) ||
37 !iter->ReadInt(&channel_layout) || 41 !iter->ReadInt(&channel_layout) ||
38 !iter->ReadInt(&sample_rate) || 42 !iter->ReadInt(&sample_rate) ||
39 !iter->ReadInt(&bits_per_sample) || 43 !iter->ReadInt(&bits_per_sample) ||
40 !iter->ReadInt(&frames_per_buffer) || 44 !iter->ReadInt(&frames_per_buffer) ||
41 !iter->ReadInt(&channels) || 45 !iter->ReadInt(&channels) ||
42 !iter->ReadInt(&effects)) 46 !iter->ReadInt(&effects)) {
43 return false; 47 return false;
48 }
44 49
45 AudioParameters params(static_cast<AudioParameters::Format>(format), 50 AudioParameters params(static_cast<AudioParameters::Format>(format),
46 static_cast<ChannelLayout>(channel_layout), channels, 51 static_cast<ChannelLayout>(channel_layout), channels,
47 sample_rate, bits_per_sample, frames_per_buffer, effects); 52 sample_rate, bits_per_sample, frames_per_buffer, effects);
48 *r = params; 53 *r = params;
49 if (!r->IsValid()) 54 return r->IsValid();
50 return false;
51 return true;
52 } 55 }
53 56
54 void ParamTraits<AudioParameters>::Log(const AudioParameters& p, 57 void ParamTraits<AudioParameters>::Log(const AudioParameters& p,
55 std::string* l) { 58 std::string* l) {
56 l->append(base::StringPrintf("<AudioParameters>")); 59 l->append(base::StringPrintf("<AudioParameters>"));
57 } 60 }
58 61
59 void ParamTraits<VideoCaptureFormat>::Write(Message* m, 62 void ParamTraits<VideoCaptureFormat>::Write(Message* m,
60 const VideoCaptureFormat& p) { 63 const VideoCaptureFormat& p) {
61 // Crash during Send rather than have a failure at the message handler. 64 // Crash during Send rather than have a failure at the message handler.
62 m->WriteInt(p.frame_size.width()); 65 m->WriteInt(p.frame_size.width());
63 m->WriteInt(p.frame_size.height()); 66 m->WriteInt(p.frame_size.height());
64 m->WriteFloat(p.frame_rate); 67 m->WriteFloat(p.frame_rate);
65 m->WriteInt(static_cast<int>(p.pixel_format)); 68 m->WriteInt(static_cast<int>(p.pixel_format));
69 m->WriteInt(static_cast<int>(p.pixel_storage));
dcheng 2015/06/25 02:02:18 Btw, these should probably be WriteParam() as well
mcasas 2015/06/25 13:51:03 Done.
66 } 70 }
67 71
68 bool ParamTraits<VideoCaptureFormat>::Read(const Message* m, 72 bool ParamTraits<VideoCaptureFormat>::Read(const Message* m,
69 base::PickleIterator* iter, 73 base::PickleIterator* iter,
70 VideoCaptureFormat* r) { 74 VideoCaptureFormat* r) {
71 int frame_size_width, frame_size_height, pixel_format; 75 if (!ReadParam(m, iter, &r->frame_size) ||
72 if (!iter->ReadInt(&frame_size_width) || 76 !ReadParam(m, iter, &r->frame_rate) ||
73 !iter->ReadInt(&frame_size_height) || 77 !ReadParam(m, iter, &r->pixel_format) ||
74 !iter->ReadFloat(&r->frame_rate) || 78 !ReadParam(m, iter, &r->pixel_storage)) {
75 !iter->ReadInt(&pixel_format))
76 return false; 79 return false;
77 80 }
78 r->frame_size.SetSize(frame_size_width, frame_size_height); 81 return r->IsValid();
79 r->pixel_format = static_cast<VideoPixelFormat>(pixel_format);
80 if (!r->IsValid())
81 return false;
82 return true;
83 } 82 }
84 83
85 void ParamTraits<VideoCaptureFormat>::Log(const VideoCaptureFormat& p, 84 void ParamTraits<VideoCaptureFormat>::Log(const VideoCaptureFormat& p,
86 std::string* l) { 85 std::string* l) {
87 l->append(base::StringPrintf("<VideoCaptureFormat>")); 86 l->append(base::StringPrintf("<VideoCaptureFormat>"));
88 } 87 }
89 88
90 } 89 }
OLDNEW
« no previous file with comments | « content/browser/renderer_host/media/video_capture_device_client.cc ('k') | media/base/video_capture_types.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698