mirror of
				https://github.com/halpz/re3.git
				synced 2025-10-25 18:07:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			136 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // File: VPConfig.h
 | |
| //
 | |
| // Desc: An interface exposed by the decoder to help it and the filter
 | |
| //       configuring the videoport to communicate.
 | |
| //
 | |
| // Copyright (c) 1992-2001, Microsoft Corporation.  All rights reserved.
 | |
| //------------------------------------------------------------------------------
 | |
| 
 | |
| 
 | |
| #ifndef __IVPConfig__
 | |
| #define __IVPConfig__
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| // IVPBaseConfig
 | |
| DECLARE_INTERFACE_(IVPBaseConfig, IUnknown)
 | |
| {
 | |
| public:
 | |
| 
 | |
|     // gets the various connection information structures (guid, portwidth)
 | |
|     // in an array of structures. If the pointer to the array is NULL, first 
 | |
|     // parameter returns the total number of formats supported.
 | |
|     STDMETHOD (GetConnectInfo)(THIS_
 | |
|                    IN OUT LPDWORD pdwNumConnectInfo,
 | |
|                    IN OUT LPDDVIDEOPORTCONNECT pddVPConnectInfo
 | |
|                   ) PURE;
 | |
| 
 | |
|     // sets the connection entry chosen (0, 1, .. ,(dwNumProposedEntries-1))
 | |
|     STDMETHOD (SetConnectInfo)(THIS_
 | |
|                    IN DWORD dwChosenEntry
 | |
|                   ) PURE;
 | |
| 
 | |
|     // gets various data parameters, includes dimensionnal info
 | |
|     STDMETHOD (GetVPDataInfo)(THIS_
 | |
|                    IN OUT LPAMVPDATAINFO pamvpDataInfo
 | |
|                   ) PURE;
 | |
| 
 | |
|     // retrives maximum pixels per second rate expected for a given 
 | |
|     // format and a given scaling factor. If decoder does not support 
 | |
|     // those scaling factors, then it gives the rate and the nearest 
 | |
|     // scaling factors.
 | |
|     STDMETHOD (GetMaxPixelRate)(THIS_
 | |
|                     IN OUT LPAMVPSIZE pamvpSize,
 | |
|                     OUT LPDWORD pdwMaxPixelsPerSecond
 | |
|                   ) PURE;
 | |
| 
 | |
|     // informs the callee of the videoformats supported by the videoport
 | |
|     STDMETHOD (InformVPInputFormats)(THIS_
 | |
|                     IN DWORD dwNumFormats,
 | |
|                     IN LPDDPIXELFORMAT pDDPixelFormats
 | |
|                   ) PURE;
 | |
| 
 | |
|     // gets the various formats supported by the decoder in an array
 | |
|     // of structures. If the pointer to the array is NULL, first parameter
 | |
|     // returns the total number of formats supported.
 | |
|     STDMETHOD (GetVideoFormats)(THIS_
 | |
|                     IN OUT LPDWORD pdwNumFormats,
 | |
|                     IN OUT LPDDPIXELFORMAT pddPixelFormats
 | |
|                    ) PURE;
 | |
| 
 | |
|     // sets the format entry chosen (0, 1, .. ,(dwNumProposedEntries-1))
 | |
|     STDMETHOD (SetVideoFormat)(THIS_
 | |
|                    IN DWORD dwChosenEntry
 | |
|                   ) PURE;
 | |
| 
 | |
|     // asks the decoder to treat even fields like odd fields and visa versa
 | |
|     STDMETHOD (SetInvertPolarity)(THIS_
 | |
|                   ) PURE;
 | |
| 
 | |
|     // the mixer uses this function to determine if the callee wants
 | |
|     // the vpmixer to use its overlay surface and if so to get a pointer to it
 | |
|     STDMETHOD (GetOverlaySurface)(THIS_
 | |
|                    OUT LPDIRECTDRAWSURFACE* ppddOverlaySurface
 | |
|                   ) PURE;
 | |
| 
 | |
|     // sets the direct draw kernel handle
 | |
|     STDMETHOD (SetDirectDrawKernelHandle)(THIS_
 | |
|                    IN ULONG_PTR dwDDKernelHandle
 | |
|                   ) PURE;
 | |
| 
 | |
|     // sets the video port id
 | |
|     STDMETHOD (SetVideoPortID)(THIS_
 | |
|                    IN DWORD dwVideoPortID
 | |
|                   ) PURE;
 | |
| 
 | |
|     // sets the direct draw surface kernel handle
 | |
|     STDMETHOD (SetDDSurfaceKernelHandles)(THIS_
 | |
|                    IN DWORD cHandles,
 | |
|                    IN ULONG_PTR *rgDDKernelHandles
 | |
|                   ) PURE;
 | |
| 
 | |
|     // Tells driver about surface created on its behalf by ovmixer/vbisurf and 
 | |
|     // returned from videoport/ddraw. Should always return NOERROR or E_NOIMPL. 
 | |
|     // dwPitch is the pitch of the surface (distance in pixels between the start 
 | |
|     // pixels of two consecutive lines of the surface). (dwXOrigin, dwYOrigin) 
 | |
|     // are the (X, Y) coordinates of the pixel at which valid data starts.  
 | |
|     STDMETHOD (SetSurfaceParameters)(THIS_
 | |
|                    IN DWORD dwPitch,
 | |
|                    IN DWORD dwXOrigin,
 | |
|                    IN DWORD dwYOrigin
 | |
|                   ) PURE;
 | |
| };
 | |
| 
 | |
| // IVPConfig
 | |
| DECLARE_INTERFACE_(IVPConfig, IVPBaseConfig)
 | |
| {
 | |
| public:
 | |
|     // the mixer uses this function to determine if the callee wants
 | |
|     // the mixer to decimate VIDEO data at its own descrition
 | |
|     STDMETHOD (IsVPDecimationAllowed)(THIS_
 | |
|                    OUT LPBOOL pbIsDecimationAllowed
 | |
|                   ) PURE;
 | |
| 
 | |
|     // sets the scaling factors. If decoder does not support these,
 | |
|     // then it sets the values to the nearest factors it can support
 | |
|     STDMETHOD (SetScalingFactors)(THIS_
 | |
|                    IN LPAMVPSIZE pamvpSize
 | |
|                   ) PURE;
 | |
| };
 | |
| 
 | |
| // IVPVBIConfig
 | |
| DECLARE_INTERFACE_(IVPVBIConfig, IVPBaseConfig)
 | |
| {
 | |
| public:
 | |
| };
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| 
 | |
| #endif // __IVPConfig__
 |