通过API实现C#对硬件的控制(一)

转:http://blog.csdn.net/cocosoft/article/details/2086710


最近在做项目的过程中,涉及到对硬件启用及禁用的功能(在指定时间段内才能启用硬件)。因为C#自身对硬件的操作基本为零,为此,搜索了一下MSDN中与设备相关的API函数。还果然就有。下面一一列举出各函数的原型及相关的说明文档。并将其转为C#代码实现。

函数一: RegisterDeviceNotification

功能:注册设备或者设备类型,在指定的窗口返回相关的信息

原型:

HDEVNOTIFY WINAPI RegisterDeviceNotification(
  __in  HANDLE hRecipient,
  __in  LPVOID NotificationFilter,
  __in  DWORD Flags
);

参考说明文档:http://msdn2.microsoft.com/en-us/library/aa363431.aspx

转为C#后的代码为:

        [DllImport( " user32.dll " , CharSet  =  CharSet.Auto)]
        
public   static   extern  IntPtr RegisterDeviceNotification(IntPtr hRecipient, DEV_BROADCAST_DEVICEINTERFACE NotificationFilter, UInt32 Flags);
        [StructLayout(LayoutKind.Sequential)]
        
public   class  DEV_BROADCAST_DEVICEINTERFACE
        
{
            
public int dbcc_size;
            
public int dbcc_devicetype;
            
public int dbcc_reserved;
        }


函数二:UnregisterDeviceNotification

功能:通过名柄,关闭指定设备的信息。(主要应用于清理非托管资源,并与RegisterDeviceNotification配对使用)

原型:

BOOL WINAPI UnregisterDeviceNotification(
  __in  HDEVNOTIFY Handle
);

参考说明文档:http://msdn2.microsoft.com/en-us/library/aa363475(VS.85).aspx

转为C#后的代码:

        [DllImport( " user32.dll " , CharSet  =  CharSet.Auto)]
        
public   static   extern   uint  UnregisterDeviceNotification(IntPtr hHandle);
函数三:SetupDiGetClassDevs

功能:获取一个指定类别或全部类别的所有已安装设备的信息。

原型:

HDEVINFO  SetupDiGetClassDevs(    IN LPGUID  ClassGuid,  OPTIONAL    IN PCTSTR  Enumerator,  OPTIONAL    IN HWND  hwndParent,  OPTIONAL    IN DWORD  Flags    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792959.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , SetLastError  =   true )]
        
public   static   extern  IntPtr SetupDiGetClassDevs( ref  Guid gClass, UInt32 iEnumerator, IntPtr hParent, UInt32 nFlags);
函数四:SetupDiDestroyDeviceInfoList

功能:销毁一个设备信息集合,并且释放所有关联的内存。

原型:

WINSETUPAPI BOOL WINAPI  SetupDiDestroyDeviceInfoList(    IN HDEVINFO  DeviceInfoSet    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792991.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , SetLastError  =   true )]
        
public   static   extern   int  SetupDiDestroyDeviceInfoList(IntPtr lpInfoSet);
函数五:SetupDiEnumDeviceInfo

功能:枚举指定设备信息集合的成员,并将数据放在SP_DEVINFO_DATA中。

原型:

WINSETUPAPI BOOL WINAPI  SetupDiEnumDeviceInfo( 
IN HDEVINFO  DeviceInfoSet,
IN DWORD  MemberIndex,
 OUT PSP_DEVINFO_DATA  DeviceInfoData    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792983.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , SetLastError  =   true )]
        
public   static   extern   bool  SetupDiEnumDeviceInfo(IntPtr lpInfoSet, UInt32 dwIndex, SP_DEVINFO_DATA devInfoData);
        
/// <summary>
        
/// 设备信息数据
    
/// </summary>

        [StructLayout(LayoutKind.Sequential)]
        
public   class  SP_DEVINFO_DATA
        
{
            
public int cbSize;
            
public Guid classGuid;
            
public int devInst;
            
public ulong reserved;
        }
;

函数六:SetupDiGetDeviceRegistryProperty

功能:获取指定设备的属性。

原型:

WINSETUPAPI BOOL WINAPI  SetupDiGetDeviceRegistryProperty(
IN HDEVINFO  DeviceInfoSet, 
IN PSP_DEVINFO_DATA  DeviceInfoData, 
IN DWORD  Property,
OUT PDWORD  PropertyRegDataType,
OPTIONAL    OUT PBYTE  PropertyBuffer, 
IN DWORD  PropertyBufferSize, 
OUT PDWORD  RequiredSize  OPTIONAL    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792967.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , SetLastError  =   true )]
        
public   static   extern   bool  SetupDiGetDeviceRegistryProperty(IntPtr lpInfoSet, SP_DEVINFO_DATA DeviceInfoData, UInt32 Property, UInt32 PropertyRegDataType, StringBuilder PropertyBuffer, UInt32 PropertyBufferSize, IntPtr RequiredSize);
函数七:SetupDiSetClassInstallParams

功能:停用设备。

原型:

WINSETUPAPI BOOL WINAPI 
 SetupDiSetClassInstallParams(
    IN HDEVINFO  DeviceInfoSet, 
    IN PSP_DEVINFO_DATA  DeviceInfoData,
    OPTIONAL    IN PSP_CLASSINSTALL_HEADER  ClassInstallParams,
    OPTIONAL    IN DWORD  ClassInstallParamsSize    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792876.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , SetLastError  =   true , CharSet  =  CharSet.Auto)]
        
public   static   extern   bool  SetupDiSetClassInstallParams(IntPtr DeviceInfoSet, IntPtr DeviceInfoData, IntPtr ClassInstallParams,  int  ClassInstallParamsSize);
函数八:SetupDiCallClassInstaller

功能:启用设备。

原型:

WINSETUPAPI BOOL WINAPI
  SetupDiCallClassInstaller(
    IN DI_FUNCTION  InstallFunction,
    IN HDEVINFO  DeviceInfoSet,
    IN PSP_DEVINFO_DATA  DeviceInfoData  OPTIONAL    );

参考说明文档:http://msdn2.microsoft.com/en-us/library/ms792989.aspx

转为C#后的代码:

        [DllImport( " setupapi.dll " , CharSet  =  CharSet.Auto)]
        
public   static   extern  Boolean SetupDiCallClassInstaller(UInt32 InstallFunction, IntPtr DeviceInfoSet, IntPtr DeviceInfoData);
相关推荐

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页
评论

打赏作者

努力的犀牛

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值