亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? chrcdevice.cpp

?? Windows上的MUD客戶端程序
?? CPP
字號:
/*----------------------------------------------------------------------------
                        _                              _ _       
        /\             | |                            | (_)      
       /  \   _ __   __| |_ __ ___  _ __ ___   ___  __| |_  __ _ 
      / /\ \ | '_ \ / _` | '__/ _ \| '_ ` _ \ / _ \/ _` | |/ _` |
     / ____ \| | | | (_| | | | (_) | | | | | |  __/ (_| | | (_| |
    /_/    \_\_| |_|\__,_|_|  \___/|_| |_| |_|\___|\__,_|_|\__,_|

    The contents of this file are subject to the Andromedia Public
	License Version 1.0 (the "License"); you may not use this file
	except in compliance with the License. You may obtain a copy of
	the License at http://www.andromedia.com/APL/

    Software distributed under the License is distributed on an
	"AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
	implied. See the License for the specific language governing
	rights and limitations under the License.

    The Original Code is Pueblo client code, released November 4, 1998.

    The Initial Developer of the Original Code is Andromedia Incorporated.
	Portions created by Andromedia are Copyright (C) 1998 Andromedia
	Incorporated.  All Rights Reserved.

	Andromedia Incorporated                         415.365.6700
	818 Mission Street - 2nd Floor                  415.365.6701 fax
	San Francisco, CA 94103

    Contributor(s):
	--------------------------------------------------------------------------
	   Chaco team:  Dan Greening, Glenn Crocker, Jim Doubek,
	                Coyote Lussier, Pritham Shetty.

					Wrote and designed original codebase.

------------------------------------------------------------------------------

	Implementation of native device creation for the ChRenderContext class.
	Used by RL and D3D implementations

----------------------------------------------------------------------------*/

// $Header: /home/cvs/chaco/modules/client/msw/ChGraphx/ChRCDevice.cpp,v 2.4 1996/07/19 20:44:45 jimd Exp $

#include "grheader.h"

#include "ChMaze.h"
#include "ChRCDevice.h"

#if defined(CH_USE_D3D)

#if !defined(CH_EXCEPTIONS)
#error "This file requires enabling of C++ Exceptions!"
#endif

HRESULT
GetSurfDesc(LPDDSURFACEDESC lpDDSurfDesc,LPDIRECTDRAWSURFACE lpDDSurf)
{
    HRESULT result;
    memset(lpDDSurfDesc, 0, sizeof(DDSURFACEDESC));
    lpDDSurfDesc->dwSize = sizeof(DDSURFACEDESC);
    result = lpDDSurf->GetSurfaceDesc(lpDDSurfDesc);
    return result;
}

#endif 	 // D3D

ChNativeContext ChRenderContext::CreateDevice(int width, int height)
{
	#if (defined(CH_USE_RLAB))
	#ifdef DDRAW
	m_hRC = createWinDevice(win, hdc, NULL, width, height);
	#else
	m_hRC = RLWinCreateDevice(GetWnd()->GetSafeHwnd(), NULL, width, height);
	#endif
	#elif (defined(CH_USE_D3D))

	ChRenderOptimization setting = ((ChMazeWnd*)GetWnd())->GetSettings()->GetRenderOptimization();

	for(int j = 0; j < renderOptimizationCount; j++)
	{
		m_drivers[j] = ChD3dDriver();
	}
	if(m_drivers[renderBetter].GetName().IsEmpty())
	{
		if(!EnumDrivers()) return 0;	// FAILURE!
	}

	/*
     * Create the D3DRM device from this window and using the specified D3D
     * driver.
     */
	GUID guid = m_drivers[setting].GetGUID();	// our driver to use
	m_hRC = 0;									// in case of failure
	#if FANCY_CREATE
	// NOT DONE YET!!
	// Create the front and back buffers, along with the clipper

	// Create the Z buffer

	// Create the device on top of the buffers

	#else
    HRESULT rval = m_D3DRM->CreateDeviceFromClipper(m_DDClipper, &guid, width, height, &m_hRC);
	#endif

	#if 0
	DDSURFACEDESC desc;
	LPDIRECTDRAWSURFACE lpDDSurf = 0;
	LPDIRECT3DDEVICE d3dDevice = 0;
	rval = m_hRC->GetDirect3DDevice(&d3dDevice);
	if(rval == DD_OK)
	{

		rval = d3dDevice->QueryInterface(IID_IDirectDrawSurface, (void**)&lpDDSurf);
		if(rval == DD_OK)
		{
			GetSurfDesc(&desc,lpDDSurf);
			if((desc.ddsCaps.dwCaps & DDSCAPS_BACKBUFFER) == 0)
			{
				LPDIRECTDRAWSURFACE backSurf = 0;
				DDSCAPS ddsCaps;
				ddsCaps.dwCaps = DDSCAPS_BACKBUFFER;
				rval = lpDDSurf->GetAttachedSurface(&ddsCaps, &backSurf); 
				if(rval == DD_OK)
				{
					GetSurfDesc(&desc,backSurf);
				}
				RELEASE_INTERFACE(backSurf);
			}
		}
	}
	RELEASE_INTERFACE(lpDDSurf);
	RELEASE_INTERFACE(d3dDevice);
	#endif	// 0

	#endif // elif (defined(CH_USE_D3D))
	return m_hRC;
}

#if (defined(CH_USE_D3D))

int ChRenderContext::GetBPP()
{
    return GetDeviceCaps(m_hDC, BITSPIXEL);
}

static HRESULT
WINAPI enumDeviceFunc(LPGUID lpGuid, LPSTR lpDeviceDescription, LPSTR lpDeviceName,
        LPD3DDEVICEDESC lpHWDesc, LPD3DDEVICEDESC lpHELDesc, LPVOID lpContext)
{

	ChRenderContext *pRC = (ChRenderContext *)lpContext;

	return pRC->EnumDriver(lpGuid, lpDeviceDescription, lpDeviceName,
        lpHWDesc, lpHELDesc);

}

/****************************************************************************/
/*                         D3D Device Enumeration                           */
/****************************************************************************/
/*
 * BPPToDDBD
 * Converts bits per pixel to a DirectDraw bit depth flag
 */
static DWORD
BPPToDDBD(int bpp)
{
    switch(bpp) {
        case 1:
            return DDBD_1;
        case 2:
            return DDBD_2;
        case 4:
            return DDBD_4;
        case 8:
            return DDBD_8;
        case 16:
            return DDBD_16;
        case 24:
            return DDBD_24;
        case 32:
            return DDBD_32;
        default:
            return 0;
    }
}

HRESULT ChRenderContext::EnumDriver(LPGUID lpGuid, LPSTR lpDeviceDescription, LPSTR lpDeviceName,
        LPD3DDEVICEDESC lpHWDesc, LPD3DDEVICEDESC lpHELDesc)
{
    BOOL hardware = FALSE; /* current start driver is hardware */
    BOOL mono = FALSE;     /* current start driver is mono light */
    LPD3DDEVICEDESC lpDesc;
    /*
     * Decide which device description we should consult
     */
    lpDesc = lpHWDesc->dcmColorModel ? lpHWDesc : lpHELDesc;
    /*
     * If this driver cannot render in the current display bit depth skip
     * it and continue with the enumeration.
     */
    if (!(lpDesc->dwDeviceRenderBitDepth & BPPToDDBD(GetBPP())))
        return D3DENUMRET_OK;
    /*
     * Record this driver's info
     */
    //memcpy(&myglobs.DriverGUID[myglobs.NumDrivers], lpGuid, sizeof(GUID));
    //lstrcpy(&myglobs.DriverName[myglobs.NumDrivers][0], lpDeviceName);
    /*
     * Choose hardware over software for everything, RGB lights over mono lights for "better"
	 * mono over rgb for "faster"
     */
    hardware = lpDesc == lpHWDesc ? TRUE : FALSE;
    mono = lpDesc->dcmColorModel & D3DCOLOR_MONO ? TRUE : FALSE;
    if (m_drivers[renderBetter].GetName().IsEmpty()) {
        /*
         * this is the first valid driver
         */
		m_drivers[renderBetter].Set(lpDeviceName, *lpGuid, hardware, mono);
		m_drivers[renderFaster].Set(lpDeviceName, *lpGuid, hardware, mono);
    } 
    else
    {
    	if (hardware)
	    {
	        /*
	         * this driver is hardware and start driver is not
	         */
			 if(!m_drivers[renderBetter].IsHardware() || (!mono && m_drivers[renderBetter].IsMono()))
			 {
			 	// If both mono, choose the hardware one
				m_drivers[renderBetter].Set(lpDeviceName, *lpGuid, hardware, mono);
			 }
			 if(!m_drivers[renderFaster].IsHardware() || (mono && !m_drivers[renderFaster].IsMono()))
			 {
				m_drivers[renderFaster].Set(lpDeviceName, *lpGuid, hardware, mono);
			 }
    	}
		if(mono)
		{
			 if(!m_drivers[renderFaster].IsHardware() && !m_drivers[renderFaster].IsMono())
			 {
				m_drivers[renderFaster].Set(lpDeviceName, *lpGuid, hardware, mono);
			 }
		}
		else
		{
			 if(!m_drivers[renderBetter].IsHardware() && m_drivers[renderBetter].IsMono())
			 {
				m_drivers[renderBetter].Set(lpDeviceName, *lpGuid, hardware, mono);
			 }
		}
	}

	//#pragma message("D3D no-devices failure handling Not done!")
    return (D3DENUMRET_OK);
}

/*
 * EnumDrivers
 * Enumerate the available D3D drivers, add them to the file menu, and choose
 * one to use.
 */
BOOL ChRenderContext::EnumDrivers()
{
    LPDIRECTDRAW lpDD;
    LPDIRECT3D lpD3D;
    HRESULT rval;

    /*
     * Create a DirectDraw object and query for the Direct3D interface to use
     * to enumerate the drivers.
     */
    rval = DirectDrawCreate(NULL, &lpDD, NULL);
    if (rval != DD_OK) {
        //TRACE1("Creation of DirectDraw HEL failed.\n%s", D3DRMErrorToString(rval));
        return FALSE;
    }
    rval = lpDD->QueryInterface(IID_IDirect3D, (void**) &lpD3D);
    if (rval != DD_OK) {
        //TRACE1("Creation of Direct3D interface failed.\n%s", D3DRMErrorToString(rval));
        lpDD->Release();
        return FALSE;
    }
    /*
     * Enumerate the drivers, setting CurrDriver to -1 to initialize the
     * driver selection code in enumDeviceFunc
     */

    rval = lpD3D->EnumDevices(enumDeviceFunc, this);
    if (rval != DD_OK) {
        //TRACE1("Enumeration of drivers failed.\n%s", D3DAppErrorToString(rval));
        return FALSE;
    }
    lpD3D->Release();
    lpDD->Release();

    /*
     * Make sure we found at least one valid driver for each one
     */

	if(m_drivers[renderBetter].GetName().IsEmpty() || 
		m_drivers[renderFaster].GetName().IsEmpty())
	{
		return FALSE;
	}

    return TRUE;
}

#endif	// D3D


#if (defined(CH_USE_D3D))
ChDevice3D::ChDevice3D() :
		#if (defined(CH_USE_D3D))
		m_frontSurface(0),
		m_backSurface(0),
		m_zSurface(0),
		m_clipper(0),
		#endif
		m_pRC(0),
		m_device(0)
{
}
ChDevice3D::ChDevice3D(ChRenderContext *pRC, int width, int height, bool boolOffscreen ) :
		#if (defined(CH_USE_D3D))
		m_frontSurface(0),
		m_backSurface(0),
		m_zSurface(0),
		m_clipper(0),
		#endif
		m_pRC(0),
		m_device(0)
{
	Init(pRC, width, height, boolOffscreen);	
}


ChDevice3D::~ChDevice3D()
{
	Kill();
}

void ChDevice3D::Kill()
{
	RELEASE_INTERFACE(m_device);
	RELEASE_INTERFACE(m_backSurface);
	RELEASE_INTERFACE(m_frontSurface);
	RELEASE_INTERFACE(m_zSurface);
	RELEASE_INTERFACE(m_clipper);
}



bool ChDevice3D::Init(ChRenderContext *pRC, int width, int height, bool boolOffscreen)
{
	Kill();					// If we decide we want to reuse these,
							// just release eveything first
	m_pRC = pRC;
	if(boolOffscreen)
	{
		return pRC->InitOffscreenDevice(*this, width, height);
	}
	else
	{
		return pRC->InitWindowDevice(*this, width, height);
	}
}

bool ChRenderContext::InitWindowDevice(ChDevice3D &device, int width, int height)
{
	return false;
}

bool ChRenderContext::InitOffscreenDevice(ChDevice3D &device, int width, int height)
{
	bool boolSuccess = true;
	#if (defined(CH_USE_D3D))
    DDSURFACEDESC       ddsd;
    //HRESULT result;

	device.m_frontSurface = 0;
	device.m_backSurface = 0;
	device.m_device = 0;

	try
	{
	    memset( &ddsd, 0, sizeof( ddsd ) );
	    ddsd.dwSize = sizeof( ddsd );
	    ddsd.dwFlags = DDSD_CAPS | DDSD_HEIGHT |DDSD_WIDTH | DDSD_BACKBUFFERCOUNT;
	    ddsd.ddsCaps.dwCaps = DDSCAPS_OFFSCREENPLAIN | DDSCAPS_SYSTEMMEMORY | DDSCAPS_FLIP |
            DDSCAPS_3DDEVICE | DDSCAPS_COMPLEX;
	    ddsd.dwBackBufferCount = 1;
		ddsd.dwHeight = height;
	    ddsd.dwWidth = width;

	    if(m_DD->CreateSurface(&ddsd, &device.m_frontSurface, NULL) != DD_OK) 
	    	throw ChExInterface(CH_EX_CREATE_FAILED);

		ddsd.ddsCaps.dwCaps = DDSCAPS_BACKBUFFER;

		if(device.m_frontSurface->GetAttachedSurface(&ddsd.ddsCaps, &device.m_backSurface) != DD_OK) 
	    	throw ChExInterface(CH_EX_QUERY_FAILED);


		ChRenderOptimization setting = ((ChMazeWnd*)GetWnd())->GetSettings()->GetRenderOptimization();
		GUID guid = m_drivers[setting].GetGUID();	// our driver to use
		if(m_D3DRM->CreateDeviceFromSurface(&guid, m_DD, device.m_backSurface, &device.m_device) != DD_OK) 
	    	throw ChExInterface(CH_EX_QUERY_FAILED);

	}
	catch( ChExInterface qExcept )
	{
		int val =  qExcept.val;
		TRACE1("Offscreen device creation failure - reason %d", val);  
		RELEASE_INTERFACE(device.m_frontSurface);
		RELEASE_INTERFACE(device.m_backSurface);
		boolSuccess = false;
	}
	catch(...)
	{
		RELEASE_INTERFACE(device.m_frontSurface);
		RELEASE_INTERFACE(device.m_backSurface);
		boolSuccess = false;
	}
	#endif

	return (boolSuccess);
	
}

#endif // D3D


//#endif // (defined(CH_USE_RLAB)) || defined(CH_USE_D3D)




#if 0
	// maybe useful debris
		#if 0
		if(device.m_backSurface->QueryInterface( , &device.m_device) != DD_OK) 
	    	throw ChExInterface(CH_EX_QUERY_FAILED);


           d3dappi.lpBackBuffer->lpVtbl->QueryInterface(d3dappi.lpBackBuffer,
                                                &d3dappi.Driver[driver].Guid,
                                              (LPVOID*)&d3dappi.lpD3DDevice);
		#endif
HRESULT
D3DAppICreateSurface(LPDDSURFACEDESC lpDDSurfDesc,
                LPDIRECTDRAWSURFACE FAR *lpDDSurface) {
    HRESULT result;
    if (d3dappi.bOnlySystemMemory)
        lpDDSurfDesc->ddsCaps.dwCaps |= DDSCAPS_SYSTEMMEMORY;
    result = d3dappi.lpDD->lpVtbl->CreateSurface(d3dappi.lpDD, lpDDSurfDesc,
                                                 lpDDSurface, NULL);
    return result;
}


    ddrval = D3DAppCreateSurface(&ddsd, &myglobs.lpFrameRateBuffer);
    if (ddrval != DD_OK) {
        Msg("Could not create frame rate buffer.\n%s", D3DAppErrorToString(ddrval));    
        goto exit_with_error;
    }
#endif	// debris

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粉嫩aⅴ一区二区三区四区| 欧美极品xxx| 国产91丝袜在线播放0| 亚洲色图制服诱惑| 久久久蜜桃精品| 欧美变态tickle挠乳网站| 成人av在线观| 精品中文字幕一区二区| 亚洲国产精品久久人人爱蜜臀| 欧美激情一二三区| www国产精品av| 欧美精品在线一区二区| 欧美专区日韩专区| 91麻豆国产香蕉久久精品| 成人中文字幕电影| 国产成人无遮挡在线视频| 精品一区二区三区在线播放视频| 丝袜美腿成人在线| 亚洲精品免费一二三区| 亚洲欧美在线观看| 欧美一区二区久久久| 久久99精品久久久久久| 国内精品久久久久影院色| 国产一区二区三区四区五区美女| 国产精品亚洲视频| 色综合欧美在线视频区| 欧美久久一二三四区| 精品成人一区二区三区四区| 国产精品热久久久久夜色精品三区| 亚洲欧美激情视频在线观看一区二区三区| 亚洲影院在线观看| 九一九一国产精品| 一本色道a无线码一区v| 欧美一区二区免费| 亚洲欧美日本在线| 美女视频网站久久| 91色婷婷久久久久合中文| 日韩视频免费观看高清在线视频| 中文字幕av一区二区三区免费看| 亚洲自拍偷拍网站| 国产精品主播直播| 欧美疯狂性受xxxxx喷水图片| 国产亚洲综合在线| 日韩高清国产一区在线| 91精品久久久久久蜜臀| 国产精品免费视频观看| 日韩国产欧美在线播放| 91社区在线播放| 国产亚洲欧美激情| 日韩不卡一二三区| 91黄色小视频| 欧美激情在线免费观看| 久久精品二区亚洲w码| 一本色道久久综合狠狠躁的推荐| 国产三级精品三级| 久久精品国内一区二区三区| 在线观看网站黄不卡| 国产精品大尺度| 国产suv一区二区三区88区| 精品区一区二区| 亚洲图片欧美色图| 91在线国产福利| 中文字幕第一区| 国产精品亚洲综合一区在线观看| 欧美一卡二卡在线观看| 亚洲成精国产精品女| 91福利精品第一导航| 亚洲精品视频在线看| 成人免费看黄yyy456| 国产精品日韩成人| 成年人国产精品| 自拍偷在线精品自拍偷无码专区| 国产精品中文字幕一区二区三区| 精品久久久三级丝袜| 美女视频网站久久| 精品久久人人做人人爰| 国产资源在线一区| 久久久久久免费网| 丁香一区二区三区| 中文字幕一区二区三区av| 99久久久无码国产精品| 日本一区二区三区在线观看| 丰满少妇久久久久久久| 国产精品国产三级国产| 91视频你懂的| 亚洲国产aⅴ成人精品无吗| 欧美夫妻性生活| 麻豆精品视频在线观看视频| 精品国产污网站| 国内欧美视频一区二区| 中文字幕巨乱亚洲| 在线观看av一区| 青青草97国产精品免费观看无弹窗版| 91精品福利在线一区二区三区 | 婷婷激情综合网| 欧美三级午夜理伦三级中视频| 亚洲综合色区另类av| 欧美精品日韩精品| 麻豆精品视频在线观看视频| 国产亚洲制服色| 色乱码一区二区三区88| 美女久久久精品| 国产精品入口麻豆原神| 欧美日韩另类国产亚洲欧美一级| 奇米色一区二区三区四区| 国产亚洲视频系列| 欧美亚洲高清一区二区三区不卡| 日日骚欧美日韩| 中文字幕不卡在线观看| 欧美在线不卡一区| 激情欧美一区二区| 一区二区视频免费在线观看| 日韩欧美在线1卡| 99久久精品一区| 日本三级韩国三级欧美三级| 欧美国产日韩a欧美在线观看| 在线免费一区三区| 国产精华液一区二区三区| 亚洲欧美精品午睡沙发| www成人在线观看| 日本韩国欧美国产| 国产精品456露脸| 性做久久久久久| 中文字幕日韩一区| 日韩精品一区二区三区中文不卡 | 亚洲欧美综合在线精品| 91精品在线麻豆| 99精品在线观看视频| 国产一区二区免费看| 亚洲一区二区三区四区在线| 国产日韩欧美不卡在线| 欧美一级片免费看| 91搞黄在线观看| 99九九99九九九视频精品| 国产综合色在线| 免费人成精品欧美精品| 亚洲超碰精品一区二区| 亚洲精品自拍动漫在线| 欧美国产欧美亚州国产日韩mv天天看完整| 制服.丝袜.亚洲.另类.中文| 色婷婷国产精品久久包臀| 成人午夜电影久久影院| 国产在线国偷精品产拍免费yy| 日韩精品久久理论片| 亚洲欧美韩国综合色| 亚洲日本va午夜在线影院| 国产日韩精品一区| 久久久99精品久久| wwww国产精品欧美| 久久久久久久久久久久久夜| 日韩欧美亚洲一区二区| 91精品婷婷国产综合久久性色| 欧美制服丝袜第一页| 日本精品一区二区三区高清 | 秋霞午夜av一区二区三区| 日韩国产一二三区| 久久精品国产第一区二区三区| 日本亚洲三级在线| 九色综合狠狠综合久久| 激情五月激情综合网| 国产精品白丝jk黑袜喷水| 国产成人av一区二区三区在线| 免费视频一区二区| 久久99国产乱子伦精品免费| 国产一区欧美一区| 国产麻豆精品视频| 99精品国产热久久91蜜凸| 在线观看成人小视频| 51精品视频一区二区三区| 日韩免费观看2025年上映的电影| 精品嫩草影院久久| 欧美高清在线精品一区| 成人免费在线视频| 天堂成人免费av电影一区| 美日韩黄色大片| 成人开心网精品视频| 欧美日韩黄色影视| 久久综合九色欧美综合狠狠 | 欧美午夜精品一区二区三区| 91精品国产品国语在线不卡| 精品理论电影在线观看| 中文字幕一区二区三区在线播放| 亚洲综合丝袜美腿| 韩国欧美国产一区| 91一区二区在线观看| 欧美一卡二卡三卡四卡| 中文字幕一区二区三区视频| 日韩专区一卡二卡| 成人涩涩免费视频| 欧美人与禽zozo性伦| 欧美国产日本韩| 天堂一区二区在线| av不卡免费在线观看| 日韩欧美一级片| 亚洲女人的天堂| 国内精品写真在线观看 | 视频在线观看91| 激情欧美一区二区三区在线观看| www.在线成人| 欧美精品一区二区不卡|