mirror of
https://github.com/reactos/reactos.git
synced 2025-04-20 04:20:46 +00:00
Test code to create surface. it is a big hack to create a primare surface.
but we success create a primary surface. with this hack. svn path=/trunk/; revision=25104
This commit is contained in:
parent
9360360cb5
commit
465b3d78e8
1 changed files with 65 additions and 29 deletions
|
@ -185,6 +185,7 @@ HRESULT WINAPI Main_DirectDraw_CreateSurface (LPDIRECTDRAW7 iface, LPDDSURFACEDE
|
||||||
LPDDRAWI_DDRAWSURFACE_INT That;
|
LPDDRAWI_DDRAWSURFACE_INT That;
|
||||||
DDHAL_CANCREATESURFACEDATA mDdCanCreateSurface;
|
DDHAL_CANCREATESURFACEDATA mDdCanCreateSurface;
|
||||||
DDHAL_CREATESURFACEDATA mDdCreateSurface;
|
DDHAL_CREATESURFACEDATA mDdCreateSurface;
|
||||||
|
LPDDRAWI_DDRAWSURFACE_MORE SurfaceMore;
|
||||||
|
|
||||||
if (pUnkOuter!=NULL)
|
if (pUnkOuter!=NULL)
|
||||||
{
|
{
|
||||||
|
@ -250,6 +251,7 @@ HRESULT WINAPI Main_DirectDraw_CreateSurface (LPDIRECTDRAW7 iface, LPDDSURFACEDE
|
||||||
|
|
||||||
/* own code now */
|
/* own code now */
|
||||||
|
|
||||||
|
|
||||||
mDdCanCreateSurface.lpDD = This->lpLcl->lpGbl;
|
mDdCanCreateSurface.lpDD = This->lpLcl->lpGbl;
|
||||||
mDdCanCreateSurface.bIsDifferentPixelFormat = FALSE;
|
mDdCanCreateSurface.bIsDifferentPixelFormat = FALSE;
|
||||||
mDdCanCreateSurface.lpDDSurfaceDesc = (LPDDSURFACEDESC) pDDSD;
|
mDdCanCreateSurface.lpDDSurfaceDesc = (LPDDSURFACEDESC) pDDSD;
|
||||||
|
@ -261,43 +263,77 @@ HRESULT WINAPI Main_DirectDraw_CreateSurface (LPDIRECTDRAW7 iface, LPDDSURFACEDE
|
||||||
mDdCreateSurface.dwSCnt = That->dwIntRefCnt + 1; // is this correct
|
mDdCreateSurface.dwSCnt = That->dwIntRefCnt + 1; // is this correct
|
||||||
mDdCreateSurface.lpDDSurfaceDesc = (LPDDSURFACEDESC) pDDSD;
|
mDdCreateSurface.lpDDSurfaceDesc = (LPDDSURFACEDESC) pDDSD;
|
||||||
//mDdCreateSurface.lplpSList = That->lpLcl->lpSurfMore->slist;
|
//mDdCreateSurface.lplpSList = That->lpLcl->lpSurfMore->slist;
|
||||||
mDdCreateSurface.lplpSList = &That->lpLcl;
|
//mDdCreateSurface.lplpSList = &That->lpLcl;
|
||||||
|
|
||||||
|
SurfaceMore = DxHeapMemAlloc(sizeof(DDRAWI_DDRAWSURFACE_MORE));
|
||||||
|
if (SurfaceMore == NULL)
|
||||||
|
{
|
||||||
|
return DDERR_OUTOFMEMORY;
|
||||||
|
}
|
||||||
|
|
||||||
if (pDDSD->ddsCaps.dwCaps & DDSCAPS_PRIMARYSURFACE)
|
if (pDDSD->ddsCaps.dwCaps & DDSCAPS_PRIMARYSURFACE)
|
||||||
{
|
{
|
||||||
|
DDRAWI_DDRAWSURFACE_LCL *mpPrimaryLocals[1];
|
||||||
|
DDSURFACEDESC mddsdPrimary;
|
||||||
|
|
||||||
/* we only create one surface it is primary */
|
This->lpLcl->lpGbl->lp16DD = This->lpLcl->lpGbl;
|
||||||
//LPDDRAWI_DDRAWSURFACE_LCL surf;
|
That->lpLcl->lpSurfMore = SurfaceMore;
|
||||||
|
|
||||||
DX_STUB_str( "Can not create primary surface well yet");
|
ZeroMemory(&mddsdPrimary, sizeof(DDSURFACEDESC));
|
||||||
|
mddsdPrimary.dwSize = sizeof(DDSURFACEDESC);
|
||||||
|
mddsdPrimary.dwFlags = DDSD_CAPS;
|
||||||
|
mddsdPrimary.ddsCaps.dwCaps = DDSCAPS_PRIMARYSURFACE | DDSCAPS_VIDEOMEMORY | DDSCAPS_VISIBLE;
|
||||||
|
|
||||||
|
mDdCanCreateSurface.lpDD = This->lpLcl->lpGbl;
|
||||||
|
mDdCanCreateSurface.CanCreateSurface = This->lpLcl->lpDDCB->HALDD.CanCreateSurface;
|
||||||
|
mDdCanCreateSurface.bIsDifferentPixelFormat = FALSE; //isDifferentPixelFormat;
|
||||||
|
mDdCanCreateSurface.lpDDSurfaceDesc = &mddsdPrimary; // pDDSD;
|
||||||
|
|
||||||
if (mDdCanCreateSurface.CanCreateSurface(&mDdCanCreateSurface)== DDHAL_DRIVER_NOTHANDLED)
|
if (mDdCanCreateSurface.CanCreateSurface(&mDdCanCreateSurface)== DDHAL_DRIVER_NOTHANDLED)
|
||||||
{
|
{
|
||||||
DX_STUB_str( "Can not create surface ");
|
|
||||||
return DDERR_NOTINITIALIZED;
|
return DDERR_NOTINITIALIZED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mDdCanCreateSurface.ddRVal != DD_OK)
|
if (mDdCanCreateSurface.ddRVal != DD_OK)
|
||||||
{
|
{
|
||||||
DX_STUB_str( "Fail");
|
|
||||||
return mDdCanCreateSurface.ddRVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
DX_STUB_str( "Can not create primary surface well yet");
|
|
||||||
|
|
||||||
if (mDdCreateSurface.CreateSurface(&mDdCreateSurface) == DDHAL_DRIVER_NOTHANDLED)
|
|
||||||
{
|
|
||||||
DX_STUB_str( "Can not create surface fail");
|
|
||||||
return DDERR_NOTINITIALIZED;
|
return DDERR_NOTINITIALIZED;
|
||||||
}
|
}
|
||||||
|
|
||||||
DX_STUB_str( "Can not create primary surface well yet");
|
That->lpLcl->lpGbl->dwGlobalFlags = DDRAWISURFGBL_ISGDISURFACE;
|
||||||
|
That->lpLcl->lpGbl->lpDD = This->lpLcl->lpGbl;
|
||||||
|
That->lpLcl->lpGbl->lpDDHandle = This->lpLcl->lpGbl;
|
||||||
|
That->lpLcl->lpGbl->wWidth = 1024; //(WORD)mpModeInfos[0].dwWidth;
|
||||||
|
That->lpLcl->lpGbl->wHeight = 768; //(WORD)mpModeInfos[0].dwHeight;
|
||||||
|
That->lpLcl->lpGbl->lPitch = 32; //mpModeInfos[0].lPitch;
|
||||||
|
|
||||||
Main_DirectDraw_AddRef((LPDIRECTDRAW7)This);
|
memset(SurfaceMore, 0, sizeof(DDRAWI_DDRAWSURFACE_MORE));
|
||||||
Main_DDrawSurface_AddRef((LPDIRECTDRAWSURFACE7)That);
|
SurfaceMore->dwSize = sizeof(DDRAWI_DDRAWSURFACE_MORE);
|
||||||
|
|
||||||
|
That->lpLcl->lpGbl = That->lpLcl->lpGbl;
|
||||||
|
That->lpLcl->lpSurfMore = SurfaceMore;
|
||||||
|
That->lpLcl->dwProcessId = GetCurrentProcessId();
|
||||||
|
That->lpLcl->dwFlags = DDRAWISURF_PARTOFPRIMARYCHAIN|DDRAWISURF_HASOVERLAYDATA;
|
||||||
|
That->lpLcl->ddsCaps.dwCaps = mddsdPrimary.ddsCaps.dwCaps;
|
||||||
|
|
||||||
|
mpPrimaryLocals[0] = That->lpLcl;
|
||||||
|
|
||||||
|
mDdCreateSurface.lpDD = This->lpLcl->lpGbl;
|
||||||
|
mDdCreateSurface.CreateSurface = This->lpLcl->lpDDCB->HALDD.CreateSurface;
|
||||||
|
mDdCreateSurface.lpDDSurfaceDesc = &mddsdPrimary;//pDDSD;
|
||||||
|
mDdCreateSurface.lplpSList = mpPrimaryLocals; //cSurfaces;
|
||||||
|
mDdCreateSurface.dwSCnt = 1 ; //ppSurfaces;
|
||||||
|
|
||||||
|
if (mDdCreateSurface.CreateSurface(&mDdCreateSurface) == DDHAL_DRIVER_NOTHANDLED)
|
||||||
|
{
|
||||||
|
return DDERR_NOTINITIALIZED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mDdCreateSurface.ddRVal != DD_OK)
|
||||||
|
{
|
||||||
return mDdCreateSurface.ddRVal;
|
return mDdCreateSurface.ddRVal;
|
||||||
|
}
|
||||||
|
|
||||||
|
return DD_OK;
|
||||||
}
|
}
|
||||||
else if (pDDSD->ddsCaps.dwCaps & DDSCAPS_OVERLAY)
|
else if (pDDSD->ddsCaps.dwCaps & DDSCAPS_OVERLAY)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue