Difference Between Directx9 And 11
Important changes from Direct3D 9 to Direct3D 11. 8 minutes to read. Contributors.In this articleSummary. Important changes from Direct3D 9 to Direct3D 11.This topic explains the high-level differences between DirectX 9 and DirectX 11.Direct3D 11 is fundamentally the same type of API as Direct3D 9 - a low-level, virtualized interface into graphics hardware. It still allows you to perform graphics drawing operations on a variety of hardware implementations. The layout of the graphics API has changed since Direct3D 9; the concept of a device context has been expanded, and an API has been added specifically for graphics infrastructure. Resources stored on the Direct3D device have a novel mechanism for data polymorphism called a resource view.
Core API functionsIn Direct3D 9 you had to create an interface to the Direct3D API before you could start using it. In your Direct3D 11 Universal Windows Platform (UWP) game, you call a static function called to create the device and the device context. Devices and device contextA Direct3D 11 device represents a virtualized graphics adapter. It's used to create resources in video memory, for example: uploading textures to the GPU, creating views on texture resources and swap chains, and creating texture samplers. For a complete list of what a Direct3D 11 device interface is used for see and.A Direct3D 11. Device context is used to set pipeline state and generate rendering commands. For example, a Direct3D 11 rendering chain uses a device context to set up the rendering chain and draw the scene (see below).
The device context is used to access (map) video memory used by Direct3D device resources; it's also used to update subresource data, for example constant buffer data. For a complete list of what a Direct3D 11 device context is used for see. Note that most of our samples use an immediate context to render directly to the device, but Direct3D 11 also supports deferred device contexts, which are primarily used for multithreading.In Direct3D 11, the device handle and device context handle are both obtained by calling.
This method is also where you request a specific set of hardware features and retrieve information on Direct3D feature levels supported by the graphics adapter. See for more info on devices, device contexts, and threading considerations. Device infrastructure, frame buffers, and render target viewsIn Direct3D 11, the device adapter and hardware configuration are set with the DirectX Graphics Infrastructure (DXGI) API using the and COM interfaces. Buffers and other window resources (visible or offscreen) are created and configured by specific DXGI interfaces; the factory pattern implementation acquires DXGI resources such as the frame buffer. Since DXGI owns the swap chain, a DXGI interface is used to present frames to the screen - see.Use to create a swap chain compatible with your game. You need to create a swap chain for a core window, or for composition (XAML interop), instead of creating a swap chain for an HWND. Device resources and resource viewsDirect3D 11 supports an additional level of polymorphism on video memory resources known as views.
Essentially, where you had a single Direct3D 9 object for a texture, you now have two objects: the texture resource, which holds the data, and the resource view, which indicates how the view is used for rendering. A view based on a resource enables that resource to be used for a specific purpose.
For example, a 2D texture resource is created as an, then a shader resource view is created on it so it can be used as a texture in a shader. A render target view can also be created on the same 2D texture resource so that it can be used as a drawing surface. In another example, the same pixel data is represented in 2 different pixel formats by using 2 separate views on a single texture resource.The underlying resource must be created with properties that are compatible with the type of views that will be created from it. For example, if an is applied to a surface, that surface is created with the flag. The surface also has to have a DXGI surface format compatible with rendering (see ).Most of the resources you use for rendering inherit from the interface, which inherits from. Vertex buffers, index buffers, constant buffers, and shaders are all Direct3D 11 resources.
Input layouts and sampler states inherit directly from.Resources views use a DXGIFORMAT enum value to indicate the pixel format. Not every D3DFMT is supported as a DXGIFORMAT. For example, there is no 24bpp RGB format in DXGI that is equivalent to D3DFMTR8G8B8. There are also not BGR equivalents to every RGB format (DXGIFORMATR10G10B10A2UNORM is equivalent to D3DFMTA2B10G10R10, but there’s no direct equivalent to D3DFMTA2R10G10B10). You should plan to convert any content in these legacy formats to supported formats at build-time. For a complete list of DXGI formats see the enumeration.Direct3D device resources (and resource views) are created before the scene is rendered. Device contexts are used to set up the rendering chain, as explained below.
Device context and the rendering chainIn Direct3D 9 and Direct3D 10.x, there was a single Direct3D device object which managed resource creation, state, and drawing. In Direct3D 11, the Direct3D device interface still manages resource creation, but all state and drawing operations are handled by using a Direct3D device context. Here's an example of how the device context ( interface) is used to set up the rendering chain:.
Set and clear render target views (and depth stencil view). Set the vertex buffer, index buffer, and input layout for the input assembler stage (IA stage). Bind vertex and pixel shaders to the pipeline. Bind constant buffers to shaders.
Bind texture views and samplers to the pixel shader. Draw the sceneWhen one of the methods is called, the scene is drawn on the render target view. When you're done will all your drawing the DXGI adapter is used to present the completed frame by calling. State managementDirect3D 9 managed state settings with a large set of individual toggles set with the SetRenderState, SetSamplerState, and SetTextureStageState methods. Since Direct3D 11 does not support the legacy fixed-function pipeline, the SetTextureStageState is replaced by writing pixel shaders (PS). There is no equivalent to a Direct3D 9 state block. Direct3D 11 instead manages state through the use of 4 kinds of state objects which provide a more streamlined way to group the rendering state.For example, instead of using SetRenderState with D3DRSZENABLE, you create a DepthStencilState object with this and other related state settings and use it to change state while rendering.When porting Direct3D 9 applications to state objects, be aware that your various state combinations are represented as immutable state objects.
Civ 5 Directx 9 Vs 11
They should be created once and re-used as long as they are valid. Direct3D feature levelsDirect3D has a new mechanism for determining hardware support called feature levels. Feature levels simplify the task of figuring out what the graphics adapter can do by allowing you to request a well-defined set of GPU functionality. For example, the 91 feature level implements the functionality provided by Direct3D 9 graphics adapters, including shader model 2.x. Since 91 is the lowest feature level, you can expect all devices to support a vertex shader and a pixel shader, which were the same stages supported by the Direct3D 9 programmable shader model.Your game will use to create the Direct3D device and device context. When you call this function you provide a list of feature levels that your game can support.
It will return the highest supported feature level from that list. For example if your game can use BC4/BC5 textures (a feature of DirectX 10 hardware), you would include at least 91 and 100 in the list of supported feature levels. If the game is running on DirectX 9 hardware and BC4/BC5 textures can't be used, then will return 91. Then your game can fall back to a different texture format (and smaller textures).If you decide to extend your Direct3D 9 game to support higher Direct3D feature levels then it's better to finish porting your existing Direct3D 9 graphics code first.
Directx 9 Vs 12
After you have your game working in Direct3D 11, it's easier to add additional rendering paths with enhanced graphics.See for a detailed explanation of feature level support. See and for a full list of Direct3D 11 features. Feature levels and the programmable pipelineHardware has continue to evolve since Direct3D 9, and several new optional stages have been added to the programmable graphics pipeline. The set of options you have for the graphics pipeline varies with the Direct3D feature level. Feature level 10.0 includes the geometry shader stage with optional stream out for multipass rendering on the GPU. Feature level 110 include the hull shader and domain shader for use with hardware tessellation.
Feature level 110 also includes full support for DirectCompute shaders, while feature levels 10.x only include support for a limited form of DirectCompute.All shaders are written in HLSL using a shader profile that corresponds to a Direct3D feature level. Shader profiles are upwards compatible, so an HLSL shader that compiles using vs40level91 or ps40level91 will work across all devices. Shader profiles are not downlevel compatible, so a shader compiled using vs41 will only work on feature level 101, 110, or 111 devices.Direct3D 9 managed constants for shaders using a shared array with SetVertexShaderConstant and SetPixelShaderConstant.
Direct3D 11 uses constant buffers, which are resources like a vertex buffer or index buffer. Constant buffers are designed to be updated efficiently.
Instead of having all the shader contants organized into a single global array you organize your constants into logical groupings and manage them through one or more constant buffers. When you port your Direct3D 9 game to Direct3D 11, plan to organize your constant buffers so that you can update them appropriately. For example, group shader constants that aren't updated every frame into a separate constant buffer, so that you don't have to constantly upload that data to the graphics adapter along with your more dynamic shader constants.Note Most Direct3D 9 applications made extensive use of shaders, but occasionally mixed in use of the legacy fixed-function behavior. Note that Direct3D 11 only uses a programmable shading model. The legacy fixed-function features of Direct3D 9 are deprecated.Feedback.