一个用于驱动摄像头的类

原创 2005年01月01日 13:59:00

    本文是借助avicap32.dll库来驱动摄像头。做到了抓图、录像功能。
using System;
using System.Runtime.InteropServices;
using System.Drawing;
using System.Drawing.Imaging;

namespace using System;
using System.Runtime.InteropServices;
using System.Drawing;
using System.Drawing.Imaging;

namespace PickHead
{
 /// <summary>
 /// 一个控制摄像头的类
 /// </summary>
 public class Pick
 {
  private const int WM_USER = 0x400;
  private const int WS_CHILD = 0x40000000;
  private const int WS_VISIBLE = 0x10000000;
  private const int WM_CAP_START = WM_USER;
  private const int WM_CAP_STOP = WM_CAP_START + 68;
  private const int WM_CAP_DRIVER_CONNECT = WM_CAP_START + 10;
  private const int WM_CAP_DRIVER_DISCONNECT = WM_CAP_START + 11;
  private const int WM_CAP_SAVEDIB = WM_CAP_START + 25;
  private const int WM_CAP_GRAB_FRAME = WM_CAP_START + 60;
  private const int WM_CAP_SEQUENCE = WM_CAP_START + 62;
  private const int WM_CAP_FILE_SET_CAPTURE_FILEA = WM_CAP_START + 20;
  private const int WM_CAP_SEQUENCE_NOFILE =WM_CAP_START+ 63;
  private const int WM_CAP_SET_OVERLAY =WM_CAP_START+ 51;
  private const int WM_CAP_SET_PREVIEW =WM_CAP_START+ 50;
  private const int WM_CAP_SET_CALLBACK_VIDEOSTREAM = WM_CAP_START +6;
  private const int WM_CAP_SET_CALLBACK_ERROR=WM_CAP_START +2;
  private const int WM_CAP_SET_CALLBACK_STATUSA= WM_CAP_START +3;
  private const int WM_CAP_SET_CALLBACK_FRAME= WM_CAP_START +5;
  private const int WM_CAP_SET_SCALE=WM_CAP_START+ 53;
  private const int WM_CAP_SET_PREVIEWRATE=WM_CAP_START+ 52;
  private IntPtr hWndC;
  private bool bStat = false;
  
  private IntPtr mControlPtr;
  private int mWidth;
  private int mHeight;
  private int mLeft;
  private int mTop;
  
  /// <summary>
  /// 初始化摄像头
  /// </summary>
  /// <param name="handle">控件的句柄</param>
  /// <param name="left">开始显示的左边距</param>
  /// <param name="top">开始显示的上边距</param>
  /// <param name="width">要显示的宽度</param>
  /// <param name="height">要显示的长度</param>
  public Pick(IntPtr handle, int left, int top, int width,int height)
  {
   mControlPtr = handle;
   mWidth = width;
   mHeight = height;
   mLeft = left;
   mTop = top;
  }

  [DllImport("avicap32.dll")]
  private static extern IntPtr capCreateCaptureWindowA(byte[] lpszWindowName, int dwStyle, int x, int y, int nWidth, int nHeight, IntPtr hWndParent, int nID);
 
  [DllImport("avicap32.dll")]
  private static extern int capGetVideoFormat(IntPtr hWnd, IntPtr psVideoFormat, int wSize );
  [DllImport("User32.dll")]
  private static extern bool SendMessage(IntPtr hWnd, int wMsg, int wParam, long lParam);

  /// <summary>
  /// 开始显示图像
  /// </summary>
  public void Start()
  {
   if (bStat)
    return;
   
   bStat = true;
   byte[] lpszName = new byte[100];
   
   hWndC = capCreateCaptureWindowA(lpszName,WS_CHILD|WS_VISIBLE ,mLeft,mTop,mWidth,mHeight,mControlPtr,0);

   if (hWndC.ToInt32() != 0)
   {
    SendMessage(hWndC, WM_CAP_SET_CALLBACK_VIDEOSTREAM, 0, 0);
    SendMessage(hWndC, WM_CAP_SET_CALLBACK_ERROR, 0, 0);
    SendMessage(hWndC, WM_CAP_SET_CALLBACK_STATUSA, 0, 0);
    SendMessage(hWndC, WM_CAP_DRIVER_CONNECT, 0, 0);
    SendMessage(hWndC, WM_CAP_SET_SCALE, 1, 0);
    SendMessage(hWndC, WM_CAP_SET_PREVIEWRATE, 66, 0);
    SendMessage(hWndC, WM_CAP_SET_OVERLAY, 1, 0);
    SendMessage(hWndC, WM_CAP_SET_PREVIEW, 1, 0);
   }

   return;

 


  }

  /// <summary>
  /// 停止显示
  /// </summary>
  public void Stop()
  {
   SendMessage(hWndC, WM_CAP_DRIVER_DISCONNECT, 0, 0);
   bStat = false;
  }

  /// <summary>
  /// 抓图
  /// </summary>
  /// <param name="path">要保存bmp文件的路径</param>
  public void GrabImage(string path)
  {
   
   IntPtr hBmp = Marshal.StringToHGlobalAnsi(path);
   SendMessage(hWndC,WM_CAP_SAVEDIB,0,hBmp.ToInt64());

  }

  /// <summary>
  /// 录像
  /// </summary>
  /// <param name="path">要保存avi文件的路径</param>
  public void Kinescope(string path)
  {
   IntPtr hBmp = Marshal.StringToHGlobalAnsi(path);
   SendMessage(hWndC,WM_CAP_FILE_SET_CAPTURE_FILEA,0,hBmp.ToInt64());
   SendMessage(hWndC, WM_CAP_SEQUENCE, 0, 0);
  }

  /// <summary>
  /// 停止录像
  /// </summary>
  public void StopKinescope()
  {
   SendMessage(hWndC, WM_CAP_STOP, 0, 0);
  }

 }
}

.Net里一个用于驱动摄像头的类

本文是借助avicap32.dll库来驱动摄像头。做到了抓图、录像功能。using System;using System.Runtime.InteropServices;using System.D...
  • enginetanmary
  • enginetanmary
  • 2007年07月27日 15:50
  • 356

.Net里一个用于驱动摄像头的类

本文是借助avicap32.dll库来驱动摄像头。做到了抓图、录像功能。  using System;  using System.Runtime.InteropServices;  using Sy...
  • metababy
  • metababy
  • 2005年12月30日 10:25
  • 1613

opencv学习笔记(二十二)——驱动双摄像头

问题描述:驱动双目摄像头——这是我研究双目视觉系统的第一步,俗话说万事开头难,我这第一步搞得真是头破血流啊,终于在我百般努力下驱动起这个双目摄像头了。在驱动的过程中,我发现当我们驱动多个摄像头时,op...
  • hx1298234467
  • hx1298234467
  • 2016年01月07日 18:38
  • 2897

驱动摄像头的类

本文是借助avicap32.dll库来驱动摄像头。做到了抓图、录像功能。using System;using System.Runtime.InteropServices;using System.D...
  • enginetanmary
  • enginetanmary
  • 2008年03月03日 13:38
  • 348

Windows摄像头驱动研究(一)

Windows 驱动基础系列,转载请标明出处:http://blog.csdn.net/ikerpeng/article/details/38865317 摄像头驱动的主要目的是通过通过硬件...
  • u012192662
  • u012192662
  • 2014年08月27日 15:18
  • 2283

个人封装的一个Camera类

本文转自:http://blog.csdn.net/wz331956750/article/details/24291479
  • FightForFuture2013
  • FightForFuture2013
  • 2014年04月22日 11:07
  • 1763

驱动摄像头的三种方式

备注:本文部分解决方案来自互联网,本文仅作为自己学习笔记,不存在任何商业目的   进来研究把硬件摄像头驱动起来,得到3种方法:VFW、DirectShow、OpenCV。   下面依次对3种方...
  • y601500359
  • y601500359
  • 2014年04月19日 12:28
  • 725

【C++程序设计】P123_4-10 设计一个用于人事管理的"人员“ 类

#include using namespace std; class Date{ public: int year,month,day; Date(){} Date(int y,int m...
  • u012306122
  • u012306122
  • 2013年11月15日 15:58
  • 915

从0写USB摄像头驱动程序

从0写USB摄像头驱动程序 1.构造一个usb_driver结构体 .id_table .probe 1.分配video_device结构体 2.设置 3.注册 2.下面具体分析probe函数中的内容...
  • u013985662
  • u013985662
  • 2015年10月01日 14:58
  • 1795

战舰v3|stm32f103 摄像头OV2640驱动程序

【硬件接线】 【最少接线】 模块ov2640 stm32f103 数据:D[0..7] 8根 PC[0..7] 串口:SCL、SDA 2根 uart3的PB10,11 其他...
  • ss343fd
  • ss343fd
  • 2017年01月24日 23:14
  • 2523
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个用于驱动摄像头的类
举报原因:
原因补充:

(最多只允许输入30个字)