+++ /dev/null
-/*\r
-* Copyright (c) 2007-2010 SlimDX Group\r
-* \r
-* Permission is hereby granted, free of charge, to any person obtaining a copy\r
-* of this software and associated documentation files (the "Software"), to deal\r
-* in the Software without restriction, including without limitation the rights\r
-* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r
-* copies of the Software, and to permit persons to whom the Software is\r
-* furnished to do so, subject to the following conditions:\r
-* \r
-* The above copyright notice and this permission notice shall be included in\r
-* all copies or substantial portions of the Software.\r
-* \r
-* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
-* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r
-* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r
-* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r
-* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r
-* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r
-* THE SOFTWARE.\r
-*/\r
-#pragma once\r
-\r
-#include "Enums.h"\r
-#include "ObjectDxgi.h"\r
-\r
-namespace SlimDX\r
-{\r
- namespace DXGI\r
- {\r
- ref class Adapter;\r
-\r
- /// <summary>\r
- /// Implements methods for generating DXGI objects.\r
- /// </summary>\r
- /// <unmanaged>IDXGIFactory</unmanaged>\r
- public ref class Factory : DXGIObject\r
- {\r
- COMOBJECT(IDXGIFactory, Factory);\r
- \r
- private protected:\r
- // Terrible no-op constructor hack for Factory1.\r
- Factory( bool /*hack*/ ) { }\r
-\r
- public:\r
- /// <summary>\r
- /// Initializes a new instance of the <see cref="Factory"/> class.\r
- /// </summary>\r
- Factory();\r
- \r
- /// <summary>\r
- /// Gets the number of available adapters.\r
- /// </summary>\r
- /// <returns>The number of available adapters.</returns>\r
- int GetAdapterCount();\r
- \r
- /// <summary>\r
- /// Gets the specified adapter.\r
- /// </summary>\r
- /// <param name="index">The index of the desired adapter.</param>\r
- /// <returns>The specified adapter, or <c>null</c> on failure.</returns>\r
- Adapter^ GetAdapter( int index );\r
- \r
- /// <summary>\r
- /// Creates a software adapter interface.\r
- /// </summary>\r
- /// <param name="softwareModule">The unmanaged HMODULE for the software adapter DLL.</param>\r
- /// <returns>The specified adapter, or <c>null</c> on failure.</returns>\r
- [System::Security::Permissions::SecurityPermission( System::Security::Permissions::SecurityAction::LinkDemand, Flags=System::Security::Permissions::SecurityPermissionFlag::UnmanagedCode )]\r
- Adapter^ CreateSoftwareAdapter( System::IntPtr softwareModule );\r
- \r
- /// <summary>\r
- /// Creates a software adapater interface.\r
- /// </summary>\r
- /// <param name="softwareModule">The module for the software adapter DLL.</param>\r
- /// <returns>The specified adapter, or <c>null</c> on failure.</returns>\r
- [System::Security::Permissions::SecurityPermission( System::Security::Permissions::SecurityAction::LinkDemand, Flags=System::Security::Permissions::SecurityPermissionFlag::UnmanagedCode )]\r
- Adapter^ CreateSoftwareAdapter( System::Reflection::Module^ softwareModule );\r
- \r
- /// <summary>\r
- /// Gets the window handle associated with the factory (the window through which the user signals fullscreen transitions).\r
- /// </summary>\r
- /// <returns>The window handle.</returns>\r
- System::IntPtr GetWindowAssociation();\r
- \r
- /// <summary>\r
- /// Sets the window handle associated with the factory (the window through which the user signals fullscreen transitions).\r
- /// </summary>\r
- /// <param name="handle">The window handle.</param>\r
- /// <param name="flags">Flags controlling window association behavior.</param>\r
- /// <returns>A <see cref="SlimDX::Result"/> object describing the result of the operation.</returns>\r
- Result SetWindowAssociation( System::IntPtr handle, WindowAssociationFlags flags );\r
- };\r
- }\r
-}
\ No newline at end of file