Made GraphicsMode query non-eager. The GraphicsMode will only be queried on first access of its Index property, for example when creating an X11 window or a new GraphicsContext.

This commit is contained in:
the_fiddler 2009-08-15 16:03:54 +00:00
parent 0feae9b6e3
commit b503c41bf1

View file

@ -19,7 +19,7 @@ namespace OpenTK.Graphics
ColorFormat color_format, accumulator_format; ColorFormat color_format, accumulator_format;
int depth, stencil, buffers, samples; int depth, stencil, buffers, samples;
bool stereo; bool stereo;
IntPtr index; // The id of the pixel format or visual. IntPtr? index; // The id of the pixel format or visual.
static GraphicsMode defaultMode; static GraphicsMode defaultMode;
static IGraphicsMode implementation; static IGraphicsMode implementation;
@ -53,36 +53,14 @@ namespace OpenTK.Graphics
if (buffers <= 0) throw new ArgumentOutOfRangeException("buffers", "Must be greater than zero."); if (buffers <= 0) throw new ArgumentOutOfRangeException("buffers", "Must be greater than zero.");
if (samples < 0) throw new ArgumentOutOfRangeException("samples", "Must be greater than, or equal to zero."); if (samples < 0) throw new ArgumentOutOfRangeException("samples", "Must be greater than, or equal to zero.");
// This method will search for the closest this.Index = index;
this.ColorFormat = color;
if (index == IntPtr.Zero) this.Depth = depth;
{ this.Stencil = stencil;
GraphicsMode mode; this.Samples = samples;
lock (mode_selection_lock) this.AccumulatorFormat = accum;
{ this.Buffers = buffers;
mode = implementation.SelectGraphicsMode(color, depth, stencil, samples, accum, buffers, stereo); this.Stereo = stereo;
}
this.Index = mode.Index;
this.ColorFormat = mode.ColorFormat;
this.Depth = mode.Depth;
this.Stencil = mode.Stencil;
this.Samples = mode.Samples;
this.AccumulatorFormat = mode.AccumulatorFormat;
this.Buffers = mode.Buffers;
this.Stereo = mode.Stereo;
}
else
{
this.Index = index;
this.ColorFormat = color;
this.Depth = depth;
this.Stencil = stencil;
this.Samples = samples;
this.AccumulatorFormat = accum;
this.Buffers = buffers;
this.Stereo = stereo;
}
} }
#endregion #endregion
@ -310,8 +288,29 @@ namespace OpenTK.Graphics
#region internal IntPtr Index #region internal IntPtr Index
internal IntPtr Index internal IntPtr Index
{ {
get { return index; } get
{
if (index == null)
{
GraphicsMode mode;
lock (mode_selection_lock)
{
mode = implementation.SelectGraphicsMode(ColorFormat, Depth, Stencil, Samples, AccumulatorFormat, Buffers, Stereo);
}
Index = mode.Index;
ColorFormat = mode.ColorFormat;
Depth = mode.Depth;
Stencil = mode.Stencil;
Samples = mode.Samples;
AccumulatorFormat = mode.AccumulatorFormat;
Buffers = mode.Buffers;
Stereo = mode.Stereo;
}
return index.Value;
}
set { index = value; } set { index = value; }
} }