Chromium Code Reviews| Index: media/video/capture/win/capability_list_win.cc |
| diff --git a/media/video/capture/win/capability_list_win.cc b/media/video/capture/win/capability_list_win.cc |
| index 9b4531b82820107c2908b61dd6fe0ddfdf366d4d..6d58ee8b64e629a9d3c0499b8d9aa625c4e7df87 100644 |
| --- a/media/video/capture/win/capability_list_win.cc |
| +++ b/media/video/capture/win/capability_list_win.cc |
| @@ -4,117 +4,22 @@ |
| #include "media/video/capture/win/capability_list_win.h" |
| -#include <algorithm> |
| - |
| -#include "base/logging.h" |
| +#include "media/video/capture/video_capture_device.h" |
| namespace media { |
| -namespace { |
| - |
| -// Help structure used for comparing video capture capabilities. |
| -struct ResolutionDiff { |
| - const VideoCaptureCapabilityWin* capability; |
| - int diff_height; |
| - int diff_width; |
| - int diff_frame_rate; |
| -}; |
| - |
| -bool CompareHeight(const ResolutionDiff& item1, const ResolutionDiff& item2) { |
| - return abs(item1.diff_height) < abs(item2.diff_height); |
| -} |
| - |
| -bool CompareWidth(const ResolutionDiff& item1, const ResolutionDiff& item2) { |
| - return abs(item1.diff_width) < abs(item2.diff_width); |
| -} |
| - |
| -bool CompareFrameRate(const ResolutionDiff& item1, |
| - const ResolutionDiff& item2) { |
| - return abs(item1.diff_frame_rate) < abs(item2.diff_frame_rate); |
| -} |
| - |
| -bool CompareColor(const ResolutionDiff& item1, const ResolutionDiff& item2) { |
| - return item1.capability->supported_format.pixel_format < |
| - item2.capability->supported_format.pixel_format; |
| -} |
| - |
| -} // namespace. |
| - |
| -CapabilityList::CapabilityList() { |
| - DetachFromThread(); |
| -} |
| - |
| -CapabilityList::~CapabilityList() {} |
| -// Appends an entry to the list. |
| -void CapabilityList::Add(const VideoCaptureCapabilityWin& capability) { |
| - DCHECK(CalledOnValidThread()); |
| - capabilities_.push_back(capability); |
| -} |
| - |
| -const VideoCaptureCapabilityWin& CapabilityList::GetBestMatchedFormat( |
| - int requested_width, |
| - int requested_height, |
| - float requested_frame_rate) const { |
| - DCHECK(CalledOnValidThread()); |
| - DCHECK(!capabilities_.empty()); |
| - |
| - std::list<ResolutionDiff> diff_list; |
| - |
| - // Loop through the candidates to create a list of differentials between the |
| - // requested resolution and the camera capability. |
| - for (Capabilities::const_iterator it = capabilities_.begin(); |
| - it != capabilities_.end(); ++it) { |
| - ResolutionDiff diff; |
| - diff.capability = &(*it); |
| - diff.diff_width = it->supported_format.frame_size.width() - requested_width; |
| - diff.diff_height = |
| - it->supported_format.frame_size.height() - requested_height; |
| - // The 1000 allows using integer arithmetic for f.i. 29.971 fps. |
| - diff.diff_frame_rate = |
| - 1000 * ((static_cast<float>(it->frame_rate_numerator) / |
| - it->frame_rate_denominator) - |
| - requested_frame_rate); |
| - diff_list.push_back(diff); |
| - } |
| - |
| - // Sort the best height candidates. |
| - diff_list.sort(&CompareHeight); |
| - int best_diff = diff_list.front().diff_height; |
| - for (std::list<ResolutionDiff>::iterator it = diff_list.begin(); |
| - it != diff_list.end(); ++it) { |
| - if (it->diff_height != best_diff) { |
| - // Remove all candidates but the best. |
| - diff_list.erase(it, diff_list.end()); |
| - break; |
| +CapabilityList::const_iterator GetBestMatchedCapability( |
| + const VideoCaptureFormat& requested, |
| + const CapabilityList& capabilities) { |
| + CapabilityList::const_iterator best_match = capabilities.begin(); |
| + for (CapabilityList::const_iterator it = capabilities.begin(); |
|
mcasas
2014/10/13 08:18:47
Consider using:
for (const auto& it : capabiliti
|
| + it != capabilities.end(); ++it) { |
| + if (DiffVideoCaptureFormat(requested, it->supported_format) < |
| + DiffVideoCaptureFormat(requested, best_match->supported_format)) { |
| + best_match = it; |
| } |
| } |
| - |
| - // Sort the best width candidates. |
| - diff_list.sort(&CompareWidth); |
| - best_diff = diff_list.front().diff_width; |
| - for (std::list<ResolutionDiff>::iterator it = diff_list.begin(); |
| - it != diff_list.end(); ++it) { |
| - if (it->diff_width != best_diff) { |
| - // Remove all candidates but the best. |
| - diff_list.erase(it, diff_list.end()); |
| - break; |
| - } |
| - } |
| - |
| - // Sort the best frame rate candidates. |
| - diff_list.sort(&CompareFrameRate); |
| - best_diff = diff_list.front().diff_frame_rate; |
| - for (std::list<ResolutionDiff>::iterator it = diff_list.begin(); |
| - it != diff_list.end(); ++it) { |
| - if (it->diff_frame_rate != best_diff) { |
| - diff_list.erase(it, diff_list.end()); |
| - break; |
| - } |
| - } |
| - |
| - // Decide the best color format. |
| - diff_list.sort(&CompareColor); |
| - return *diff_list.front().capability; |
| + return best_match; |
| } |
| } // namespace media |