Win32 API:ICredentialProviderCredentialWithFieldOptions 接口(Credentialprovider.h)
ICredentialProviderCredentialWithFieldOptions 接口是 Windows Credential Provider API 的一部分,用于提供对 Credential Provider 凭据字段选项的支持。这个接口扩展了 ICredentialProviderCredential 接口,允许 Credential Provider 凭据对象实现者为每个字段提供额外的选项信息。以下是 ICredentialProviderCredentialWithFieldOptions 接口的基本定义:DECLARE_INTERFACE_IID_(ICredentialProviderCredentialWithFieldOptions, ICredentialProviderCredential){ STDMETHOD(GetFieldOptions)( _In_ DWORD dwFieldID, _Out_ CREDENTIAL_PROVIDER_CREDENTIAL_FIELD_OPTIONS *pcpcfo ) ...
Win32 API:ICredentialProviderCredentialEvents 接口(Credentialprovider.h)
ICredentialProviderCredentialEvents 接口是 Windows Credential Provider API 的一部分,用于向凭据对象发送事件通知。Credential Provider 允许开发者实现这个接口,以接收来自 Credential Provider 的事件,如连接、断开连接等。以下是 ICredentialProviderCredentialEvents 接口的基本定义:DECLARE_INTERFACE_IID_(ICredentialProviderCredentialEvents, IUnknown){ STDMETHOD(SetFieldState)( _In_ DWORD dwFieldID, _In_ CREDENTIAL_PROVIDER_FIELD_STATE cpfs ) PURE; STDMETHOD(SetFieldInteractiveState)( _In_ DWORD dwFieldID, _In_ CREDENTIAL_PROVIDER...
Win32 API:ICredentialProviderCredential 接口(Credentialprovider.h)
ICredentialProviderCredential 接口是 Windows Credential Provider API 的一部分,用于表示 Credential Provider 中的单个凭据对象。Credential Provider 允许开发者实现这个接口以提供用户身份验证方法,并集成到 Windows 登录系统中。以下是 ICredentialProviderCredential 接口的基本定义:DECLARE_INTERFACE_IID_(ICredentialProviderCredential, IUnknown){ STDMETHOD(Advise)( _In_ ICredentialProviderCredentialEvents *pcpce, _In_ UINT_PTR upAdviseContext ) PURE; STDMETHOD(UnAdvise)() PURE; STDMETHOD(SetSelected)(_Out_ BOOL *pbAutoLogon) PURE; STDMETHOD...
Win32 API:ICredentialProvider 接口(Credentialprovider.h)
ICredentialProvider 接口是 Windows Credential Provider API 的核心接口之一,用于创建和管理凭据提供者。Credential Provider 允许开发者实现自定义的用户身份验证方法,并集成到 Windows 登录系统中。以下是 ICredentialProvider 接口的基本定义:DECLARE_INTERFACE_IID_(ICredentialProvider, IUnknown){ STDMETHOD(SetUsageScenario)( _In_ CREDENTIAL_PROVIDER_USAGE_SCENARIO cpus, _In_ DWORD dwFlags ) PURE; STDMETHOD(SetSerialization)( _In_ const CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION *pcpcs ) PURE; STDMETHOD(Advise)( _Inout_ ICred...
Win32 API:IConnectableCredentialProviderCredential 接口(Credentialprovider.h)
在 Credential Provider API 中,IConnectableCredentialProviderCredential 接口用于表示可连接的凭据提供者凭据对象。这个接口允许 Credential Provider 通知凭据对象发生的连接和断开连接事件。以下是 IConnectableCredentialProviderCredential 接口的基本定义:DECLARE_INTERFACE_IID_(IConnectableCredentialProviderCredential, ICredentialProviderCredential){ STDMETHOD(Advise)(_Inout_ IConnectableCredentialProviderCredentialEvents *pcpce) PURE; STDMETHOD(UnAdvise)() PURE;};主要的方法包括: Advise: 用于通知凭据对象连接事件。当 Credential Provider 连接到凭据对象时,通过这个方法向凭据对象提供一个 IConnectableCred...
Win32 API:CREDENTIAL_PROVIDER_USAGE_SCENARIO 枚举(Credentialprovider.h)
CREDENTIAL_PROVIDER_USAGE_SCENARIO 枚举是 Windows Credential Provider API 中的一部分,用于表示 Credential Provider 的使用场景。这个枚举定义了一些场景,用于标识 Credential Provider 正在处理的具体情境。以下是可能的枚举值:typedef enum _CREDENTIAL_PROVIDER_USAGE_SCENARIO { CPUS_INVALID = 0, CPUS_LOGON = 1, CPUS_UNLOCK_WORKSTATION = 2, CPUS_CHANGE_PASSWORD = 3, CPUS_CREDUI = 4, CPUS_PLAP = 5, CPUS_FIRST_TIME = 6, CPUS_CHANGE_PIN = 7, CPUS_UNLOCK_WORKSTATION_PLAP = 8, CPUS_SYNC = 9, CPUS_TICKET_CREATION = 10} CREDENTIAL_PROVIDER_USAGE_SCENARIO...
Win32 API:CREDENTIAL_PROVIDER_FIELD_TYPE 枚举(Credentialprovider.h)
CREDENTIAL_PROVIDER_FIELD_TYPE 枚举是 Windows Credential Provider API 中的一部分,用于定义 Credential Provider 中字段(如用户名、密码等)的数据类型。这个枚举包含以下值:typedef enum _CREDENTIAL_PROVIDER_FIELD_TYPE { CPFT_INVALID = 0, CPFT_LARGE_TEXT, CPFT_SMALL_TEXT, CPFT_COMMAND_LINK, CPFT_EDIT_TEXT, CPFT_PASSWORD_TEXT, CPFT_TILE_IMAGE, CPFT_CHECKBOX, CPFT_COMBOBOX, CPFT_SUBMIT_BUTTON} CREDENTIAL_PROVIDER_FIELD_TYPE; CPFT_INVALID: 无效类型。 CPFT_LARGE_TEXT: 大文本类型。 CPFT_SMALL_TEXT: 小文本类型。 CPFT_COMMAND_LINK: 命令链接类型。 CPFT_EDIT_TEXT:...
Win32 API:CREDENTIAL_PROVIDER_FIELD_INTERACTIVE_STATE 枚举(Credentialprovider.h)
CREDENTIAL_PROVIDER_FIELD_INTERACTIVE_STATE 枚举是 Windows Credential Provider API 中的一部分,用于表示交互式字段的状态。这个枚举定义了字段可能的几种状态,通常用于描述用户与登录界面中的字段进行交互的情况。以下是可能的枚举值:typedef enum _CREDENTIAL_PROVIDER_FIELD_INTERACTIVE_STATE { CPFIS_NONE, CPFIS_READONLY, CPFIS_DISABLED, CPFIS_FOCUSED, CPFIS_SELECTED} CREDENTIAL_PROVIDER_FIELD_INTERACTIVE_STATE; CPFIS_NONE: 没有特定的交互状态。 CPFIS_READONLY: 字段只读,用户不能编辑。 CPFIS_DISABLED: 字段被禁用,用户不能进行交互。 CPFIS_FOCUSED: 字段处于焦点状态,表示用户正在与该字段进行交互。 CPFIS_SELECTED: 字段被选择,通常与焦点状态同时存在,表示用户可能...
Win32 API:CREDENTIAL_PROVIDER_FIELD_DESCRIPTOR 结构(Credentialprovider.h)
CREDENTIAL_PROVIDER_FIELD_DESCRIPTOR 结构体是 Windows 中 Credential Provider API 中的一部分,用于描述认证信息提供者字段(例如用户名、密码等)的属性。该结构体定义如下:typedef struct _CREDENTIAL_PROVIDER_FIELD_DESCRIPTOR { DWORD dwFieldID; CREDENTIAL_PROVIDER_FIELD_TYPE cpft; LPWSTR pszLabel; GUID guidFieldType;} CREDENTIAL_PROVIDER_FIELD_DESCRIPTOR;这个结构体包含以下字段: dwFieldID: 用于标识字段的唯一ID。每个字段都应该有一个不同的ID。 cpft: 字段的类型,是一个 CREDENTIAL_PROVIDER_FIELD_TYPE 枚举值,表示字段的数据类型,例如文本、密码等。 pszLabel: 字段的标签,是一个描述字段用途的字符串。 guidFieldType: 用于进一步标识字段类型...
Win32 API:CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION 结构(Credentialprovider.h)
CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION 结构体是 Windows 凭据提供程序 (Credential Provider) API 中的一部分,位于 <Credentialprovider.h> 头文件中。该结构体用于序列化凭据信息以进行传递。以下是该结构体的定义:typedef struct _CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION { ULONG ulAuthenticationPackage; GUID clsidCredentialProvider; ULONG cbSerialization; ULONG ulAuthenticationPackageForCredUI; GUID clsidCredentialProviderForCredUI; ULONG cbSerializationForCredUI;} CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION, *PCREDENTIAL_PROV...
Win32 API:NEWCPLINFOW 结构(Cpl.h)
NEWCPLINFOW 是 Win32 API 中定义的一个结构体,位于 <Cpl.h> 头文件中。该结构体用于传递控制面板应用程序(CPL)的信息。以下是该结构体的定义:typedef struct tagNEWCPLINFOW { DWORD dwSize; // 结构体的大小,用于版本控制 DWORD dwFlags; // 控制面板信息标志 DWORD dwHelpContext; // 帮助上下文标识符 LONG lData; // 与 CPL 进程相关的数据 HICON hIcon; // 控制面板图标的句柄 WCHAR szName[32]; // 控制面板的名称 WCHAR szInfo[64]; // 控制面板的描述信息 WCHAR szHelpFile[128];// 控制面板帮助文件的路径} NEWCPLINFOW, *LPNEWCPLINFOW;各个字段的含义如下: dwSize: 结构体的大小,用于版本控制,应该设置...
Win32 API:NEWCPLINFOA 结构(Cpl.h)
NEWCPLINFOA 结构是与控制面板应用程序相关的 Windows API 结构,用于提供关于控制面板应用程序的详细信息。以下是 NEWCPLINFOA 结构的定义:typedef struct tagNEWCPLINFOA { DWORD dwSize; // 结构的大小 DWORD dwFlags; // 控制面板应用程序的标志 DWORD dwHelpContext; // 帮助上下文 ID LONG lData; // 应用程序特定的数据 HICON hIcon; // 应用程序的图标句柄 CHAR szName[32]; // 应用程序的名称 CHAR szInfo[64]; // 应用程序的描述信息 CHAR szHelpFile[128]; // 应用程序的帮助文件路径} NEWCPLINFOA, *LPNEWCPLINFOA;这个结构包含了有关控制面板应用程序的信息,如结构大小、标志...
Win32 API:CPLINFO 结构(Cpl.h)
CPLINFO 结构是与控制面板应用程序相关的 Windows API 结构。控制面板应用程序(CPL)是一种允许用户配置系统设置的应用程序类型。以下是 CPLINFO 结构的定义:typedef struct tagCPLINFO { int idIcon; // 应用程序的图标资源 ID int idName; // 应用程序的名称资源 ID int idInfo; // 应用程序的描述信息资源 ID HICON hIcon; // 应用程序的图标句柄} CPLINFO, *LPCPLINFO;这个结构包含了有关控制面板应用程序的信息,如图标资源 ID、名称资源 ID、描述信息资源 ID 和图标句柄等。这些信息通常用于显示在控制面板或其他系统相关的界面上。请注意,CPLINFO 结构可能是由控制面板应用程序实现的一个回调函数或 API 返回的,以提供有关该应用程序的信息。
Win32 API:ICoreWindowInterop 接口(Corewindow.h)
ICoreWindowInterop 接口是与 Windows 运行时 (WinRT) API 相关的接口,用于与 CoreWindow 相关的交互。这个接口通常用于获取与 WinRT CoreWindow 对象关联的窗口句柄(HWND)以及其他与窗口相关的信息。以下是 ICoreWindowInterop 接口的简化定义:#include <CoreWindow.h>interface ICoreWindowInterop : public IUnknown{public: virtual HRESULT STDMETHODCALLTYPE get_WindowHandle( /* [out][retval] */ __RPC__out HWND* hwnd) = 0; // 其他方法...};该接口的主要功能是通过 get_WindowHandle 方法获取与 CoreWindow 关联的窗口句柄(HWND)。这对于在 WinRT 和传统 Win32 API 之间进行交互是非常有用的。
Win32 API:ICoreWindowAdapterInterop 接口(Corewindow.h)
ICoreWindowAdapterInterop 接口也是与 Windows 运行时 (WinRT) API 相关的接口,通常与 CoreWindow 相关联。这个接口用于获取与 WinRT CoreWindow 对象关联的窗口句柄(HWND)。以下是 ICoreWindowAdapterInterop 接口的简化定义:#include <CoreWindow.h>interface ICoreWindowAdapterInterop : public IUnknown{public: virtual HRESULT STDMETHODCALLTYPE get_WindowHandle( /* [out][retval] */ __RPC__out HWND* hwnd) = 0;};该接口允许通过 get_WindowHandle 方法获取与 CoreWindow 关联的窗口句柄(HWND)。这对于在 WinRT 和传统 Win32 API 之间进行交互是非常有用的。
Win32 API:ICoreInputInterop 接口(Corewindow.h)
ICoreInputInterop 接口是与 Windows 运行时 (WinRT) API 相关的接口,而不是传统的 Win32 API。这个接口通常与 CoreWindow 和输入事件处理相关。以下是 ICoreInputInterop 接口的简化定义:#include <CoreWindow.h>interface ICoreInputInterop : public IUnknown{public: virtual HRESULT STDMETHODCALLTYPE get_CoreWindow( /* [in] */ __RPC__in REFIID riid, /* [iid_is][out][retval] */ __RPC__deref_out_opt void **ppUnk) = 0;};这个接口允许您通过 get_CoreWindow 方法获取与 CoreWindow 相关的 WinRT 对象。如果您想要详细了解该接口的用法以及与 CoreWindow 相关的其他输入功能,建议查阅 Microsoft 官方文档或相关的...
Win32 API:IVideoWindow 接口(Control.h)
Win32 API 中的 IVideoWindow 接口通常与 DirectShow 多媒体框架相关。在 DirectShow 中,IVideoWindow 接口用于控制视频窗口的属性和行为。这个接口通常在控制视频播放器时使用。以下是 IVideoWindow 接口的一些常见方法:interface IVideoWindow : public IUnknown{public: // 设置视频窗口的位置和大小 virtual HRESULT STDMETHODCALLTYPE put_Caption(/* [in] */ __RPC__in BSTR strCaption) = 0; // 获取视频窗口的标题 virtual HRESULT STDMETHODCALLTYPE get_Caption(/* [out][retval] */ __RPC__deref_out_opt BSTR *strCaption) = 0; // 设置视频窗口的位置和大小 virtual HRESULT STDMETHODCALLTYPE put_WindowStyl...
Win32 API:IMediaPosition 接口(Control.h)
在 Win32 API 中,IMediaPosition 接口是与多媒体操作相关的 COM 接口之一。它通常与 DirectShow 相关的多媒体框架一起使用,用于获取和设置媒体的播放位置。以下是关于 IMediaPosition 接口的一些基本信息:#include <Control.h>// 定义 IMediaPosition 接口的 GUID// {56A868B2-0AD4-11CE-B03A-0020AF0BA770}DEFINE_GUID(IID_IMediaPosition, 0x56A868B2, 0x0AD4, 0x11CE, 0xB0, 0x3A, 0x00, 0x20, 0xAF, 0x0B, 0xA7, 0x70);// IMediaPosition 接口的定义DECLARE_INTERFACE_(IMediaPosition, IUnknown){ // IUnknown 接口的成员函数 STDMETHOD(QueryInterface)(THIS_ REFIID riid, void **ppvObject) PURE; STD...
Win32 API:IMediaEventEx 接口(Control.h)
IMediaEventEx 接口是 Microsoft Windows 平台上使用的一种 COM 接口,用于处理多媒体事件。在 Win32 API 中,它通常与 DirectShow 相关的多媒体框架一起使用,用于捕获、处理和响应多媒体事件。以下是关于 IMediaEventEx 接口的一些基本信息:#include <Control.h>// 定义 IMediaEventEx 接口的 GUID// {56A868C0-0AD4-11CE-B03A-0020AF0BA770}DEFINE_GUID(IID_IMediaEventEx, 0x56A868C0, 0x0AD4, 0x11CE, 0xB0, 0x3A, 0x00, 0x20, 0xAF, 0x0B, 0xA7, 0x70);// IMediaEventEx 接口的定义DECLARE_INTERFACE_(IMediaEventEx, IMediaEvent){ // IMediaEvent 接口的成员函数 STDMETHOD(GetEventHandle)(THIS_ OAEVENT *hEvent)...
Win32 API:IMediaEvent 接口(Control.h)
Win32 API 中的 IMediaEvent 接口通常与多媒体应用程序一起使用,用于处理媒体事件。以下是一个简单的示例代码,演示如何使用 IMediaEvent 接口。请注意,这只是一个简单的示例,实际使用时需要根据具体需求进行修改。#include <windows.h>#include <dshow.h>// 初始化 DirectShowHRESULT InitializeDirectShow(HWND hwnd) { // 初始化 COM CoInitialize(NULL); // 创建 Filter Graph Manager IGraphBuilder *pGraph = NULL; CoCreateInstance(CLSID_FilterGraph, NULL, CLSCTX_INPROC_SERVER, IID_IGraphBuilder, (void **)&pGraph); // 创建 Capture Graph Builder ICaptureGraphBuilder2 *pCaptu...