#region --- License ---
/* Copyright (c) 2006, 2007 Stefanos Apostolopoulos
* See license.txt for license info
*/
#endregion
#region --- Using Directives ---
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Diagnostics;
using OpenTK.Platform;
#endregion
namespace OpenTK
{
// TODO: Document the GLControl class.
///
/// Defines a UserControl with opengl rendering capabilities.
///
public partial class GLControl : UserControl, IGLControl
{
#region --- Private Fields ---
private IGLControl glControl;
#endregion
#region --- Contructors ---
///
/// Constructs a new GLControl.
///
public GLControl()
:this(new DisplayMode())
{
}
///
/// Constructs a new GLControl, with the specified DisplayMode.
///
/// The DisplayMode of the control.
public GLControl(DisplayMode mode)
{
InitializeComponent();
this.Visible = false;
this.Fullscreen = mode.Fullscreen;
this.SetStyle(ControlStyles.UserPaint, true);
this.SetStyle(ControlStyles.AllPaintingInWmPaint, true);
//this.SetStyle(ControlStyles.OptimizedDoubleBuffer, true);
this.Disposed += new EventHandler(GLControl_Disposed);
//Debug.Print("Creating GLControl.");
//this.CreateControl();
}
void GLControl_Disposed(object sender, EventArgs e)
{
//glControl.Context.Dispose();
//Application.ExitThread();
}
#endregion
/*
CreateParams @params;
protected override CreateParams CreateParams
{
get
{
if (@params == null)
{
@params = base.CreateParams;
//@params.ClassStyle = (int)
// (OpenTK.Platform.Windows.API.WindowClassStyle.OwnDC |
// OpenTK.Platform.Windows.API.WindowClassStyle.HRedraw |
// OpenTK.Platform.Windows.API.WindowClassStyle.VRedraw);
//@params.Style = (int)
// (OpenTK.Platform.Windows.API.WindowStyle.ClipChildren);
// OpenTK.Platform.Windows.API.WindowStyle.ClipSiblings);
//@params.ExStyle = OpenTK.Platform.Windows.API.ExtendedWindowStyle.
}
return @params;
}
}
*/
#region --- Public Methods ---
///
/// Forces the creation of the opengl rendering context.
///
public void CreateContext()
{
if (glControl != null)
{
throw new ApplicationException("Attempted to create GLControl more than once.");
}
try
{
switch (Environment.OSVersion.Platform)
{
case PlatformID.Win32NT:
case PlatformID.Win32Windows:
glControl = new OpenTK.Platform.Windows.WinGLControl(this, new DisplayMode(Width, Height));
break;
case PlatformID.Unix:
case (PlatformID)128: // some older versions of Mono reported 128.
glControl = new OpenTK.Platform.X11.X11GLControl(this);
break;
default:
throw new PlatformNotSupportedException("Your operating system is not currently supported. We are sorry for the inconvenience.");
}
}
catch (Exception e)
{
Debug.Print("Could not create GLControl, error: {0}", e.ToString());
throw;
}
this.Visible = true;
OpenTK.OpenGL.GL.LoadAll();
this.OnResize(EventArgs.Empty);
}
///
/// Swaps the front and back buffers, and presents the rendered scene to the screen.
///
public void SwapBuffers()
{
Context.SwapBuffers();
}
///
/// Makes the underlying GLContext of this GLControl current. All OpenGL commands issued
/// from this point are interpreted by this GLContext.
///
public void MakeCurrent()
{
Context.MakeCurrent();
}
#endregion
#region --- Public Properties ---
///
/// Gets the AspectRatio of the control this GLContext object
/// renders to. This is usually used in a call to Glu.Perspective.
///
public double AspectRatio
{
get
{
return this.Width / (double)this.Height;
}
}
///
/// Gets or sets the display mode of the control.
///
public bool Fullscreen
{
get
{
return false;
//throw new NotImplementedException();
}
set
{
//throw new NotImplementedException();
}
}
#endregion
#region --- IGLControl Members ---
#region public bool IsIdle
///
/// Gets the idle status of the control.
///
public bool IsIdle
{
get
{
if (glControl == null)
this.CreateContext();
return glControl.IsIdle;
}
}
#endregion
#region public IGLContext Context
///
/// Gets the opengl context associated with this control.
///
public IGLContext Context
{
get
{
if (glControl == null)
this.CreateContext();
return glControl.Context;
}
}
#endregion
#region DisplayMode changes
///
/// Selects the fullscreen DisplayMode closest to the DisplayMode requested.
///
///
/// The fullscreen DisplayMode to match, or null to get the current screen DisplayMode.
///
/// The DisplayMode closest to the requested one, or null if no DisplayModes are available.
///
/// SetDisplayMode
///
public DisplayMode SelectDisplayMode(DisplayMode mode)
{
throw new NotImplementedException();
//return glWindow.SelectDisplayMode(mode);
}
///
/// Selects the fullscreen DisplayMode closest to the DisplayMode requested, accoriding to the specified
/// parameters.
///
///
/// The fullscreen DisplayMode to match, or null to get the current screen DisplayMode.
///
///
/// The DisplayModeMatchOptions flags that indicate how to search for the requested DisplayMode.
///
///
/// The DisplayMode closest to the requested one, or null if no DisplayModes are available or
/// DisplayModeMatchOptions.ExactMatch was passed.
///
///
/// SetDisplayMode
///
public DisplayMode SelectDisplayMode(DisplayMode mode, DisplayModeMatchOptions options)
{
throw new NotImplementedException();
//return glWindow.SelectDisplayMode(mode, options);
}
///
/// Sets the requested DisplayMode.
///
///
/// The fulscreen DisplayMode to set. Passing null will return the application to windowed
/// mode.
///
///
/// Use SelectDisplayMode to select one of the available fullscreen modes.
///
/// If the mode requested is not available, this function will throw a
/// DisplayModeNotAvailable exception.
///
///
/// Pass null to return to windowed mode. The previous desktop DisplayMode will be automatically reset by this
/// function. This function cannot be used to permanently change the user's desktop DisplayMode.
///
/// SelectDisplayMode
/// DisplayModeNotAvailable exception
///
public void SetDisplayMode(DisplayMode mode)
{
throw new NotImplementedException();
//glWindow.SetDisplayMode(mode);
}
#endregion
#endregion
}
}