summaryrefslogtreecommitdiffstats
path: root/media/video/capture/win/capability_list_win.h
blob: c07b220b0d55dc246355f84ef141ae3267796b26 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// Copyright (c) 2012 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.

// Windows specific implementation of VideoCaptureDevice.
// DirectShow is used for capturing. DirectShow provide its own threads
// for capturing.

#ifndef MEDIA_VIDEO_CAPTURE_WIN_CAPABILITY_LIST_WIN_H_
#define MEDIA_VIDEO_CAPTURE_WIN_CAPABILITY_LIST_WIN_H_

#include <list>

#include "base/threading/non_thread_safe.h"
#include "media/video/capture/video_capture_types.h"

namespace media {

struct VideoCaptureCapabilityWin : public VideoCaptureCapability {
  explicit VideoCaptureCapabilityWin(int index)
      : stream_index(index),
        frame_rate_numerator(0),
        frame_rate_denominator(1) {}
  int stream_index;
  // Internally to Media Foundation Api type devices we use rational framerates
  // so framerates can be properly represented, f.i. 29.971fps= 30000/1001.
  int frame_rate_numerator;
  int frame_rate_denominator;
};

class CapabilityList : public base::NonThreadSafe {
 public:
  CapabilityList();
  ~CapabilityList();

  bool empty() const { return capabilities_.empty(); }

  // Appends an entry to the list.
  void Add(const VideoCaptureCapabilityWin& capability);

  // Loops through the list of capabilities and returns an index of the best
  // matching capability.  The algorithm prioritizes height, width, frame rate
  // and color format in that order.
  const VideoCaptureCapabilityWin& GetBestMatchedCapability(
      int requested_width, int requested_height,
      int requested_frame_rate) const;

 private:
  typedef std::list<VideoCaptureCapabilityWin> Capabilities;
  Capabilities capabilities_;

  DISALLOW_COPY_AND_ASSIGN(CapabilityList);
};

}  // namespace media

#endif  // MEDIA_VIDEO_CAPTURE_WIN_CAPABILITY_LIST_WIN_H_