From 70963b09af4614d0e5c3c8c5a6cdcb339cf28e4a Mon Sep 17 00:00:00 2001 From: the_fiddler Date: Sat, 7 Mar 2009 07:16:46 +0000 Subject: [PATCH] Use Glx.ChooseFBConfig instead of the deprecated Glx.ChooseVisual, if the first is available. This is necessary for OpenGL 3.0 contexts. --- Source/OpenTK/Platform/X11/X11GraphicsMode.cs | 41 +++++++++++++++++-- 1 file changed, 38 insertions(+), 3 deletions(-) diff --git a/Source/OpenTK/Platform/X11/X11GraphicsMode.cs b/Source/OpenTK/Platform/X11/X11GraphicsMode.cs index 6cc64410..20d172bf 100644 --- a/Source/OpenTK/Platform/X11/X11GraphicsMode.cs +++ b/Source/OpenTK/Platform/X11/X11GraphicsMode.cs @@ -18,16 +18,22 @@ namespace OpenTK.Platform.X11 { class X11GraphicsMode : IGraphicsMode { - internal X11GraphicsMode() + #region Constructors + + public X11GraphicsMode() { } + #endregion + + #region IGraphicsMode Members + public GraphicsMode SelectGraphicsMode(ColorFormat color, int depth, int stencil, int samples, ColorFormat accum, int buffers, bool stereo) { GraphicsMode gfx; // The actual GraphicsMode that will be selected. List visualAttributes = new List(); - IntPtr visual; + IntPtr visual = IntPtr.Zero; Debug.Print("Bits per pixel: {0}", color.BitsPerPixel); @@ -90,7 +96,34 @@ namespace OpenTK.Platform.X11 IntPtr root = Functions.XRootWindow(display, screen); Debug.Print("Display: {0}, Screen: {1}, RootWindow: {2}", display, screen, root); - visual = Glx.ChooseVisual(display, screen, visualAttributes.ToArray()); + try + { + unsafe + { + Debug.Print("Getting FB config."); + int fbcount; + // Note that ChooseFBConfig returns an array of GLXFBConfig opaque structures (i.e. mapped to IntPtrs). + IntPtr* fbconfigs = Glx.ChooseFBConfig(display, screen, visualAttributes.ToArray(), out fbcount); + if (fbcount > 0 && fbconfigs != null) + { + // We want to use the first GLXFBConfig from the fbconfigs array (the first one is the best match). + visual = Glx.GetVisualFromFBConfig(display, *fbconfigs); + Functions.XFree((IntPtr)fbconfigs); + } + } + } + catch (EntryPointNotFoundException) + { + Debug.Print("Functions glXChooseFBConfig not supported."); + } + + // Older drivers don't support glXChooseFBConfig and glXGetVisualFromFBConfig. + // Fall back to the old glXChooseVisual method. + if (visual == IntPtr.Zero) + { + Debug.Print("Falling back to glXChooseVisual."); + visual = Glx.ChooseVisual(display, screen, visualAttributes.ToArray()); + } if (visual == IntPtr.Zero) throw new GraphicsContextException("Requested GraphicsMode not available."); @@ -156,5 +189,7 @@ namespace OpenTK.Platform.X11 return gfx; } + + #endregion } }