2017-06-23 17:35:32 +00:00
|
|
|
|
//
|
2009-09-03 19:01:11 +00:00
|
|
|
|
// The Open Toolkit Library License
|
|
|
|
|
//
|
|
|
|
|
// Copyright (c) 2006 - 2009 the Open Toolkit library.
|
|
|
|
|
//
|
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal
|
2017-06-20 13:52:16 +00:00
|
|
|
|
// in the Software without restriction, including without limitation the rights to
|
2009-09-03 19:01:11 +00:00
|
|
|
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
|
|
|
// the Software, and to permit persons to whom the Software is furnished to do
|
|
|
|
|
// so, subject to the following conditions:
|
|
|
|
|
//
|
|
|
|
|
// The above copyright notice and this permission notice shall be included in all
|
|
|
|
|
// copies or substantial portions of the Software.
|
|
|
|
|
//
|
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
|
|
|
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
|
|
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
|
|
|
|
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
|
|
|
// OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
using System;
|
2011-12-08 00:03:14 +00:00
|
|
|
|
using System.ComponentModel;
|
2015-05-19 19:09:04 +00:00
|
|
|
|
#if !MINIMAL
|
2009-09-03 19:01:11 +00:00
|
|
|
|
using System.Drawing;
|
2015-05-12 20:11:27 +00:00
|
|
|
|
#endif
|
2009-09-03 19:01:11 +00:00
|
|
|
|
using OpenTK.Platform;
|
|
|
|
|
|
|
|
|
|
namespace OpenTK
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Defines the interface for a native window.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
public interface INativeWindow : IDisposable
|
|
|
|
|
{
|
2009-10-18 16:52:07 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the <see cref="System.Drawing.Icon"/> of the window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Icon Icon { get; set; }
|
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the title of the window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
string Title { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets a System.Boolean that indicates whether this window has input focus.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool Focused { get; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a System.Boolean that indicates whether the window is visible.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool Visible { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets a System.Boolean that indicates whether the window has been created and has not been destroyed.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool Exists { get; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the <see cref="OpenTK.Platform.IWindowInfo"/> for this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
IWindowInfo WindowInfo { get; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the <see cref="OpenTK.WindowState"/> for this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
WindowState WindowState { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the <see cref="OpenTK.WindowBorder"/> for this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
WindowBorder WindowBorder { get; set; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a <see cref="System.Drawing.Rectangle"/> structure the contains the external bounds of this window, in screen coordinates.
|
|
|
|
|
/// External bounds include the title bar, borders and drawing area of the window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Rectangle Bounds { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a <see cref="System.Drawing.Point"/> structure that contains the location of this window on the desktop.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Point Location { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a <see cref="System.Drawing.Size"/> structure that contains the external size of this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Size Size { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the horizontal location of this window on the desktop.
|
|
|
|
|
/// </summary>
|
|
|
|
|
int X { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the vertical location of this window on the desktop.
|
|
|
|
|
/// </summary>
|
|
|
|
|
int Y { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the external width of this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
int Width { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the external height of this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
int Height { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a <see cref="System.Drawing.Rectangle"/> structure that contains the internal bounds of this window, in client coordinates.
|
|
|
|
|
/// The internal bounds include the drawing area of the window, but exclude the titlebar and window borders.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Rectangle ClientRectangle { get; set; }
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a <see cref="System.Drawing.Size"/> structure that contains the internal size this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
Size ClientSize { get; set; }
|
|
|
|
|
|
2014-02-18 15:44:28 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the <see cref="OpenTK.MouseCursor"/> for this window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The cursor.</value>
|
|
|
|
|
MouseCursor Cursor { get; set; }
|
|
|
|
|
|
2010-10-18 15:25:25 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets a value, indicating whether the mouse cursor is visible.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool CursorVisible { get; set; }
|
|
|
|
|
|
|
|
|
|
// /// <summary>
|
|
|
|
|
// /// Gets or sets a value, indicating whether the mouse cursor is confined inside the window size.
|
|
|
|
|
// /// </summary>
|
|
|
|
|
// bool CursorGrabbed { get; set; }
|
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
2009-09-04 21:44:39 +00:00
|
|
|
|
/// Closes this window.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
void Close();
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Processes pending window events.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void ProcessEvents();
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Transforms the specified point from screen to client coordinates.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="point">
|
|
|
|
|
/// A <see cref="System.Drawing.Point"/> to transform.
|
|
|
|
|
/// </param>
|
|
|
|
|
/// <returns>
|
|
|
|
|
/// The point transformed to client coordinates.
|
|
|
|
|
/// </returns>
|
|
|
|
|
Point PointToClient(Point point);
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Transforms the specified point from client to screen coordinates.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="point">
|
|
|
|
|
/// A <see cref="System.Drawing.Point"/> to transform.
|
|
|
|
|
/// </param>
|
|
|
|
|
/// <returns>
|
|
|
|
|
/// The point transformed to screen coordinates.
|
|
|
|
|
/// </returns>
|
|
|
|
|
Point PointToScreen(Point point);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs whenever the window is moved.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> Move;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs whenever the window is resized.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> Resize;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs when the window is about to close.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<CancelEventArgs> Closing;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs after the window has closed.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> Closed;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs when the window is disposed.
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> Disposed;
|
|
|
|
|
|
2009-10-18 16:52:07 +00:00
|
|
|
|
/// <summary>
|
2017-06-20 13:52:16 +00:00
|
|
|
|
/// Occurs when the <see cref="Icon"/> property of the window changes.
|
2009-10-18 16:52:07 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> IconChanged;
|
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the <see cref="Title"/> property of the window changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> TitleChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the <see cref="Visible"/> property of the window changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> VisibleChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the <see cref="Focused"/> property of the window changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> FocusedChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the <see cref="WindowBorder"/> property of the window changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> WindowBorderChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the <see cref="WindowState"/> property of the window changes.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> WindowStateChanged;
|
|
|
|
|
|
2010-11-08 21:48:00 +00:00
|
|
|
|
/// <summary>
|
2017-04-27 07:43:21 +00:00
|
|
|
|
/// Occurs whenever a keyboard key is pressed.
|
2010-11-08 21:48:00 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<OpenTK.Input.KeyboardKeyEventArgs> KeyDown;
|
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever a character is typed.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<KeyPressEventArgs> KeyPress;
|
2017-06-20 13:52:16 +00:00
|
|
|
|
|
2010-11-08 21:48:00 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever a keyboard key is released.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<OpenTK.Input.KeyboardKeyEventArgs> KeyUp;
|
2009-10-27 23:57:44 +00:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever the mouse cursor leaves the window <see cref="Bounds"/>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> MouseLeave;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever the mouse cursor enters the window <see cref="Bounds"/>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<EventArgs> MouseEnter;
|
|
|
|
|
|
2014-05-02 12:18:52 +00:00
|
|
|
|
/// <summary>
|
2014-07-21 13:03:24 +00:00
|
|
|
|
/// Occurs whenever a <see cref="OpenTK.Input.MouseButton"/> is clicked.
|
2014-05-02 12:18:52 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<Input.MouseButtonEventArgs> MouseDown;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2014-07-21 13:03:24 +00:00
|
|
|
|
/// Occurs whenever a <see cref="OpenTK.Input.MouseButton"/> is released.
|
2014-05-02 12:18:52 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<Input.MouseButtonEventArgs> MouseUp;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever the mouse cursor is moved;
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<Input.MouseMoveEventArgs> MouseMove;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever a mouse wheel is moved;
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<Input.MouseWheelEventArgs> MouseWheel;
|
|
|
|
|
|
2009-09-03 19:01:11 +00:00
|
|
|
|
//event EventHandler<MouseEventArgs> MouseClick;
|
|
|
|
|
//event EventHandler<MouseEventArgs> MouseDoubleClick;
|
|
|
|
|
|
2017-06-18 19:37:16 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs whenever file dropped on window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<OpenTK.Input.FileDropEventArgs> FileDrop;
|
2009-09-03 19:01:11 +00:00
|
|
|
|
}
|
|
|
|
|
}
|