| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/renderer/media/media_stream_constraints_util.h" | 5 #include "content/renderer/media/media_stream_constraints_util.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| (...skipping 194 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 205 if (GetConstraintValueAsBoolean(constraints, picker, &value)) { | 205 if (GetConstraintValueAsBoolean(constraints, picker, &value)) { |
| 206 return rtc::Optional<bool>(value); | 206 return rtc::Optional<bool>(value); |
| 207 } | 207 } |
| 208 return rtc::Optional<bool>(); | 208 return rtc::Optional<bool>(); |
| 209 } | 209 } |
| 210 | 210 |
| 211 VideoTrackAdapterSettings SelectVideoTrackAdapterSettings( | 211 VideoTrackAdapterSettings SelectVideoTrackAdapterSettings( |
| 212 const blink::WebMediaTrackConstraintSet& basic_constraint_set, | 212 const blink::WebMediaTrackConstraintSet& basic_constraint_set, |
| 213 const ResolutionSet& resolution_set, | 213 const ResolutionSet& resolution_set, |
| 214 const NumericRangeSet<double>& frame_rate_set, | 214 const NumericRangeSet<double>& frame_rate_set, |
| 215 const media::VideoCaptureFormat& source_format) { | 215 const media::VideoCaptureFormat& source_format, |
| 216 bool expect_source_native_size) { |
| 216 ResolutionSet::Point resolution = resolution_set.SelectClosestPointToIdeal( | 217 ResolutionSet::Point resolution = resolution_set.SelectClosestPointToIdeal( |
| 217 basic_constraint_set, source_format.frame_size.height(), | 218 basic_constraint_set, source_format.frame_size.height(), |
| 218 source_format.frame_size.width()); | 219 source_format.frame_size.width()); |
| 219 int track_max_height = static_cast<int>(std::round(resolution.height())); | 220 int track_max_height = static_cast<int>(std::round(resolution.height())); |
| 220 int track_max_width = static_cast<int>(std::round(resolution.width())); | 221 int track_max_width = static_cast<int>(std::round(resolution.width())); |
| 221 double track_min_aspect_ratio = | 222 double track_min_aspect_ratio = |
| 222 std::max(resolution_set.min_aspect_ratio(), | 223 std::max(resolution_set.min_aspect_ratio(), |
| 223 static_cast<double>(resolution_set.min_width()) / | 224 static_cast<double>(resolution_set.min_width()) / |
| 224 static_cast<double>(resolution_set.max_height())); | 225 static_cast<double>(resolution_set.max_height())); |
| 225 double track_max_aspect_ratio = | 226 double track_max_aspect_ratio = |
| 226 std::min(resolution_set.max_aspect_ratio(), | 227 std::min(resolution_set.max_aspect_ratio(), |
| 227 static_cast<double>(resolution_set.max_width()) / | 228 static_cast<double>(resolution_set.max_width()) / |
| 228 static_cast<double>(resolution_set.min_height())); | 229 static_cast<double>(resolution_set.min_height())); |
| 229 double track_max_frame_rate = frame_rate_set.Max(); | 230 double track_max_frame_rate = frame_rate_set.Max(); |
| 230 if (basic_constraint_set.frame_rate.HasIdeal()) { | 231 if (basic_constraint_set.frame_rate.HasIdeal()) { |
| 231 track_max_frame_rate = std::min( | 232 track_max_frame_rate = std::min( |
| 232 track_max_frame_rate, std::max(basic_constraint_set.frame_rate.Ideal(), | 233 track_max_frame_rate, std::max(basic_constraint_set.frame_rate.Ideal(), |
| 233 frame_rate_set.Min())); | 234 frame_rate_set.Min())); |
| 234 } | 235 } |
| 235 // VideoTrackAdapter uses a frame rate of 0.0 to disable frame-rate | 236 // VideoTrackAdapter uses a frame rate of 0.0 to disable frame-rate |
| 236 // adjustment. | 237 // adjustment. |
| 237 if (track_max_frame_rate >= source_format.frame_rate) | 238 if (track_max_frame_rate >= source_format.frame_rate) |
| 238 track_max_frame_rate = 0.0; | 239 track_max_frame_rate = 0.0; |
| 239 | 240 |
| 241 base::Optional<gfx::Size> expected_native_size; |
| 242 if (expect_source_native_size) |
| 243 expected_native_size = source_format.frame_size; |
| 244 |
| 240 return VideoTrackAdapterSettings( | 245 return VideoTrackAdapterSettings( |
| 241 track_max_width, track_max_height, track_min_aspect_ratio, | 246 track_max_width, track_max_height, track_min_aspect_ratio, |
| 242 track_max_aspect_ratio, track_max_frame_rate); | 247 track_max_aspect_ratio, track_max_frame_rate, expected_native_size); |
| 243 } | 248 } |
| 244 | 249 |
| 245 } // namespace content | 250 } // namespace content |
| OLD | NEW |