Added VSync property to IGLContext.

This commit is contained in:
the_fiddler 2007-09-29 15:24:55 +00:00
parent 29b6f1660e
commit 4e421d30fb
5 changed files with 47 additions and 0 deletions

View file

@ -153,6 +153,15 @@ namespace OpenTK
return implementation.GetDisplayModes(); return implementation.GetDisplayModes();
} }
/// <summary>
/// Gets or sets a value indicating whether VSync is enabled.
/// </summary>
public bool VSync
{
get { return implementation.VSync; }
set { implementation.VSync = value; }
}
#endregion #endregion
#region IDisposable Members #region IDisposable Members

View file

@ -34,6 +34,8 @@ namespace OpenTK.Platform
public IntPtr GetAddress(string function) { return IntPtr.Zero; } public IntPtr GetAddress(string function) { return IntPtr.Zero; }
public IEnumerable<DisplayMode> GetDisplayModes() { return null; } public IEnumerable<DisplayMode> GetDisplayModes() { return null; }
public bool VSync { get { return false; } set { } }
#endregion #endregion
#region --- IDisposable Members --- #region --- IDisposable Members ---

View file

@ -87,5 +87,10 @@ namespace OpenTK.Platform
/// </summary> /// </summary>
/// <returns>An IEnumerable containing all supported display modes.</returns> /// <returns>An IEnumerable containing all supported display modes.</returns>
IEnumerable<DisplayMode> GetDisplayModes(); IEnumerable<DisplayMode> GetDisplayModes();
/// <summary>
/// Gets or sets a value indicating whether VSyncing is enabled.
/// </summary>
bool VSync { get; set; }
} }
} }

View file

@ -32,6 +32,7 @@ namespace OpenTK.Platform.Windows
private WindowInfo windowInfo = new WindowInfo(); private WindowInfo windowInfo = new WindowInfo();
private DisplayMode mode; private DisplayMode mode;
private bool vsync_supported;
private bool disposed; private bool disposed;
@ -232,6 +233,11 @@ namespace OpenTK.Platform.Windows
Wgl.Imports.MakeCurrent(deviceContext, renderContext); Wgl.Imports.MakeCurrent(deviceContext, renderContext);
Wgl.LoadAll(); Wgl.LoadAll();
vsync_supported =
(Wgl.ARB.SupportsExtension(this.deviceContext, "WGL_EXT_swap_control") ||
Wgl.EXT.SupportsExtension(this.deviceContext, "WGL_EXT_swap_control")) &&
Wgl.Load("wglGetSwapIntervalEXT") && Wgl.Load("wglSwapIntervalEXT");
if (source != null) if (source != null)
{ {
Debug.Print("Sharing state with context {0}", (source as WinGLContext).Context); Debug.Print("Sharing state with context {0}", (source as WinGLContext).Context);
@ -322,6 +328,19 @@ namespace OpenTK.Platform.Windows
#endregion #endregion
public bool VSync
{
get
{
//return vsync != 0;
return Wgl.EXT.GetSwapInterval() != 0;
}
set
{
Wgl.EXT.SwapInterval(value ? 1 : 0);
}
}
#endregion #endregion
#region --- IDisposable Members --- #region --- IDisposable Members ---

View file

@ -267,6 +267,18 @@ namespace OpenTK.Platform.X11
throw new Exception("The method or operation is not implemented."); throw new Exception("The method or operation is not implemented.");
} }
public bool VSync
{
get
{
return false;
}
set
{
}
}
#endregion #endregion
#region --- IDisposable Members --- #region --- IDisposable Members ---