aboutsummaryrefslogtreecommitdiffstats
path: root/src/native/windows/directshow/ds_capture_device.h
blob: a49859ed01418a79f56eefd6e236525711ab7df1 (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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
/*
 * SIP Communicator, the OpenSource Java VoIP and Instant Messaging client.
 *
 * Distributable under LGPL license.
 * See terms of license at gnu.org.
 */

/**
 * \file ds_capture_device.h
 * \brief DirectShow capture device.
 * \author Sebastien Vincent
 * \date 2010
 */

#ifndef DS_CAPTURE_DEVICE_H
#define DS_CAPTURE_DEVICE_H

#include <list>

#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <dshow.h>
#include "qedit.h"

#include "video_format.h"

/**
 * \class DSGrabberCallback
 * \brief Callback when DirectShow device capture frames.
 */
class DSGrabberCallback : public ISampleGrabberCB
{
public:
	/**
	 * \brief Constructor.
	 */
	DSGrabberCallback();

	/**
	 * \brief Destructor.
	 */
	~DSGrabberCallback();

	/**
	 * \brief Method callback when device capture a frame.
	 * \param time time when frame was received
	 * \param sample media sample
	 * \see ISampleGrabberCB
	 */
	virtual STDMETHODIMP SampleCB(double time, IMediaSample* sample);

	/**
	 * \brief Method callback when device buffer a frame.
	 * \param time time when frame was received
	 * \param buffer raw buffer
	 * \param len length of buffer
	 * \see ISampleGrabberCB
	 */
	virtual STDMETHODIMP BufferCB(double time, BYTE* buffer, long len);

	/**
	 * \brief Query if this COM object has the interface iid.
	 * \param iid interface requested
	 * \param ptr if method succeed, an object corresponding
	 * to the interface requested will be copied in this pointer
	 */
	virtual HRESULT STDMETHODCALLTYPE QueryInterface(const IID& iid, void** ptr);

	/**
	 * \brief Adding a reference.
	 * \return number of reference hold
	 */
    STDMETHODIMP_(ULONG) AddRef();

	/**
	 * \brief Release a reference.
	 * \return number of reference hold
	 */
    STDMETHODIMP_(ULONG) Release();
};

/**
 * \class DSCaptureDevice
 * \brief DirectShow capture device.
 *
 * Once a DSCapture has been obtained by DSManager, do not
 * forget to build the graph and optionally set a format.
 */
class DSCaptureDevice
{
public:
	/**
	 * \brief Constructor.
	 * \param name name of the capture device
	 */
	DSCaptureDevice(const WCHAR* name);

	/**
	 * \brief Destructor.
	 */
	~DSCaptureDevice();

	/**
	 * \brief Get name of the capture device.
	 * \return name of the capture device
	 */
	const WCHAR* getName() const;

	/**
	 * \brief Initialize the device.
	 * \param moniker moniker of the capture device
	 * \return true if initialization succeed, false otherwise (in this
	 * case the capture device have to be deleted)
	 */
	bool initDevice(IMoniker* moniker);

	/**
	 * \brief Set video format.
	 * \param format video format
	 * \return true if change is successful, false otherwise (format unsupported, ...)
	 * \note This method stop stream so you have to call start() after.
	 */
	bool setFormat(const VideoFormat& format);

	/**
	 * \brief Get list of supported formats.
	 * \return list of supported formats.
	 */
	std::list<VideoFormat> getSupportedFormats() const;

	/**
	 * \brief Build the filter graph for this capture device.
	 * \return true if success, false otherwise
	 * \note Call this method before start().
	 */
	bool buildGraph();

	/**
	 * \brief get callback object.
	 * \return callback
	 */
	DSGrabberCallback* getCallback();

	/**
	 * \brief Set callback object when receiving new frames.
	 * \param callback callback object to set
	 */
	void setCallback(DSGrabberCallback* callback);

	/**
	 * \brief Start capture device.
	 * \return false if problem, true otherwise
	 */
	bool start();

	/**
	 * \brief Stop capture device.
	 * \return false if problem, true otherwise
	 */
	bool stop();

    /**
     * \brief Get current format.
     * \return current format
     */
    VideoFormat getFormat() const;

    /**
     * \brief Get current bit per pixel.
     * \return bit per pixel of images
     */
    size_t getBitPerPixel();

private:
	/**
	 * \brief Initialize list of supported size.
	 */
	void initSupportedFormats();
	
    /**
	 * \brief Name of the capture device.
	 */
	WCHAR* m_name;

    /**
     * \brief Callback.
     */
    DSGrabberCallback* m_callback;

	/**
	 * \brief List of VideoFormat.
	 */
	std::list<VideoFormat> m_formats;
    
	/**
	 * \brief Reference of the filter graph.
	 */
	IFilterGraph2* m_filterGraph;

	/**
	 * \brief Reference of the capture graph builder.
	 */
	ICaptureGraphBuilder2* m_captureGraphBuilder;

	/**
	 * \brief Controller of the graph.
	 */
	IMediaControl* m_graphController;

	/**
	 * \brief Source filter.
	 */
	IBaseFilter* m_srcFilter;
	
	/**
	 * \brief Sample grabber filter.
	 */
	IBaseFilter* m_sampleGrabberFilter;

	/**
	 * \brief The null renderer.
	 */
	IBaseFilter* m_renderer;

	/**
	 * \brief The sample grabber.
	 */
	ISampleGrabber* m_sampleGrabber;

    /**
     * \brief Current format.
     */
    VideoFormat m_format;

    /**
     * \brief Current bit per pixel.
     */
    size_t m_bitPerPixel;
};

#endif /* DS_CAPTURE_DEVICE_H */