| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
- //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
- #pragma once
- #include "BsGLPrerequisites.h"
- #include "BsGLRenderAPI.h"
- #include "BsRenderWindow.h"
- namespace BansheeEngine
- {
- /**
- * @brief Helper class dealing mostly with platform specific OpenGL functionality,
- * initialization, extensions and window creation.
- */
- class BS_RSGL_EXPORT GLSupport
- {
- public:
- GLSupport() { }
- virtual ~GLSupport() { }
- /**
- * @brief Creates a new render window using the specified descriptor.
- *
- * @param desc Description of a render window to create.
- * @param windowId Window ID provided by the render window manager.
- * @param parentWindow Optional parent window if the window shouldn't be a main window. First
- * created window cannot have a parent.
- *
- * @param Returns newly created window.
- */
- virtual RenderWindowPtr newWindow(RENDER_WINDOW_DESC& desc, UINT32 windowId, RenderWindowPtr parentWindow) = 0;
- /**
- * @brief Creates a new render window using the specified descriptor.
- *
- * @param desc Description of a render window to create.
- * @param windowId Window ID provided by the render window manager.
- * @param parentWindow Optional parent window if the window shouldn't be a main window. First
- * created window cannot have a parent.
- *
- * @param Returns newly created window.
- */
- virtual SPtr<RenderWindowCore> newWindowCore(RENDER_WINDOW_DESC& desc, UINT32 windowId) = 0;
- /**
- * @brief Called when OpenGL is being initialized.
- */
- virtual void start() = 0;
- /**
- * @brief Called when OpenGL is being shut down.
- */
- virtual void stop() = 0;
- /**
- * @brief Gets OpenGL vendor name.
- */
- const String& getGLVendor() const
- {
- return mVendor;
- }
- /**
- * @brief Gets OpenGL version string.
- */
- const String& getGLVersion() const
- {
- return mVersion;
- }
- /**
- * @brief Checks is the specified extension available.
- */
- virtual bool checkExtension(const String& ext) const;
- /**
- * @brief Gets an address of an OpenGL procedure with the specified name.
- */
- virtual void* getProcAddress(const String& procname) = 0;
- /**
- * @brief Initializes OpenGL extensions. Must be called after we have a valid and active
- * OpenGL context.
- */
- virtual void initializeExtensions();
- /**
- * @brief Gets a structure describing all available video modes.
- */
- virtual VideoModeInfoPtr getVideoModeInfo() const = 0;
- protected:
- Set<String> extensionList;
- String mVersion;
- String mVendor;
- };
- };
|