I'm trying to get video from an Axis P5515 IP camera to feed into DirectShow, but all I get in the render window is a black screen.
Nearly every search I do looking for an IP camera source capture filter ends at the "DirectShow Video Source Filter for JPEG and M-JPEG IP Cameras" page at http://alax.info/blog/1216 (which has the same files attached to it as the "IP Video Source: 64-bit version, resolution flexibility, Adobe FMLE" page at http://alax.info/blog/1223 where I first found them). I downloaded and installed the 32 bit IpVideoSource
device. I have it configured with this URL (username and password substitution in effect):
http://user:password@192.168.14.101:1026/axis-cgi/mjpg/video.cgi?resolution=640x360
When I plug that URL into Firefox, Chrome and Opera, they all display the video stream without complaints. When I put it into Safari, I get a warning that it might be a phishing site because it has a username and password, but when I say OK, Safari displays the video stream. When I try to open the video stream with Internet Exploiter (11), it just says
One of my searches had turned up the "MediaTools to deliver video from network/IP cameras and video servers into DirectShow environment" page at http://alax.info/blog/741 which has a "Quick Usage Example" that I tried to follow, but I was unable to complete the filter graph in GraphEdit because the "JPEG Decoder Filter" it calls for is not available: The CodingI.dll that would contain it is not in either of the packages I downloaded. The "Quick Usage Example" should produce a graph as shown in the illustration on http://alax.info/blog/1216
Since I couldn't get results by following the provided instructions, I tried right-clicking the output pin of the Office_cam
instantiation of the IpVideoSource
filter in GraphEdit, which generated this graph
When I try to run the graph, an Active Movie window is opened, but it's black. The C:\ProgramData\IpVideoSource.log
file contains this data:
*** Exception
Process: 0x000288e0, Thread: 0x00028858, Date: 1/30/2017, Time: 11:34:59 AM, Application: graphedt.exe
Module: IpVideoSource.dll, Product Version: 1.0.3.1, File Version: 1.0.3.1506, File Time: 12.04.2015, 20:13
Code: 0xe06d7363, Flags: 0x00000001, Address: 0x75e6c54f
Parameters: 0x19930520, 0x02faea88, 0x5321d498
Native Parameters: 0x80190191, ...
** Call Stack
KERNELBASE!75E6C54F RaiseException (+ 88) @75E60000
IpVideoSource!531F7DCF @531A0000
IpVideoSource!531A281F @531A0000
IpVideoSource!531B5BD2 @531A0000
ntdll!773DF5DE RtlImageNtHeaderEx (+ 169) @773B0000
*** Exception
Process: 0x000288e0, Thread: 0x00028858, Date: 1/30/2017, Time: 11:34:59 AM, Application: graphedt.exe
Module: IpVideoSource.dll, Product Version: 1.0.3.1, File Version: 1.0.3.1506, File Time: 12.04.2015, 20:13
Code: 0xe06d7363, Flags: 0x00000001, Address: 0x75e6c54f
Parameters: 0x19930520, 0x02faea88, 0x5321d498
Native Parameters: 0x80190191, ...
** Call Stack
KERNELBASE!75E6C54F RaiseException (+ 88) @75E60000
IpVideoSource!531F7DCF @531A0000
IpVideoSource!531A281F @531A0000
IpVideoSource!531B5BD2 @531A0000
ntdll!773DF5DE RtlImageNtHeaderEx (+ 169) @773B0000
*** Exception
Process: 0x000288e0, Thread: 0x00028858, Date: 1/30/2017, Time: 11:34:59 AM, Application: graphedt.exe
Module: IpVideoSource.dll, Product Version: 1.0.3.1, File Version: 1.0.3.1506, File Time: 12.04.2015, 20:13
Code: 0xe06d7363, Flags: 0x00000003, Address: 0x75e6c54f
Parameters: 0x19930520, 0x02faea88, 0x5321d498
Native Parameters: 0x80190191, ...
** Call Stack
IpVideoSource!531F0727 @531A0000
IpVideoSource!531F5E93 @531A0000
IpVideoSource!531F61A3 @531A0000
IpVideoSource!531F6896 @531A0000
IpVideoSource!531F0819 @531A0000
ntdll!77413529 RtlDestroyEnvironment (+ 1227) @773B0000
ntdll!774134FB RtlDestroyEnvironment (+ 1181) @773B0000
ntdll!773C0143 KiUserExceptionDispatcher (+ 15) @773B0000
IpVideoSource!531F7DCF @531A0000
IpVideoSource!531A281F @531A0000
IpVideoSource!531B5BD2 @531A0000
ntdll!773DF5DE RtlImageNtHeaderEx (+ 169) @773B0000
I've tried combinations of lots of filters, including the Alax.Info HTTP Stream File Renderer
, Alax.Info JPEG Frame Decoder
, Alax.Info HTTP Stream Parser
, AXIS MJPEG Video Decoder
, MJPEG Decompressor
, Smart Tee
, two different Video Renderer
filters, and probably others, all to no avail.
I'm having this problem on both 32 bit and 64 bit windows 7 with the DirectX SDK (June 2010) and windows 7 SDKs installed, so I suspect I've overlooked something.
Any useful suggestions will be appreciated.
IpVideoSource.log looks relevant (keyword is 0x80190191
) and suggests that the problem is caused by HTTP 401 Unauthorized error sent by camera in response. That is, the camera does not accept credentials, which in turn - taking in consideration that it's Axis camera - is caused by setting on camera that requires safe HTTP authentication method such as digest.
IpVideoSource.dll currently implements DirectShow source filter which is restricted to basic authentication method only (WINHTTP_AUTH_SCHEME_BASIC
).
For troubleshooting, one can disable authentication on camera to check if it helps to get the picture. As a workaround, with a camera like Axis that presumably supports HTTPS protocol as well (at the time of IpVideoSource.dll development rare IP cameras supported HTTPS, and, well, digest authentication too), it is possible to use HTTPS with basic authentication so that plain text password on the wire is protected by secure sockets layer.
User contributions licensed under CC BY-SA 3.0