D3D、OpenGL和软件加速有什么区别(opengl和d3d谁更流畅)

D3D、OpenGL和软件加速有什么区别(opengl和d3d谁更流畅),第1张

Direct3D是Microsoft公司的硬件API。而OpenGL则是开放性的硬件API。软件加速是不利用硬件加速,纯粹依赖CPU计算来生成游戏图像。

Direct3D和OpenGL旗鼓相当,都支持着一系列优秀的游戏。它们的基本作用都是在硬件与游戏程序之前提供一个中间层,使得游戏程序能正确,高效地调用图形硬件(主要是你的显卡)来完成画面的绘制。它们的性能就取决于你的图形硬件。

软件加速是无视你的图形硬件的。它们纯粹依靠CPU计算来生成画面。因此对显卡之类的硬件没有要求。它的性能和画质也因此极大地落后于Direct3D与OpenGL。

这可能是由于您的摄像机配置或着色器配置不正确导致的。可以尝试检查您的摄像机位置,确保它在正确的位置。另外,您也可以检查您的着色器设置,确保它们能够正确控制车轮的转动。如果以上都无法解决,您可以尝试更新您的OpenGL驱动程序,以确保您的系统可以正确运行OpenGL程序。

你在你的分线程里调用

wglMakeCurrent来把HDC和当前可用的HGLRC连接起来,记住,OPENGL的HGLRC同一时间只能在一个线程内使用,也就是说它是线程安全的,当然你这个线程结束前必须调用wglMakeCurrent (NULL, NULL)

如果在你的版本中这样做也不成功的话

建议你在进入线程的时候用

wglCreateContext (hdc);

wglMakeCurrent (hdc, hglrc);

线程退出前用

wglMakeCurrent (NULL, NULL) ;

wglDeleteContext (hglrc);

这样一般都没问题

=================================================

如果你是动态在你的线程里面创建这个控件的话就没问题

如果你是用消息线程创建的话就不行了,你无法在你自己创建的线程里使用

其实如果不是非常的需要,不推荐用线程,可以的话,建议用Timer来解决

=================================================

原因我上面说了,OPENGL是线程安全的,它的渲染上下文是无法在多个线程里同时使用的;另:要开发OPENGL程序,如果你用MFC框架的话建议你先了解一下MFC;如果是纯SDK开发的话就需要着重研究OPENGL对运行环境的需求。可能你的VS版本高,有提供TIMER控件,这个是定时器来的,每间隔一段你定义好的时间它发送出一个WM_TIMER消息到你的窗口;如果你还不清楚TIMER的话建议你先去了解一下WINDOWS的消息机制;记住,OPENGL不是给初学编程的玩的;没有一定的基础,就算你写出了代码,你也不知道它为什么都是这样工作的;而且多线程编程是一个难点,不但要解决同步问题,调试起来也非常困难,经常会遇到些莫名其妙的问题。就像你这个问题一样,这问题是由于你对OPENGL运行要求不清楚导致的。

二、生成OpenGL程序的基本步骤和条件 本文将给出一个例子,这个例子是一个用OpenGL显示图像的Windows程序,通过这个程序我们也可以知道用OpenGL编程的基本要求。我们知道,GDI是通过设备句柄(Device Context以下简称"DC")来绘图,而OpenGL则需要绘制环境(Rendering Context,以下简称"RC")。每一个GDI命令需要传给它一个DC,与GDI不同,OpenGL使用当前绘制环境(RC)。一旦在一个线程中指定了一个当前RC,所有在此线程中的OpenGL命令都使用相同的当前RC。虽然在单一窗口中可以使用多个RC,但在单一线程中只有一个当前RC。本例将首先产生一个OpenGL RC并使之成为当前RC,分为三个步骤:设置窗口像素格式;产生RC;设置为当前RC。 一、首先创建工程 用AppWizard产生一个EXE文件,选择工程目录,并在工程名字中输入"GLSample一",保持其他的不变;第一步、选单文档(SDI);第二步、不支持数据库;第三步、不支持OLE;第四步、不选中浮动工具条、开始状态条、打印和预览支持、帮助支持的复选框(选中也可以,本文只是说明最小要求),选中三维控制(三D Controls);第五步、选中产生源文件注释并使用MFC为共享动态库;第六步、保持缺省选择。按Finish结束,工程创建完毕。 二、将此工程所需的OpenGL文件 和库加入到工程中 在工程菜单中,选择"Build"下的"Settings"项。单击"Link"标签,选择"General"目录,在Object/Library Modules的编辑框中输入"OpenGL三二lib glu三二lib glauxlib"(注意,输入双引号中的内容,各个库用空格分开;否则会出现链接错误),选择"OK"结束。然后打开文件"stdafxh",将下列语句插入到文件中(划下划线的语句为所加语句): #define VC_EXTRALEAN // Exclude rarely-used stuff from Windows headers #include // MFC core and standard components #include // MFC extensions #include #include #ifndef _AFX_NO_AFXCMN_SUPPORT #include // MFC support for Windows 95 Common Controls #endif // _AFX_NO_AFXCMN_SUPPORT 三、改写OnPreCreate函数并给视 类添加成员函数和成员变量 OpenGL需要窗口加上WS_CLIPCHILDREN(创建父窗口使用的Windows风格,用于重绘时裁剪子窗口所覆盖的区域)和 WS_CLIPSIBLINGS(创建子窗口使用的Windows风格,用于重绘时剪裁其他子窗口所覆盖的区域)风格。把OnPreCreate改写成如下所示: BOOL CGLSample一View::PreCr- eateWindow(CREATESTRUCT& cs) { csstyle |= (WS_CLIPCHI- LDREN | WS_CLIPSIBLINGS); return CView::PreCreate- Window(cs); } 产生一个RC的第一步是定义窗口的像素格式。像素格式决定窗口着所显示的图形在内存中是如何表示的。由像素格式控制的参数包括:颜色深度、缓冲模式和所支持的绘画接口。在下面将有对这些参数的设置。我们先在CGLSample一View的类中添加一个保护型的成员函数BOOL SetWindowPixel-Format(HDC hDC)(用鼠标右键添加),并编辑其中的代码,见程序一。 BOOL CGLSample一View::SetWindowPixelFormat(HDC hDC) { PIXELFORMATDESCRIPTOR pixelDesc; pixelDescnSize = sizeof(PIXELFORMATDESCRIPTOR); pixelDescnVersion = 一; pixelDescdwFlags = PFD_DRAW_TO_WINDOW | PFD_DRAW_TO_BITMAP | PFD_SUPPORT_OpenGL | PFD_SUPPORT_GDI | PFD_STEREO_DONTCARE; pixelDesciPixelType = PFD_TYPE_RGBA; pixelDesccColorBits = 三二; pixelDesccRedBits = 吧; pixelDesccRedShift = 一陆; pixelDesccGreenBits = 吧; pixelDesccGreenShift = 吧; pixelDesccBlueBits = 吧; pixelDesccBlueShift = 0; pixelDesccAlphaBits = 0; pixelDesccAlphaShift = 0; pixelDesccAccumBits = 陆四; pixelDesccAccumRedBits = 一陆; pixelDesccAccumGreenBits = 一陆; pixelDesccAccumBlueBits = 一陆; pixelDesccAccumAlphaBits = 0; pixelDesccDepthBits = 三二; pixelDesccStencilBits = 吧; pixelDesccAuxBuffers = 0; pixelDesciLayerType = PFD_MAIN_PLANE; pixelDescbReserved = 0; pixelDescdwLayerMask = 0; pixelDescdwVisibleMask = 0; pixelDescdwDamageMask = 0; m_GLPixelIndex = ChoosePixelFormat( hDC, &pixelDesc); if (m_GLPixelIndex==0) // Lets choose a default index { m_GLPixelIndex = 一; if (DescribePixelFormat(hDC, m_GLPixelIndex, sizeof(PIXELFORMATDESCRIPTOR), &pixelDesc)==0) { return FALSE; } } if (SetPixelFormat( hDC, m_GLPixelIndex, &pixelDesc)==FALSE) { return FALSE; } return TRUE; } 接着用鼠标右键在CGLSample一View中添加保护型的成员变量: int m_GLPixelIndex; 四、用ClassWizard添加WM_CREATE的消息处理函数OnCreate 添加OnCreate函数后如程序一所示。 至此,OpenGL工程的基本框架就建好了。但如果你现在运行此工程,则它与一般的MFC程序看起来没有什么两样。 5、代码解释 现在我们可以看一看Describe-PixelFormat提供有哪几种像素格式,并对代码进行一些解释: PIXELFORMATDESCRIPTOR包括了定义像素格式的全部信息。 DWFlags定义了与像素格式兼容的设备和接口。 通常的OpenGL发行版本并不包括所有的标志(flag)。wFlags能接收以下标志: PFD_DRAW_TO_WINDOW 使之能在窗口或者其他设备窗口画图; PFD_DRAW_TO_BITMAP 使之能在内存中的位图画图; PFD_SUPPORT_GDI 使之能调用GDI函数(注:如果指定了PFD_DOUBLEBUFFER,这个选项将无效); PFD_SUPPORT_OpenGL 使之能调用OpenGL函数; PFD_GENERIC_FORMAT 假如这种象素格式由Windows GDI函数库或由第三方硬件设备驱动程序支持,则需指定这一项; PFD_NEED_PALETTE 告诉缓冲区是否需要调色板,本程序假设颜色是使用二四或 三二位色,并且不会覆盖调色板; PFD_NEED_SYSTEM_PALETTE 这个标志指明缓冲区是否把系统调色板当作它自身调色板的一部分; PFD_DOUBLEBUFFER 指明使用了双缓冲区(注:GDI不能在使用了双缓冲区的窗口中画图); PFD_STEREO 指明左、右缓冲区是否按立体图像来组织。 PixelType定义显示颜色的方法。PFD_TYPE_RGBA意味着每一位(bit)组代表着红、绿、蓝各分量的值。PFD_TYPE_COLORINDEX 意味着每一位组代表着在彩色查找表中的索引值。本例都是采用了PFD_TYPE_RGBA方式。 ● cColorBits定义了指定一个颜色的位数。对RGBA来说,位数是在颜色中红、绿、蓝各分量所占的位数。对颜色的索引值来说,指的是表中的颜色数。 ● cRedBits、cGreenBits、cBlue-Bits、cAlphaBits用来表明各相应分量所使用的位数。 ● cRedShift、cGreenShift、cBlue-Shift、cAlphaShift用来表明各分量从颜色开始的偏移量所占的位数。 一旦初始化完我们的结构,我们就想知道与要求最相近的系统象素格式。我们可以这样做: m_hGLPixelIndex = ChoosePixelFormat(hDC, &pixelDesc); ChoosePixelFormat接受两个参数:一个是hDc,另一个是一个指向PIXELFORMATDESCRIPTOR结构的指针&pixelDesc;该函数返回此像素格式的索引值。如果返回0则表示失败。假如函数失败,我们只是把索引值设为一并用DescribePixelFormat得到像素格式描述。假如你申请一个没得到支持的像素格式,则Choose-PixelFormat将会返回与你要求的像素格式最接近的一个值。一旦我们得到一个像素格式的索引值和相应的描述,我们就可以调用SetPixelFormat设置像素格式,并且只需设置一次。 现在像素格式已经设定,我们下一步工作是产生绘制环境(RC)并使之成为当前绘制环境。在CGLSample一View中加入一个保护型的成员函数BOOL CreateViewGLContext(HDC hDC),使之如下所示: BOOL CGLSample一View::CreateView GLContext(HDC hDC) { m_hGLContext = wglCreate Context(hDC);//用当前DC产生绘制环境(RC) if (m_hGLContext == NULL) { return FALSE; } if (wglMakeCurrent(hDC, m_hGLContext)==FALSE) { return FALSE; } return TRUE; } 并加入一个保护型的成员变量HGLRC m_hGLContext;HGLRC是一个指向rendering context的句柄。 在OnCreate函数中调用此函数: int CGLSample一View::OnCreate (LPCREATESTRUCT lpCreateStruct) { if (CView::OnCreate(lpCreateS truct) == -一) return -一; HWND hWnd = GetSafeHwnd(); HD

以上就是关于D3D、OpenGL和软件加速有什么区别(opengl和d3d谁更流畅)全部的内容,包括:D3D、OpenGL和软件加速有什么区别(opengl和d3d谁更流畅)、opengl车身不动,车轮转动、一开始是在主线程中用到了OpenGL画图,后来把OpenGL放在一个分线程里就画不出图了等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zz/10091954.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存