//////////////////////////////////////////////////////////// // // SFML - Simple and Fast Multimedia Library // Copyright (C) 2007-2013 Laurent Gomila (laurent.gom@gmail.com) // // This software is provided 'as-is', without any express or implied warranty. // In no event will the authors be held liable for any damages arising from the use of this software. // // Permission is granted to anyone to use this software for any purpose, // including commercial applications, and to alter it and redistribute it freely, // subject to the following restrictions: // // 1. The origin of this software must not be misrepresented; // you must not claim that you wrote the original software. // If you use this software in a product, an acknowledgment // in the product documentation would be appreciated but is not required. // // 2. Altered source versions must be plainly marked as such, // and must not be misrepresented as being the original software. // // 3. This notice may not be removed or altered from any source distribution. // //////////////////////////////////////////////////////////// #ifndef SFML_WINDOW_H #define SFML_WINDOW_H //////////////////////////////////////////////////////////// // Headers //////////////////////////////////////////////////////////// #include #include #include #include #include #include //////////////////////////////////////////////////////////// /// \brief Enumeration of window creation styles /// //////////////////////////////////////////////////////////// enum { sfNone = 0, ///< No border / title bar (this flag and all others are mutually exclusive) sfTitlebar = 1 << 0, ///< Title bar + fixed border sfResize = 1 << 1, ///< Titlebar + resizable border + maximize button sfClose = 1 << 2, ///< Titlebar + close button sfFullscreen = 1 << 3, ///< Fullscreen mode (this flag and all others are mutually exclusive) sfDefaultStyle = sfTitlebar | sfResize | sfClose ///< Default window style }; //////////////////////////////////////////////////////////// /// \brief Structure defining the window's creation settings /// //////////////////////////////////////////////////////////// typedef struct { unsigned int depthBits; ///< Bits of the depth buffer unsigned int stencilBits; ///< Bits of the stencil buffer unsigned int antialiasingLevel; ///< Level of antialiasing unsigned int majorVersion; ///< Major number of the context version to create unsigned int minorVersion; ///< Minor number of the context version to create } sfContextSettings; //////////////////////////////////////////////////////////// /// \brief Construct a new window /// /// This function creates the window with the size and pixel /// depth defined in \a mode. An optional style can be passed to /// customize the look and behaviour of the window (borders, /// title bar, resizable, closable, ...). If \a style contains /// sfFullscreen, then \a mode must be a valid video mode. /// /// The fourth parameter is a pointer to a structure specifying /// advanced OpenGL context settings such as antialiasing, /// depth-buffer bits, etc. /// /// \param mode Video mode to use (defines the width, height and depth of the rendering area of the window) /// \param title Title of the window /// \param style Window style /// \param settings Additional settings for the underlying OpenGL context /// /// \return A new sfWindow object /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfWindow* sfWindow_create(sfVideoMode mode, const char* title, sfUint32 style, const sfContextSettings* settings); //////////////////////////////////////////////////////////// /// \brief Construct a new window (with a UTF-32 title) /// /// This function creates the window with the size and pixel /// depth defined in \a mode. An optional style can be passed to /// customize the look and behaviour of the window (borders, /// title bar, resizable, closable, ...). If \a style contains /// sfFullscreen, then \a mode must be a valid video mode. /// /// The fourth parameter is a pointer to a structure specifying /// advanced OpenGL context settings such as antialiasing, /// depth-buffer bits, etc. /// /// \param mode Video mode to use (defines the width, height and depth of the rendering area of the window) /// \param title Title of the window (UTF-32) /// \param style Window style /// \param settings Additional settings for the underlying OpenGL context /// /// \return A new sfWindow object /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfWindow* sfWindow_createUnicode(sfVideoMode mode, const sfUint32* title, sfUint32 style, const sfContextSettings* settings); //////////////////////////////////////////////////////////// /// \brief Construct a window from an existing control /// /// Use this constructor if you want to create an OpenGL /// rendering area into an already existing control. /// /// The second parameter is a pointer to a structure specifying /// advanced OpenGL context settings such as antialiasing, /// depth-buffer bits, etc. /// /// \param handle Platform-specific handle of the control /// \param settings Additional settings for the underlying OpenGL context /// /// \return A new sfWindow object /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfWindow* sfWindow_createFromHandle(sfWindowHandle handle, const sfContextSettings* settings); //////////////////////////////////////////////////////////// /// \brief Destroy a window /// /// \param window Window to destroy /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_destroy(sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Close a window and destroy all the attached resources /// /// After calling this function, the sfWindow object remains /// valid, you must call sfWindow_destroy to actually delete it. /// All other functions such as sfWindow_pollEvent or sfWindow_display /// will still work (i.e. you don't have to test sfWindow_isOpen /// every time), and will have no effect on closed windows. /// /// \param window Window object /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_close(sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Tell whether or not a window is opened /// /// This function returns whether or not the window exists. /// Note that a hidden window (sfWindow_setVisible(sfFalse)) will return /// sfTrue. /// /// \param window Window object /// /// \return sfTrue if the window is opened, sfFalse if it has been closed /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfBool sfWindow_isOpen(const sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Get the settings of the OpenGL context of a window /// /// Note that these settings may be different from what was /// passed to the sfWindow_create function, /// if one or more settings were not supported. In this case, /// SFML chose the closest match. /// /// \param window Window object /// /// \return Structure containing the OpenGL context settings /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfContextSettings sfWindow_getSettings(const sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Pop the event on top of event queue, if any, and return it /// /// This function is not blocking: if there's no pending event then /// it will return false and leave \a event unmodified. /// Note that more than one event may be present in the event queue, /// thus you should always call this function in a loop /// to make sure that you process every pending event. /// /// \param window Window object /// \param event Event to be returned /// /// \return sfTrue if an event was returned, or sfFalse if the event queue was empty /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfBool sfWindow_pollEvent(sfWindow* window, sfEvent* event); //////////////////////////////////////////////////////////// /// \brief Wait for an event and return it /// /// This function is blocking: if there's no pending event then /// it will wait until an event is received. /// After this function returns (and no error occured), /// the \a event object is always valid and filled properly. /// This function is typically used when you have a thread that /// is dedicated to events handling: you want to make this thread /// sleep as long as no new event is received. /// /// \param window Window object /// \param event Event to be returned /// /// \return sfFalse if any error occured /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfBool sfWindow_waitEvent(sfWindow* window, sfEvent* event); //////////////////////////////////////////////////////////// /// \brief Get the position of a window /// /// \param window Window object /// /// \return Position in pixels /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfVector2i sfWindow_getPosition(const sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Change the position of a window on screen /// /// This function only works for top-level windows /// (i.e. it will be ignored for windows created from /// the handle of a child window/control). /// /// \param window Window object /// \param position New position of the window, in pixels /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setPosition(sfWindow* window, sfVector2i position); //////////////////////////////////////////////////////////// /// \brief Get the size of the rendering region of a window /// /// The size doesn't include the titlebar and borders /// of the window. /// /// \param window Window object /// /// \return Size in pixels /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfVector2u sfWindow_getSize(const sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Change the size of the rendering region of a window /// /// \param window Window object /// \param size New size, in pixels /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setSize(sfWindow* window, sfVector2u size); //////////////////////////////////////////////////////////// /// \brief Change the title of a window /// /// \param window Window object /// \param title New title /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setTitle(sfWindow* window, const char* title); //////////////////////////////////////////////////////////// /// \brief Change the title of a window (with a UTF-32 string) /// /// \param window Window object /// \param title New title /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setUnicodeTitle(sfWindow* window, const sfUint32* title); //////////////////////////////////////////////////////////// /// \brief Change a window's icon /// /// \a pixels must be an array of \a width x \a height pixels /// in 32-bits RGBA format. /// /// \param window Window object /// \param width Icon's width, in pixels /// \param height Icon's height, in pixels /// \param pixels Pointer to the array of pixels in memory /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setIcon(sfWindow* window, unsigned int width, unsigned int height, const sfUint8* pixels); //////////////////////////////////////////////////////////// /// \brief Show or hide a window /// /// \param window Window object /// \param visible sfTrue to show the window, sfFalse to hide it /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setVisible(sfWindow* window, sfBool visible); //////////////////////////////////////////////////////////// /// \brief Show or hide the mouse cursor /// /// \param window Window object /// \param visible sfTrue to show, sfFalse to hide /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setMouseCursorVisible(sfWindow* window, sfBool visible); //////////////////////////////////////////////////////////// /// \brief Enable or disable vertical synchronization /// /// Activating vertical synchronization will limit the number /// of frames displayed to the refresh rate of the monitor. /// This can avoid some visual artifacts, and limit the framerate /// to a good value (but not constant across different computers). /// /// \param window Window object /// \param enabled sfTrue to enable v-sync, sfFalse to deactivate /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setVerticalSyncEnabled(sfWindow* window, sfBool enabled); //////////////////////////////////////////////////////////// /// \brief Enable or disable automatic key-repeat /// /// If key repeat is enabled, you will receive repeated /// KeyPress events while keeping a key pressed. If it is disabled, /// you will only get a single event when the key is pressed. /// /// Key repeat is enabled by default. /// /// \param window Window object /// \param enabled sfTrue to enable, sfFalse to disable /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setKeyRepeatEnabled(sfWindow* window, sfBool enabled); //////////////////////////////////////////////////////////// /// \brief Activate or deactivate a window as the current target /// for OpenGL rendering /// /// A window is active only on the current thread, if you want to /// make it active on another thread you have to deactivate it /// on the previous thread first if it was active. /// Only one window can be active on a thread at a time, thus /// the window previously active (if any) automatically gets deactivated. /// /// \param window Window object /// \param active sfTrue to activate, sfFalse to deactivate /// /// \return sfTrue if operation was successful, sfFalse otherwise /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfBool sfWindow_setActive(sfWindow* window, sfBool active); //////////////////////////////////////////////////////////// /// \brief Display on screen what has been rendered to the /// window so far /// /// This function is typically called after all OpenGL rendering /// has been done for the current frame, in order to show /// it on screen. /// /// \param window Window object /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_display(sfWindow* window); //////////////////////////////////////////////////////////// /// \brief Limit the framerate to a maximum fixed frequency /// /// If a limit is set, the window will use a small delay after /// each call to sfWindow_display to ensure that the current frame /// lasted long enough to match the framerate limit. /// /// \param window Window object /// \param limit Framerate limit, in frames per seconds (use 0 to disable limit) /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setFramerateLimit(sfWindow* window, unsigned int limit); //////////////////////////////////////////////////////////// /// \brief Change the joystick threshold /// /// The joystick threshold is the value below which /// no JoyMoved event will be generated. /// /// \param window Window object /// \param threshold New threshold, in the range [0, 100] /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API void sfWindow_setJoystickThreshold(sfWindow* window, float threshold); //////////////////////////////////////////////////////////// /// \brief Get the OS-specific handle of the window /// /// The type of the returned handle is sfWindowHandle, /// which is a typedef to the handle type defined by the OS. /// You shouldn't need to use this function, unless you have /// very specific stuff to implement that SFML doesn't support, /// or implement a temporary workaround until a bug is fixed. /// /// \param window Window object /// /// \return System handle of the window /// //////////////////////////////////////////////////////////// CSFML_WINDOW_API sfWindowHandle sfWindow_getSystemHandle(const sfWindow* window); #endif // SFML_WINDOW_H