mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-09 09:25:30 +00:00
Merge pull request #563 from Nihlus/cleanup-3-auto-property
Transform compatible properties to auto-properties
This commit is contained in:
commit
9ea1f55139
|
@ -17,14 +17,8 @@ namespace Bind.Structures
|
|||
/// </summary>
|
||||
class Constant : IComparable<Constant>
|
||||
{
|
||||
string original_name;
|
||||
|
||||
// Gets the name prior to translation.
|
||||
public string OriginalName
|
||||
{
|
||||
get { return original_name; }
|
||||
private set { original_name = value; }
|
||||
}
|
||||
public string OriginalName { get; private set; }
|
||||
|
||||
string _name;
|
||||
|
||||
|
@ -67,20 +61,11 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
string _reference;
|
||||
|
||||
/// <summary>
|
||||
/// Gets or sets a string indicating the OpenGL enum reference by this constant.
|
||||
/// Can be null.
|
||||
/// </summary>
|
||||
public string Reference
|
||||
{
|
||||
get { return _reference; }
|
||||
set
|
||||
{
|
||||
_reference = value;
|
||||
}
|
||||
}
|
||||
public string Reference { get; set; }
|
||||
|
||||
public bool Unchecked
|
||||
{
|
||||
|
|
|
@ -82,13 +82,7 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
private string _category;
|
||||
|
||||
public string Category
|
||||
{
|
||||
get { return _category; }
|
||||
set { _category = value; }
|
||||
}
|
||||
public string Category { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value that indicates whether this function needs to be wrapped with a Marshaling function.
|
||||
|
@ -141,18 +135,10 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
Type _return_type = new Type();
|
||||
/// <summary>
|
||||
/// Gets or sets the return value of the opengl function.
|
||||
/// </summary>
|
||||
public Type ReturnType
|
||||
{
|
||||
get { return _return_type; }
|
||||
set
|
||||
{
|
||||
_return_type = value;
|
||||
}
|
||||
}
|
||||
public Type ReturnType { get; set; } = new Type();
|
||||
|
||||
string _name;
|
||||
/// <summary>
|
||||
|
@ -170,24 +156,12 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
ParameterCollection _parameters;
|
||||
|
||||
public ParameterCollection Parameters
|
||||
{
|
||||
get { return _parameters; }
|
||||
set { _parameters = value; }
|
||||
}
|
||||
|
||||
string _version;
|
||||
public ParameterCollection Parameters { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Defines the opengl version that introduced this function.
|
||||
/// </summary>
|
||||
public string Version
|
||||
{
|
||||
get { return _version; }
|
||||
set { _version = value; }
|
||||
}
|
||||
public string Version { get; set; }
|
||||
|
||||
public string Extension
|
||||
{
|
||||
|
|
|
@ -12,8 +12,6 @@ namespace Bind.Structures
|
|||
{
|
||||
class Function : Delegate, IEquatable<Function>, IComparable<Function>
|
||||
{
|
||||
Delegate wrapped_delegate;
|
||||
|
||||
public Function(Delegate d)
|
||||
: base(d)
|
||||
{
|
||||
|
@ -34,11 +32,7 @@ namespace Bind.Structures
|
|||
Body.AddRange(f.Body);
|
||||
}
|
||||
|
||||
public Delegate WrappedDelegate
|
||||
{
|
||||
get { return wrapped_delegate; }
|
||||
set { wrapped_delegate = value; }
|
||||
}
|
||||
public Delegate WrappedDelegate { get; set; }
|
||||
|
||||
public void TurnVoidPointersToIntPtr()
|
||||
{
|
||||
|
@ -60,13 +54,7 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
FunctionBody _body;
|
||||
|
||||
public FunctionBody Body
|
||||
{
|
||||
get { return _body; }
|
||||
set { _body = value; }
|
||||
}
|
||||
public FunctionBody Body { get; set; }
|
||||
|
||||
public string TrimmedName { get; set; }
|
||||
|
||||
|
|
|
@ -134,12 +134,7 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
bool generic;
|
||||
public bool Generic
|
||||
{
|
||||
get { return generic; }
|
||||
set { generic = value; }
|
||||
}
|
||||
public bool Generic { get; set; }
|
||||
|
||||
// Returns true if this parameter differs only on reference compared to another parameter, i.e:
|
||||
// returns true for 'int' & 'ref int'
|
||||
|
@ -155,12 +150,7 @@ namespace Bind.Structures
|
|||
other.Reference && !(Reference || Array > 0 || Pointer != 0));
|
||||
}
|
||||
|
||||
string computeSize;
|
||||
public string ComputeSize
|
||||
{
|
||||
get { return computeSize; }
|
||||
set { computeSize = value; }
|
||||
}
|
||||
public string ComputeSize { get; set; }
|
||||
|
||||
// Returns the FlowDirection that matches the specified string
|
||||
// ("out" or "in", otherwise undefined).
|
||||
|
|
|
@ -13,7 +13,6 @@ namespace Bind.Structures
|
|||
class Type : IComparable<Type>, IEquatable<Type>
|
||||
{
|
||||
string current_qualifier = String.Empty;
|
||||
string previous_qualifier = String.Empty;
|
||||
|
||||
public Type()
|
||||
{
|
||||
|
@ -41,11 +40,7 @@ namespace Bind.Structures
|
|||
set { PreviousQualifier = CurrentQualifier; current_qualifier = value; }
|
||||
}
|
||||
|
||||
string PreviousQualifier
|
||||
{
|
||||
get { return previous_qualifier; }
|
||||
set { previous_qualifier = value; }
|
||||
}
|
||||
private string PreviousQualifier { get; set; } = String.Empty;
|
||||
|
||||
public string QualifiedType
|
||||
{
|
||||
|
@ -103,21 +98,9 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
private string _previous_type;
|
||||
public string PreviousType { get; private set; }
|
||||
|
||||
public string PreviousType
|
||||
{
|
||||
get { return _previous_type; }
|
||||
private set { _previous_type = value; }
|
||||
}
|
||||
|
||||
bool reference;
|
||||
|
||||
public bool Reference
|
||||
{
|
||||
get { return reference; }
|
||||
set { reference = value; }
|
||||
}
|
||||
public bool Reference { get; set; }
|
||||
|
||||
int array;
|
||||
|
||||
|
@ -209,13 +192,7 @@ namespace Bind.Structures
|
|||
}
|
||||
}
|
||||
|
||||
private WrapperTypes _wrapper_type = WrapperTypes.None;
|
||||
|
||||
public WrapperTypes WrapperType
|
||||
{
|
||||
get { return _wrapper_type; }
|
||||
set { _wrapper_type = value; }
|
||||
}
|
||||
public WrapperTypes WrapperType { get; set; } = WrapperTypes.None;
|
||||
|
||||
static readonly string[] PointerLevels =
|
||||
{
|
||||
|
|
|
@ -228,40 +228,21 @@ namespace Mono.Options
|
|||
}
|
||||
|
||||
public class OptionContext {
|
||||
private Option option;
|
||||
private string name;
|
||||
private int index;
|
||||
private OptionSet set;
|
||||
private OptionValueCollection c;
|
||||
|
||||
public OptionContext (OptionSet set)
|
||||
{
|
||||
this.set = set;
|
||||
this.c = new OptionValueCollection (this);
|
||||
this.OptionSet = set;
|
||||
this.OptionValues = new OptionValueCollection (this);
|
||||
}
|
||||
|
||||
public Option Option {
|
||||
get {return option;}
|
||||
set {option = value;}
|
||||
}
|
||||
public Option Option { get; set; }
|
||||
|
||||
public string OptionName {
|
||||
get {return name;}
|
||||
set {name = value;}
|
||||
}
|
||||
public string OptionName { get; set; }
|
||||
|
||||
public int OptionIndex {
|
||||
get {return index;}
|
||||
set {index = value;}
|
||||
}
|
||||
public int OptionIndex { get; set; }
|
||||
|
||||
public OptionSet OptionSet {
|
||||
get {return set;}
|
||||
}
|
||||
public OptionSet OptionSet { get; }
|
||||
|
||||
public OptionValueCollection OptionValues {
|
||||
get {return c;}
|
||||
}
|
||||
public OptionValueCollection OptionValues { get; }
|
||||
}
|
||||
|
||||
public enum OptionValueType {
|
||||
|
@ -271,12 +252,6 @@ namespace Mono.Options
|
|||
}
|
||||
|
||||
public abstract class Option {
|
||||
string prototype, description;
|
||||
string[] names;
|
||||
OptionValueType type;
|
||||
int count;
|
||||
string[] separators;
|
||||
|
||||
protected Option (string prototype, string description)
|
||||
: this (prototype, description, 1)
|
||||
{
|
||||
|
@ -291,44 +266,44 @@ namespace Mono.Options
|
|||
if (maxValueCount < 0)
|
||||
throw new ArgumentOutOfRangeException ("maxValueCount");
|
||||
|
||||
this.prototype = prototype;
|
||||
this.names = prototype.Split ('|');
|
||||
this.description = description;
|
||||
this.count = maxValueCount;
|
||||
this.type = ParsePrototype ();
|
||||
this.Prototype = prototype;
|
||||
this.Names = prototype.Split ('|');
|
||||
this.Description = description;
|
||||
this.MaxValueCount = maxValueCount;
|
||||
this.OptionValueType = ParsePrototype ();
|
||||
|
||||
if (this.count == 0 && type != OptionValueType.None)
|
||||
if (this.MaxValueCount == 0 && OptionValueType != OptionValueType.None)
|
||||
throw new ArgumentException (
|
||||
"Cannot provide maxValueCount of 0 for OptionValueType.Required or " +
|
||||
"OptionValueType.Optional.",
|
||||
"maxValueCount");
|
||||
if (this.type == OptionValueType.None && maxValueCount > 1)
|
||||
if (this.OptionValueType == OptionValueType.None && maxValueCount > 1)
|
||||
throw new ArgumentException (
|
||||
string.Format ("Cannot provide maxValueCount of {0} for OptionValueType.None.", maxValueCount),
|
||||
"maxValueCount");
|
||||
if (Array.IndexOf (names, "<>") >= 0 &&
|
||||
((names.Length == 1 && this.type != OptionValueType.None) ||
|
||||
(names.Length > 1 && this.MaxValueCount > 1)))
|
||||
if (Array.IndexOf (Names, "<>") >= 0 &&
|
||||
((Names.Length == 1 && this.OptionValueType != OptionValueType.None) ||
|
||||
(Names.Length > 1 && this.MaxValueCount > 1)))
|
||||
throw new ArgumentException (
|
||||
"The default option handler '<>' cannot require values.",
|
||||
"prototype");
|
||||
}
|
||||
|
||||
public string Prototype {get {return prototype;}}
|
||||
public string Description {get {return description;}}
|
||||
public OptionValueType OptionValueType {get {return type;}}
|
||||
public int MaxValueCount {get {return count;}}
|
||||
public string Prototype { get; }
|
||||
public string Description { get; }
|
||||
public OptionValueType OptionValueType { get; }
|
||||
public int MaxValueCount { get; }
|
||||
|
||||
public string[] GetNames ()
|
||||
{
|
||||
return (string[]) names.Clone ();
|
||||
return (string[]) Names.Clone ();
|
||||
}
|
||||
|
||||
public string[] GetValueSeparators ()
|
||||
{
|
||||
if (separators == null)
|
||||
if (ValueSeparators == null)
|
||||
return new string [0];
|
||||
return (string[]) separators.Clone ();
|
||||
return (string[]) ValueSeparators.Clone ();
|
||||
}
|
||||
|
||||
protected static T Parse<T> (string value, OptionContext c)
|
||||
|
@ -354,8 +329,8 @@ namespace Mono.Options
|
|||
return t;
|
||||
}
|
||||
|
||||
internal string[] Names {get {return names;}}
|
||||
internal string[] ValueSeparators {get {return separators;}}
|
||||
internal string[] Names { get; }
|
||||
internal string[] ValueSeparators { get; private set; }
|
||||
|
||||
static readonly char[] NameTerminator = new char[]{'=', ':'};
|
||||
|
||||
|
@ -363,15 +338,15 @@ namespace Mono.Options
|
|||
{
|
||||
char type = '\0';
|
||||
List<string> seps = new List<string> ();
|
||||
for (int i = 0; i < names.Length; ++i) {
|
||||
string name = names [i];
|
||||
for (int i = 0; i < Names.Length; ++i) {
|
||||
string name = Names [i];
|
||||
if (name.Length == 0)
|
||||
throw new ArgumentException ("Empty option names are not supported.", "prototype");
|
||||
|
||||
int end = name.IndexOfAny (NameTerminator);
|
||||
if (end == -1)
|
||||
continue;
|
||||
names [i] = name.Substring (0, end);
|
||||
Names [i] = name.Substring (0, end);
|
||||
if (type == '\0' || type == name [end])
|
||||
type = name [end];
|
||||
else
|
||||
|
@ -384,17 +359,17 @@ namespace Mono.Options
|
|||
if (type == '\0')
|
||||
return OptionValueType.None;
|
||||
|
||||
if (count <= 1 && seps.Count != 0)
|
||||
if (MaxValueCount <= 1 && seps.Count != 0)
|
||||
throw new ArgumentException (
|
||||
string.Format ("Cannot provide key/value separators for Options taking {0} value(s).", count),
|
||||
string.Format ("Cannot provide key/value separators for Options taking {0} value(s).", MaxValueCount),
|
||||
"prototype");
|
||||
if (count > 1) {
|
||||
if (MaxValueCount > 1) {
|
||||
if (seps.Count == 0)
|
||||
this.separators = new string[]{":", "="};
|
||||
this.ValueSeparators = new string[]{":", "="};
|
||||
else if (seps.Count == 1 && seps [0].Length == 0)
|
||||
this.separators = null;
|
||||
this.ValueSeparators = null;
|
||||
else
|
||||
this.separators = seps.ToArray ();
|
||||
this.ValueSeparators = seps.ToArray ();
|
||||
}
|
||||
|
||||
return type == '=' ? OptionValueType.Required : OptionValueType.Optional;
|
||||
|
@ -450,8 +425,6 @@ namespace Mono.Options
|
|||
|
||||
[Serializable]
|
||||
public class OptionException : Exception {
|
||||
private string option;
|
||||
|
||||
public OptionException ()
|
||||
{
|
||||
}
|
||||
|
@ -459,30 +432,28 @@ namespace Mono.Options
|
|||
public OptionException (string message, string optionName)
|
||||
: base (message)
|
||||
{
|
||||
this.option = optionName;
|
||||
this.OptionName = optionName;
|
||||
}
|
||||
|
||||
public OptionException (string message, string optionName, Exception innerException)
|
||||
: base (message, innerException)
|
||||
{
|
||||
this.option = optionName;
|
||||
this.OptionName = optionName;
|
||||
}
|
||||
|
||||
protected OptionException (SerializationInfo info, StreamingContext context)
|
||||
: base (info, context)
|
||||
{
|
||||
this.option = info.GetString ("OptionName");
|
||||
this.OptionName = info.GetString ("OptionName");
|
||||
}
|
||||
|
||||
public string OptionName {
|
||||
get {return this.option;}
|
||||
}
|
||||
public string OptionName { get; }
|
||||
|
||||
[SecurityPermission (SecurityAction.LinkDemand, SerializationFormatter = true)]
|
||||
public override void GetObjectData (SerializationInfo info, StreamingContext context)
|
||||
{
|
||||
base.GetObjectData (info, context);
|
||||
info.AddValue ("OptionName", option);
|
||||
info.AddValue ("OptionName", OptionName);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -497,14 +468,10 @@ namespace Mono.Options
|
|||
|
||||
public OptionSet (Converter<string, string> localizer)
|
||||
{
|
||||
this.localizer = localizer;
|
||||
this.MessageLocalizer = localizer;
|
||||
}
|
||||
|
||||
Converter<string, string> localizer;
|
||||
|
||||
public Converter<string, string> MessageLocalizer {
|
||||
get {return localizer;}
|
||||
}
|
||||
public Converter<string, string> MessageLocalizer { get; }
|
||||
|
||||
protected override string GetKeyForItem (Option item)
|
||||
{
|
||||
|
@ -812,7 +779,7 @@ namespace Mono.Options
|
|||
c.Option.OptionValueType == OptionValueType.Optional)
|
||||
c.Option.Invoke (c);
|
||||
else if (c.OptionValues.Count > c.Option.MaxValueCount) {
|
||||
throw new OptionException (localizer (string.Format (
|
||||
throw new OptionException (MessageLocalizer (string.Format (
|
||||
"Error: Found {0} option values when expecting {1}.",
|
||||
c.OptionValues.Count, c.Option.MaxValueCount)),
|
||||
c.OptionName);
|
||||
|
@ -847,7 +814,7 @@ namespace Mono.Options
|
|||
if (!Contains (rn)) {
|
||||
if (i == 0)
|
||||
return false;
|
||||
throw new OptionException (string.Format (localizer (
|
||||
throw new OptionException (string.Format (MessageLocalizer (
|
||||
"Cannot bundle unregistered option '{0}'."), opt), opt);
|
||||
}
|
||||
p = this [rn];
|
||||
|
@ -896,7 +863,7 @@ namespace Mono.Options
|
|||
|
||||
bool indent = false;
|
||||
string prefix = new string (' ', OptionWidth+2);
|
||||
foreach (string line in GetLines (localizer (GetDescription (p.Description)))) {
|
||||
foreach (string line in GetLines (MessageLocalizer (GetDescription (p.Description)))) {
|
||||
if (indent)
|
||||
o.Write (prefix);
|
||||
o.WriteLine (line);
|
||||
|
@ -932,17 +899,17 @@ namespace Mono.Options
|
|||
if (p.OptionValueType == OptionValueType.Optional ||
|
||||
p.OptionValueType == OptionValueType.Required) {
|
||||
if (p.OptionValueType == OptionValueType.Optional) {
|
||||
Write (o, ref written, localizer ("["));
|
||||
Write (o, ref written, MessageLocalizer ("["));
|
||||
}
|
||||
Write (o, ref written, localizer ("=" + GetArgumentName (0, p.MaxValueCount, p.Description)));
|
||||
Write (o, ref written, MessageLocalizer ("=" + GetArgumentName (0, p.MaxValueCount, p.Description)));
|
||||
string sep = p.ValueSeparators != null && p.ValueSeparators.Length > 0
|
||||
? p.ValueSeparators [0]
|
||||
: " ";
|
||||
for (int c = 1; c < p.MaxValueCount; ++c) {
|
||||
Write (o, ref written, localizer (sep + GetArgumentName (c, p.MaxValueCount, p.Description)));
|
||||
Write (o, ref written, MessageLocalizer (sep + GetArgumentName (c, p.MaxValueCount, p.Description)));
|
||||
}
|
||||
if (p.OptionValueType == OptionValueType.Optional) {
|
||||
Write (o, ref written, localizer ("]"));
|
||||
Write (o, ref written, MessageLocalizer ("]"));
|
||||
}
|
||||
}
|
||||
return true;
|
||||
|
|
|
@ -45,12 +45,8 @@ namespace OpenTK.Platform.MacOS
|
|||
/// </summary>
|
||||
class AglContext : IGraphicsContext, IGraphicsContextInternal
|
||||
{
|
||||
ContextHandle Handle;
|
||||
GraphicsMode mode;
|
||||
IWindowInfo carbonWindow;
|
||||
IGraphicsContext dummyContext; // for extension loading
|
||||
bool disposed;
|
||||
bool error_checking;
|
||||
|
||||
readonly GetInt XOffset;
|
||||
readonly GetInt YOffset;
|
||||
|
@ -69,7 +65,7 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
if (shareContext is AglContext)
|
||||
{
|
||||
shareContextRef = ((AglContext)shareContext).Handle.Handle;
|
||||
shareContextRef = ((AglContext)shareContext).Context.Handle;
|
||||
}
|
||||
else if (shareContext is GraphicsContext)
|
||||
{
|
||||
|
@ -116,7 +112,7 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
Debug.Print("Creating AGL context. Sharing with {0}", shareContextRef);
|
||||
// create the context and share it with the share reference.
|
||||
Handle = new ContextHandle(Agl.aglCreateContext(pixelformat, shareContextRef));
|
||||
Context = new ContextHandle(Agl.aglCreateContext(pixelformat, shareContextRef));
|
||||
MyAGLReportError("aglCreateContext");
|
||||
|
||||
// Free the pixel format from memory.
|
||||
|
@ -128,9 +124,9 @@ namespace OpenTK.Platform.MacOS
|
|||
Update(carbonWindow);
|
||||
|
||||
MakeCurrent(carbonWindow);
|
||||
Debug.Print("context: {0}", Handle.Handle);
|
||||
Debug.Print("context: {0}", Context.Handle);
|
||||
|
||||
dummyContext = new GraphicsContext(Handle,
|
||||
dummyContext = new GraphicsContext(Context,
|
||||
GetAddress,
|
||||
delegate()
|
||||
{
|
||||
|
@ -157,10 +153,10 @@ namespace OpenTK.Platform.MacOS
|
|||
glrect[2] = rect.Width;
|
||||
glrect[3] = rect.Height;
|
||||
|
||||
Agl.aglSetInteger(Handle.Handle, Agl.ParameterNames.AGL_BUFFER_RECT, glrect);
|
||||
Agl.aglSetInteger(Context.Handle, Agl.ParameterNames.AGL_BUFFER_RECT, glrect);
|
||||
MyAGLReportError("aglSetInteger");
|
||||
|
||||
Agl.aglEnable(Handle.Handle, Agl.ParameterNames.AGL_BUFFER_RECT);
|
||||
Agl.aglEnable(Context.Handle, Agl.ParameterNames.AGL_BUFFER_RECT);
|
||||
MyAGLReportError("aglEnable");
|
||||
}
|
||||
|
||||
|
@ -168,7 +164,7 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
IntPtr windowPort = GetWindowPortForWindowInfo(carbonWindow);
|
||||
//Debug.Print("Setting drawable for context {0} to window port: {1}", Handle.Handle, windowPort);
|
||||
Agl.aglSetDrawable(Handle.Handle, windowPort);
|
||||
Agl.aglSetDrawable(Context.Handle, windowPort);
|
||||
MyAGLReportError("aglSetDrawable");
|
||||
}
|
||||
|
||||
|
@ -186,7 +182,7 @@ namespace OpenTK.Platform.MacOS
|
|||
SetDrawable(window);
|
||||
SetBufferRect(window);
|
||||
|
||||
Agl.aglUpdateContext(Handle.Handle);
|
||||
Agl.aglUpdateContext(Context.Handle);
|
||||
}
|
||||
|
||||
void MyAGLReportError(string function)
|
||||
|
@ -212,19 +208,19 @@ namespace OpenTK.Platform.MacOS
|
|||
Update(carbonWindow);
|
||||
}
|
||||
|
||||
Agl.aglSwapBuffers(Handle.Handle);
|
||||
Agl.aglSwapBuffers(Context.Handle);
|
||||
MyAGLReportError("aglSwapBuffers");
|
||||
}
|
||||
|
||||
public void MakeCurrent(IWindowInfo window)
|
||||
{
|
||||
if (Agl.aglSetCurrentContext(Handle.Handle) == false)
|
||||
if (Agl.aglSetCurrentContext(Context.Handle) == false)
|
||||
MyAGLReportError("aglSetCurrentContext");
|
||||
}
|
||||
|
||||
public bool IsCurrent
|
||||
{
|
||||
get { return (Handle.Handle == Agl.aglGetCurrentContext()); }
|
||||
get { return (Context.Handle == Agl.aglGetCurrentContext()); }
|
||||
}
|
||||
|
||||
public int SwapInterval
|
||||
|
@ -232,7 +228,7 @@ namespace OpenTK.Platform.MacOS
|
|||
get
|
||||
{
|
||||
int swap_interval = 0;
|
||||
if (Agl.aglGetInteger(Handle.Handle, Agl.ParameterNames.AGL_SWAP_INTERVAL, out swap_interval))
|
||||
if (Agl.aglGetInteger(Context.Handle, Agl.ParameterNames.AGL_SWAP_INTERVAL, out swap_interval))
|
||||
{
|
||||
return swap_interval;
|
||||
}
|
||||
|
@ -244,36 +240,19 @@ namespace OpenTK.Platform.MacOS
|
|||
}
|
||||
set
|
||||
{
|
||||
if (!Agl.aglSetInteger(Handle.Handle, Agl.ParameterNames.AGL_SWAP_INTERVAL, ref value))
|
||||
if (!Agl.aglSetInteger(Context.Handle, Agl.ParameterNames.AGL_SWAP_INTERVAL, ref value))
|
||||
MyAGLReportError("aglSetInteger");
|
||||
}
|
||||
}
|
||||
|
||||
public GraphicsMode Mode
|
||||
{
|
||||
get
|
||||
{
|
||||
return mode;
|
||||
}
|
||||
set
|
||||
{
|
||||
mode = value;
|
||||
}
|
||||
|
||||
}
|
||||
public GraphicsMode Mode { get; set; }
|
||||
|
||||
public void LoadAll()
|
||||
{
|
||||
dummyContext.LoadAll();
|
||||
}
|
||||
|
||||
public bool IsDisposed
|
||||
{
|
||||
get
|
||||
{
|
||||
return disposed;
|
||||
}
|
||||
}
|
||||
public bool IsDisposed { get; private set; }
|
||||
|
||||
public bool VSync
|
||||
{
|
||||
|
@ -291,21 +270,11 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
get
|
||||
{
|
||||
return mode;
|
||||
return Mode;
|
||||
}
|
||||
}
|
||||
|
||||
public bool ErrorChecking
|
||||
{
|
||||
get
|
||||
{
|
||||
return error_checking;
|
||||
}
|
||||
set
|
||||
{
|
||||
error_checking = value;
|
||||
}
|
||||
}
|
||||
public bool ErrorChecking { get; set; }
|
||||
|
||||
~AglContext()
|
||||
{
|
||||
|
@ -319,7 +288,7 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
void Dispose(bool disposing)
|
||||
{
|
||||
if (IsDisposed || Handle.Handle == IntPtr.Zero)
|
||||
if (IsDisposed || Context.Handle == IntPtr.Zero)
|
||||
return;
|
||||
|
||||
Debug.Print("Disposing of AGL context.");
|
||||
|
@ -335,10 +304,10 @@ namespace OpenTK.Platform.MacOS
|
|||
// Actually, it seems to crash the mono runtime. -AMK 2013
|
||||
|
||||
Debug.Print("Destroying context");
|
||||
if (Agl.aglDestroyContext(Handle.Handle) == true)
|
||||
if (Agl.aglDestroyContext(Context.Handle) == true)
|
||||
{
|
||||
Debug.Print("Context destruction completed successfully.");
|
||||
Handle = ContextHandle.Zero;
|
||||
Context = ContextHandle.Zero;
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -352,7 +321,7 @@ namespace OpenTK.Platform.MacOS
|
|||
throw new Exception(Agl.ErrorString(Agl.GetError()));
|
||||
}
|
||||
|
||||
disposed = true;
|
||||
IsDisposed = true;
|
||||
}
|
||||
|
||||
public IntPtr GetAddress(string function)
|
||||
|
@ -373,12 +342,6 @@ namespace OpenTK.Platform.MacOS
|
|||
}
|
||||
}
|
||||
|
||||
public ContextHandle Context
|
||||
{
|
||||
get
|
||||
{
|
||||
return Handle;
|
||||
}
|
||||
}
|
||||
public ContextHandle Context { get; private set; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -38,14 +38,13 @@ namespace OpenTK
|
|||
{
|
||||
GraphicsMode mode;
|
||||
Control control;
|
||||
IWindowInfo window_info;
|
||||
|
||||
internal CarbonGLControl(GraphicsMode mode, Control owner)
|
||||
{
|
||||
this.mode = mode;
|
||||
this.control = owner;
|
||||
|
||||
window_info = Utilities.CreateMacOSCarbonWindowInfo(control.Handle, false, true);
|
||||
WindowInfo = Utilities.CreateMacOSCarbonWindowInfo(control.Handle, false, true);
|
||||
}
|
||||
|
||||
private int GetXOffset()
|
||||
|
@ -82,12 +81,6 @@ namespace OpenTK
|
|||
}
|
||||
}
|
||||
|
||||
public IWindowInfo WindowInfo
|
||||
{
|
||||
get
|
||||
{
|
||||
return window_info;
|
||||
}
|
||||
}
|
||||
public IWindowInfo WindowInfo { get; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -50,12 +50,7 @@ namespace OpenTK
|
|||
{
|
||||
static int instance_count;
|
||||
|
||||
readonly ContextHandle handle = new ContextHandle(new IntPtr(
|
||||
System.Threading.Interlocked.Increment(ref instance_count)));
|
||||
|
||||
IWindowInfo current_window;
|
||||
bool is_disposed;
|
||||
int swap_interval;
|
||||
|
||||
public void SwapBuffers()
|
||||
{
|
||||
|
@ -71,10 +66,7 @@ namespace OpenTK
|
|||
get { return current_window != null; }
|
||||
}
|
||||
|
||||
public bool IsDisposed
|
||||
{
|
||||
get { return is_disposed; }
|
||||
}
|
||||
public bool IsDisposed { get; private set; }
|
||||
|
||||
public bool VSync
|
||||
{
|
||||
|
@ -88,17 +80,7 @@ namespace OpenTK
|
|||
}
|
||||
}
|
||||
|
||||
public int SwapInterval
|
||||
{
|
||||
get
|
||||
{
|
||||
return swap_interval;
|
||||
}
|
||||
set
|
||||
{
|
||||
swap_interval = value;
|
||||
}
|
||||
}
|
||||
public int SwapInterval { get; set; }
|
||||
|
||||
public void Update(IWindowInfo window)
|
||||
{
|
||||
|
@ -126,13 +108,11 @@ namespace OpenTK
|
|||
|
||||
public void Dispose()
|
||||
{
|
||||
is_disposed = true;
|
||||
IsDisposed = true;
|
||||
}
|
||||
|
||||
public ContextHandle Context
|
||||
{
|
||||
get { return handle; }
|
||||
}
|
||||
public ContextHandle Context { get; } = new ContextHandle(new IntPtr(
|
||||
System.Threading.Interlocked.Increment(ref instance_count)));
|
||||
|
||||
public IntPtr GetAddress(IntPtr function)
|
||||
{
|
||||
|
|
|
@ -35,13 +35,12 @@ namespace OpenTK
|
|||
{
|
||||
class Sdl2GLControl : IGLControl
|
||||
{
|
||||
IWindowInfo window_info;
|
||||
GraphicsMode mode;
|
||||
|
||||
public Sdl2GLControl(GraphicsMode mode, Control control)
|
||||
{
|
||||
this.mode = mode;
|
||||
window_info = Utilities.CreateSdl2WindowInfo(control.Handle);
|
||||
WindowInfo = Utilities.CreateSdl2WindowInfo(control.Handle);
|
||||
// Fixme: SDL2 will refuse to create an OpenGL context on
|
||||
// a window with the SDL_WINDOW_FOREIGN flag (i.e. windows
|
||||
// that are passed to SDL2 through SDL_CreateWindowFrom).
|
||||
|
@ -50,7 +49,7 @@ namespace OpenTK
|
|||
|
||||
public Graphics.IGraphicsContext CreateContext(int major, int minor, Graphics.GraphicsContextFlags flags)
|
||||
{
|
||||
return new GraphicsContext(mode, window_info, major, minor, flags);
|
||||
return new GraphicsContext(mode, WindowInfo, major, minor, flags);
|
||||
}
|
||||
|
||||
public bool IsIdle
|
||||
|
@ -58,10 +57,7 @@ namespace OpenTK
|
|||
get { return NativeMethods.SDL_HasEvents(0, 0xffff); }
|
||||
}
|
||||
|
||||
public Platform.IWindowInfo WindowInfo
|
||||
{
|
||||
get { return window_info; }
|
||||
}
|
||||
public Platform.IWindowInfo WindowInfo { get; }
|
||||
|
||||
static class NativeMethods
|
||||
{
|
||||
|
|
|
@ -78,19 +78,18 @@ namespace OpenTK
|
|||
static extern bool PeekMessage(ref MSG msg, IntPtr hWnd, int messageFilterMin, int messageFilterMax, int flags);
|
||||
|
||||
MSG msg = new MSG();
|
||||
IWindowInfo window_info;
|
||||
GraphicsMode mode;
|
||||
|
||||
public WinGLControl(GraphicsMode mode, Control control)
|
||||
{
|
||||
this.mode = mode;
|
||||
|
||||
window_info = Utilities.CreateWindowsWindowInfo(control.Handle);
|
||||
WindowInfo = Utilities.CreateWindowsWindowInfo(control.Handle);
|
||||
}
|
||||
|
||||
public IGraphicsContext CreateContext(int major, int minor, GraphicsContextFlags flags)
|
||||
{
|
||||
return new GraphicsContext(mode, window_info, major, minor, flags);
|
||||
return new GraphicsContext(mode, WindowInfo, major, minor, flags);
|
||||
}
|
||||
|
||||
public bool IsIdle
|
||||
|
@ -98,13 +97,6 @@ namespace OpenTK
|
|||
get { return !PeekMessage(ref msg, IntPtr.Zero, 0, 0, 0); }
|
||||
}
|
||||
|
||||
public IWindowInfo WindowInfo
|
||||
{
|
||||
get
|
||||
{
|
||||
// This method forces the creation of the control. Beware of this side-effect!
|
||||
return window_info;
|
||||
}
|
||||
}
|
||||
public IWindowInfo WindowInfo { get; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -53,7 +53,6 @@ namespace OpenTK
|
|||
}
|
||||
|
||||
GraphicsMode mode;
|
||||
IWindowInfo window_info;
|
||||
IntPtr display;
|
||||
IntPtr rootWindow;
|
||||
|
||||
|
@ -92,7 +91,7 @@ namespace OpenTK
|
|||
rootWindow = (IntPtr)GetStaticFieldValue(xplatui, "RootWindow");
|
||||
int screen = (int)GetStaticFieldValue(xplatui, "ScreenNo");
|
||||
|
||||
window_info = Utilities.CreateX11WindowInfo(display, screen, control.Handle, rootWindow, IntPtr.Zero);
|
||||
WindowInfo = Utilities.CreateX11WindowInfo(display, screen, control.Handle, rootWindow, IntPtr.Zero);
|
||||
}
|
||||
|
||||
public IGraphicsContext CreateContext(int major, int minor, GraphicsContextFlags flags)
|
||||
|
@ -121,13 +120,7 @@ namespace OpenTK
|
|||
get { return XPending(display) == 0; }
|
||||
}
|
||||
|
||||
public IWindowInfo WindowInfo
|
||||
{
|
||||
get
|
||||
{
|
||||
return window_info;
|
||||
}
|
||||
}
|
||||
public IWindowInfo WindowInfo { get; }
|
||||
|
||||
static object GetStaticFieldValue(Type type, string fieldName)
|
||||
{
|
||||
|
|
|
@ -24,7 +24,6 @@ namespace OpenTK
|
|||
|
||||
private IGraphicsContext _GraphicsContext;
|
||||
private IWindowInfo _WindowInfo;
|
||||
private GraphicsContextFlags _GraphicsContextFlags;
|
||||
private bool _Initialized = false;
|
||||
|
||||
/// <summary>
|
||||
|
@ -76,17 +75,7 @@ namespace OpenTK
|
|||
/// <summary>
|
||||
/// The set <see cref="GraphicsContextFlags"/> for this widget.
|
||||
/// </summary>
|
||||
public GraphicsContextFlags GraphicsContextFlags
|
||||
{
|
||||
get
|
||||
{
|
||||
return _GraphicsContextFlags;
|
||||
}
|
||||
set
|
||||
{
|
||||
_GraphicsContextFlags = value;
|
||||
}
|
||||
}
|
||||
public GraphicsContextFlags GraphicsContextFlags { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="GLWidget"/> class.
|
||||
|
@ -364,7 +353,7 @@ namespace OpenTK
|
|||
_WindowInfo = XWindowInfoInitializer.Initialize(graphicsMode, this.Display.Handle, this.Screen.Number, widgetWindowHandle, this.Screen.RootWindow.Handle);
|
||||
|
||||
// GraphicsContext
|
||||
_GraphicsContext = new GraphicsContext(graphicsMode, _WindowInfo, GlVersionMajor, GlVersionMinor, _GraphicsContextFlags);
|
||||
_GraphicsContext = new GraphicsContext(graphicsMode, _WindowInfo, GlVersionMajor, GlVersionMinor, GraphicsContextFlags);
|
||||
_GraphicsContext.MakeCurrent(_WindowInfo);
|
||||
|
||||
if (GraphicsContext.ShareContexts)
|
||||
|
|
|
@ -43,10 +43,6 @@ namespace OpenTK.Audio
|
|||
IntPtr Handle;
|
||||
|
||||
// Alc.CaptureStop should be called prior to device shutdown, this keeps track of Alc.CaptureStart/Stop calls.
|
||||
bool _isrecording = false;
|
||||
|
||||
ALFormat sample_format;
|
||||
int sample_frequency;
|
||||
|
||||
|
||||
static AudioCapture()
|
||||
|
@ -80,20 +76,20 @@ namespace OpenTK.Audio
|
|||
throw new ArgumentOutOfRangeException("bufferSize");
|
||||
|
||||
// Try to open specified device. If it fails, try to open default device.
|
||||
device_name = deviceName;
|
||||
CurrentDevice = deviceName;
|
||||
Handle = Alc.CaptureOpenDevice(deviceName, frequency, sampleFormat, bufferSize);
|
||||
|
||||
if (Handle == IntPtr.Zero)
|
||||
{
|
||||
Debug.WriteLine(ErrorMessage(deviceName, frequency, sampleFormat, bufferSize));
|
||||
device_name = "IntPtr.Zero";
|
||||
CurrentDevice = "IntPtr.Zero";
|
||||
Handle = Alc.CaptureOpenDevice(null, frequency, sampleFormat, bufferSize);
|
||||
}
|
||||
|
||||
if (Handle == IntPtr.Zero)
|
||||
{
|
||||
Debug.WriteLine(ErrorMessage("IntPtr.Zero", frequency, sampleFormat, bufferSize));
|
||||
device_name = AudioDeviceEnumerator.DefaultRecordingDevice;
|
||||
CurrentDevice = AudioDeviceEnumerator.DefaultRecordingDevice;
|
||||
Handle = Alc.CaptureOpenDevice(AudioDeviceEnumerator.DefaultRecordingDevice, frequency, sampleFormat, bufferSize);
|
||||
}
|
||||
|
||||
|
@ -101,7 +97,7 @@ namespace OpenTK.Audio
|
|||
{
|
||||
// Everything we tried failed. Capture may not be supported, bail out.
|
||||
Debug.WriteLine(ErrorMessage(AudioDeviceEnumerator.DefaultRecordingDevice, frequency, sampleFormat, bufferSize));
|
||||
device_name = "None";
|
||||
CurrentDevice = "None";
|
||||
|
||||
throw new AudioDeviceException("All attempts to open capture devices returned IntPtr.Zero. See debug log for verbose list.");
|
||||
}
|
||||
|
@ -113,18 +109,10 @@ namespace OpenTK.Audio
|
|||
SampleFrequency = frequency;
|
||||
}
|
||||
|
||||
private string device_name;
|
||||
|
||||
/// <summary>
|
||||
/// The name of the device associated with this instance.
|
||||
/// </summary>
|
||||
public string CurrentDevice
|
||||
{
|
||||
get
|
||||
{
|
||||
return device_name;
|
||||
}
|
||||
}
|
||||
public string CurrentDevice { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Returns a list of strings containing all known recording devices.
|
||||
|
@ -177,14 +165,14 @@ namespace OpenTK.Audio
|
|||
public void Start()
|
||||
{
|
||||
Alc.CaptureStart(Handle);
|
||||
_isrecording = true;
|
||||
IsRunning = true;
|
||||
}
|
||||
|
||||
/// <summary>Stop recording samples. This will not clear previously recorded samples.</summary>
|
||||
public void Stop()
|
||||
{
|
||||
Alc.CaptureStop(Handle);
|
||||
_isrecording = false;
|
||||
IsRunning = false;
|
||||
}
|
||||
|
||||
/// <summary>Returns the number of available samples for capture.</summary>
|
||||
|
@ -236,28 +224,17 @@ namespace OpenTK.Audio
|
|||
/// <summary>
|
||||
/// Gets the OpenTK.Audio.ALFormat for this instance.
|
||||
/// </summary>
|
||||
public ALFormat SampleFormat
|
||||
{
|
||||
get { return sample_format; }
|
||||
private set { sample_format = value; }
|
||||
}
|
||||
public ALFormat SampleFormat { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the sampling rate for this instance.
|
||||
/// </summary>
|
||||
public int SampleFrequency
|
||||
{
|
||||
get { return sample_frequency; }
|
||||
private set { sample_frequency = value; }
|
||||
}
|
||||
public int SampleFrequency { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating whether this instance is currently capturing samples.
|
||||
/// </summary>
|
||||
public bool IsRunning
|
||||
{
|
||||
get { return _isrecording; }
|
||||
}
|
||||
public bool IsRunning { get; private set; } = false;
|
||||
|
||||
// Retrieves the sample size in bytes for various ALFormats.
|
||||
// Compressed formats always return 1.
|
||||
|
@ -342,7 +319,7 @@ namespace OpenTK.Audio
|
|||
{
|
||||
if (this.Handle != IntPtr.Zero)
|
||||
{
|
||||
if (this._isrecording)
|
||||
if (this.IsRunning)
|
||||
this.Stop();
|
||||
|
||||
Alc.CaptureCloseDevice(this.Handle);
|
||||
|
|
|
@ -41,7 +41,6 @@ namespace OpenTK.Audio
|
|||
{
|
||||
bool disposed;
|
||||
bool is_processing, is_synchronized;
|
||||
IntPtr device_handle;
|
||||
ContextHandle context_handle;
|
||||
bool context_exists;
|
||||
|
||||
|
@ -218,19 +217,19 @@ namespace OpenTK.Audio
|
|||
if (!String.IsNullOrEmpty(device))
|
||||
{
|
||||
device_name = device;
|
||||
device_handle = Alc.OpenDevice(device); // try to open device by name
|
||||
Device = Alc.OpenDevice(device); // try to open device by name
|
||||
}
|
||||
if (device_handle == IntPtr.Zero)
|
||||
if (Device == IntPtr.Zero)
|
||||
{
|
||||
device_name = "IntPtr.Zero (null string)";
|
||||
device_handle = Alc.OpenDevice(null); // try to open unnamed default device
|
||||
Device = Alc.OpenDevice(null); // try to open unnamed default device
|
||||
}
|
||||
if (device_handle == IntPtr.Zero)
|
||||
if (Device == IntPtr.Zero)
|
||||
{
|
||||
device_name = AudioContext.DefaultDevice;
|
||||
device_handle = Alc.OpenDevice(AudioContext.DefaultDevice); // try to open named default device
|
||||
Device = Alc.OpenDevice(AudioContext.DefaultDevice); // try to open named default device
|
||||
}
|
||||
if (device_handle == IntPtr.Zero)
|
||||
if (Device == IntPtr.Zero)
|
||||
{
|
||||
device_name = "None";
|
||||
throw new AudioDeviceException(String.Format("Audio device '{0}' does not exist or is tied up by another application.",
|
||||
|
@ -257,7 +256,7 @@ namespace OpenTK.Audio
|
|||
attributes.Add((int)AlcContextAttributes.Sync);
|
||||
attributes.Add(sync ? 1 : 0);
|
||||
|
||||
if (enableEfx && Alc.IsExtensionPresent(device_handle, "ALC_EXT_EFX"))
|
||||
if (enableEfx && Alc.IsExtensionPresent(Device, "ALC_EXT_EFX"))
|
||||
{
|
||||
int num_slots;
|
||||
switch (efxAuxiliarySends)
|
||||
|
@ -270,7 +269,7 @@ namespace OpenTK.Audio
|
|||
break;
|
||||
default:
|
||||
case MaxAuxiliarySends.UseDriverDefault:
|
||||
Alc.GetInteger(device_handle, AlcGetInteger.EfxMaxAuxiliarySends, 1, out num_slots);
|
||||
Alc.GetInteger(Device, AlcGetInteger.EfxMaxAuxiliarySends, 1, out num_slots);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -279,11 +278,11 @@ namespace OpenTK.Audio
|
|||
}
|
||||
attributes.Add(0);
|
||||
|
||||
context_handle = Alc.CreateContext(device_handle, attributes.ToArray());
|
||||
context_handle = Alc.CreateContext(Device, attributes.ToArray());
|
||||
|
||||
if (context_handle == ContextHandle.Zero)
|
||||
{
|
||||
Alc.CloseDevice(device_handle);
|
||||
Alc.CloseDevice(Device);
|
||||
throw new AudioContextException("The audio context could not be created with the specified parameters.");
|
||||
}
|
||||
|
||||
|
@ -297,7 +296,7 @@ namespace OpenTK.Audio
|
|||
|
||||
CheckErrors();
|
||||
|
||||
device_name = Alc.GetString(device_handle, AlcGetString.DeviceSpecifier);
|
||||
device_name = Alc.GetString(Device, AlcGetString.DeviceSpecifier);
|
||||
|
||||
|
||||
lock (audio_context_lock)
|
||||
|
@ -356,7 +355,7 @@ namespace OpenTK.Audio
|
|||
}
|
||||
}
|
||||
|
||||
IntPtr Device { get { return device_handle; } }
|
||||
private IntPtr Device { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Checks for ALC error conditions.
|
||||
|
@ -370,7 +369,7 @@ namespace OpenTK.Audio
|
|||
if (disposed)
|
||||
throw new ObjectDisposedException(this.GetType().FullName);
|
||||
|
||||
new AudioDeviceErrorChecker(device_handle).Dispose();
|
||||
new AudioDeviceErrorChecker(Device).Dispose();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -383,7 +382,7 @@ namespace OpenTK.Audio
|
|||
if (disposed)
|
||||
throw new ObjectDisposedException(this.GetType().FullName);
|
||||
|
||||
return Alc.GetError(device_handle);
|
||||
return Alc.GetError(Device);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -594,8 +593,8 @@ namespace OpenTK.Audio
|
|||
Alc.DestroyContext(context_handle);
|
||||
}
|
||||
|
||||
if (device_handle != IntPtr.Zero)
|
||||
Alc.CloseDevice(device_handle);
|
||||
if (Device != IntPtr.Zero)
|
||||
Alc.CloseDevice(Device);
|
||||
|
||||
if (manual)
|
||||
{
|
||||
|
@ -638,7 +637,7 @@ namespace OpenTK.Audio
|
|||
public override string ToString()
|
||||
{
|
||||
return String.Format("{0} (handle: {1}, device: {2})",
|
||||
this.device_name, this.context_handle, this.device_handle);
|
||||
this.device_name, this.context_handle, this.Device);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -52,32 +52,11 @@ namespace OpenTK.Audio
|
|||
}
|
||||
}
|
||||
|
||||
private static string default_playback_device;
|
||||
internal static string DefaultPlaybackDevice
|
||||
{
|
||||
get
|
||||
{
|
||||
return default_playback_device;
|
||||
}
|
||||
}
|
||||
internal static string DefaultPlaybackDevice { get; }
|
||||
|
||||
private static string default_recording_device;
|
||||
internal static string DefaultRecordingDevice
|
||||
{
|
||||
get
|
||||
{
|
||||
return default_recording_device;
|
||||
}
|
||||
}
|
||||
internal static string DefaultRecordingDevice { get; }
|
||||
|
||||
private static bool openal_supported = true;
|
||||
internal static bool IsOpenALSupported
|
||||
{
|
||||
get
|
||||
{
|
||||
return openal_supported;
|
||||
}
|
||||
}
|
||||
internal static bool IsOpenALSupported { get; } = true;
|
||||
|
||||
internal enum AlcVersion
|
||||
{
|
||||
|
@ -85,14 +64,7 @@ namespace OpenTK.Audio
|
|||
Alc1_1
|
||||
}
|
||||
|
||||
private static AlcVersion version;
|
||||
internal static AlcVersion Version
|
||||
{
|
||||
get
|
||||
{
|
||||
return version;
|
||||
}
|
||||
}
|
||||
internal static AlcVersion Version { get; }
|
||||
|
||||
// Loads all available audio devices into the available_*_devices lists.
|
||||
static AudioDeviceEnumerator()
|
||||
|
@ -121,21 +93,21 @@ namespace OpenTK.Audio
|
|||
// Get a list of all known playback devices, using best extension available
|
||||
if (Alc.IsExtensionPresent(IntPtr.Zero, "ALC_ENUMERATION_EXT"))
|
||||
{
|
||||
version = AlcVersion.Alc1_1;
|
||||
Version = AlcVersion.Alc1_1;
|
||||
if (Alc.IsExtensionPresent(IntPtr.Zero, "ALC_ENUMERATE_ALL_EXT"))
|
||||
{
|
||||
available_playback_devices.AddRange(Alc.GetString(IntPtr.Zero, AlcGetStringList.AllDevicesSpecifier));
|
||||
default_playback_device = Alc.GetString(IntPtr.Zero, AlcGetString.DefaultAllDevicesSpecifier);
|
||||
DefaultPlaybackDevice = Alc.GetString(IntPtr.Zero, AlcGetString.DefaultAllDevicesSpecifier);
|
||||
}
|
||||
else
|
||||
{
|
||||
available_playback_devices.AddRange(Alc.GetString(IntPtr.Zero, AlcGetStringList.DeviceSpecifier));
|
||||
default_playback_device = Alc.GetString(IntPtr.Zero, AlcGetString.DefaultDeviceSpecifier);
|
||||
DefaultPlaybackDevice = Alc.GetString(IntPtr.Zero, AlcGetString.DefaultDeviceSpecifier);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
version = AlcVersion.Alc1_0;
|
||||
Version = AlcVersion.Alc1_0;
|
||||
Debug.Print("Device enumeration extension not available. Failed to enumerate playback devices.");
|
||||
}
|
||||
AlcError playback_err = Alc.GetError(dummy_device);
|
||||
|
@ -143,10 +115,10 @@ namespace OpenTK.Audio
|
|||
throw new AudioContextException("Alc Error occured when querying available playback devices. " + playback_err.ToString());
|
||||
|
||||
// Get a list of all known recording devices, at least ALC_ENUMERATION_EXT is needed too
|
||||
if (version == AlcVersion.Alc1_1 && Alc.IsExtensionPresent(IntPtr.Zero, "ALC_EXT_CAPTURE"))
|
||||
if (Version == AlcVersion.Alc1_1 && Alc.IsExtensionPresent(IntPtr.Zero, "ALC_EXT_CAPTURE"))
|
||||
{
|
||||
available_recording_devices.AddRange(Alc.GetString(IntPtr.Zero, AlcGetStringList.CaptureDeviceSpecifier));
|
||||
default_recording_device = Alc.GetString(IntPtr.Zero, AlcGetString.CaptureDefaultDeviceSpecifier);
|
||||
DefaultRecordingDevice = Alc.GetString(IntPtr.Zero, AlcGetString.CaptureDefaultDeviceSpecifier);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -161,30 +133,30 @@ namespace OpenTK.Audio
|
|||
foreach (string s in available_playback_devices)
|
||||
Debug.WriteLine(s);
|
||||
|
||||
Debug.WriteLine("Default playback device: " + default_playback_device);
|
||||
Debug.WriteLine("Default playback device: " + DefaultPlaybackDevice);
|
||||
|
||||
Debug.WriteLine("Found recording devices:");
|
||||
foreach (string s in available_recording_devices)
|
||||
Debug.WriteLine(s);
|
||||
|
||||
Debug.WriteLine("Default recording device: " + default_recording_device);
|
||||
Debug.WriteLine("Default recording device: " + DefaultRecordingDevice);
|
||||
#endif
|
||||
}
|
||||
catch (DllNotFoundException e)
|
||||
{
|
||||
Trace.WriteLine(e.ToString());
|
||||
openal_supported = false;
|
||||
IsOpenALSupported = false;
|
||||
}
|
||||
catch (AudioContextException ace)
|
||||
{
|
||||
Trace.WriteLine(ace.ToString());
|
||||
openal_supported = false;
|
||||
IsOpenALSupported = false;
|
||||
}
|
||||
finally
|
||||
{
|
||||
Debug.Unindent();
|
||||
|
||||
if (openal_supported)
|
||||
if (IsOpenALSupported)
|
||||
{
|
||||
try
|
||||
{
|
||||
|
@ -197,7 +169,7 @@ namespace OpenTK.Audio
|
|||
}
|
||||
catch
|
||||
{
|
||||
openal_supported = false;
|
||||
IsOpenALSupported = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1070,23 +1070,15 @@ namespace OpenTK.Audio.OpenAL
|
|||
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTIV)( ALuint asid, ALenum pname, ALint* values );
|
||||
// typedef void (__cdecl *LPALGETAUXILIARYEFFECTSLOTFV)( ALuint asid, ALenum pname, ALfloat* values );
|
||||
|
||||
private bool _valid;
|
||||
|
||||
/// <summary>Returns True if the EFX Extension has been found and could be initialized.</summary>
|
||||
public bool IsInitialized
|
||||
{
|
||||
get
|
||||
{
|
||||
return _valid;
|
||||
}
|
||||
}
|
||||
public bool IsInitialized { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new EffectsExtension instance.
|
||||
/// </summary>
|
||||
public EffectsExtension()
|
||||
{
|
||||
_valid = false;
|
||||
IsInitialized = false;
|
||||
|
||||
if (AudioContext.CurrentContext == null)
|
||||
throw new InvalidOperationException("AL.LoadAll() needs a current AudioContext.");
|
||||
|
@ -1152,7 +1144,7 @@ namespace OpenTK.Audio.OpenAL
|
|||
// Console.WriteLine("Auxiliary Effect Slot functions appear to be ok.");
|
||||
|
||||
// didn't return so far, everything went fine.
|
||||
_valid = true;
|
||||
IsInitialized = true;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -19,13 +19,8 @@ namespace OpenTK.Audio.OpenAL
|
|||
[CLSCompliant(true)]
|
||||
public sealed class XRamExtension
|
||||
{
|
||||
private bool _valid = false;
|
||||
|
||||
/// <summary>Returns True if the X-Ram Extension has been found and could be initialized.</summary>
|
||||
public bool IsInitialized
|
||||
{
|
||||
get { return _valid; }
|
||||
}
|
||||
public bool IsInitialized { get; } = false;
|
||||
|
||||
// [CLSCompliant(false)]
|
||||
private delegate bool Delegate_SetBufferMode(int n, ref uint buffers, int value);
|
||||
|
@ -48,7 +43,7 @@ namespace OpenTK.Audio.OpenAL
|
|||
/// </summary>
|
||||
public XRamExtension()
|
||||
{ // Query if Extension supported and retrieve Tokens/Pointers if it is.
|
||||
_valid = false;
|
||||
IsInitialized = false;
|
||||
if (AL.IsExtensionPresent("EAX-RAM") == false)
|
||||
return;
|
||||
|
||||
|
@ -83,7 +78,7 @@ namespace OpenTK.Audio.OpenAL
|
|||
return;
|
||||
}
|
||||
|
||||
_valid = true;
|
||||
IsInitialized = true;
|
||||
}
|
||||
|
||||
/// <summary>Query total amount of X-RAM in bytes.</summary>
|
||||
|
|
|
@ -37,8 +37,6 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public abstract class BindingsBase
|
||||
{
|
||||
bool rebuildExtensionList = true;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new BindingsBase instance.
|
||||
/// </summary>
|
||||
|
@ -49,11 +47,7 @@ namespace OpenTK
|
|||
/// <summary>
|
||||
/// Gets or sets a <see cref="System.Boolean"/> that indicates whether the list of supported extensions may have changed.
|
||||
/// </summary>
|
||||
protected bool RebuildExtensionList
|
||||
{
|
||||
get { return rebuildExtensionList; }
|
||||
set { rebuildExtensionList = value; }
|
||||
}
|
||||
protected bool RebuildExtensionList { get; set; } = true;
|
||||
|
||||
/// <summary>
|
||||
/// Retrieves an unmanaged function pointer to the specified function.
|
||||
|
|
|
@ -42,7 +42,6 @@ namespace OpenTK
|
|||
public static class BlittableValueType<T>
|
||||
{
|
||||
static readonly Type Type;
|
||||
static readonly int stride;
|
||||
|
||||
static BlittableValueType()
|
||||
{
|
||||
|
@ -52,7 +51,7 @@ namespace OpenTK
|
|||
// Does this support generic types? On Mono 2.4.3 it does
|
||||
// On .Net it doesn't.
|
||||
// http://msdn.microsoft.com/en-us/library/5s4920fa.aspx
|
||||
stride = Marshal.SizeOf(typeof(T));
|
||||
Stride = Marshal.SizeOf(typeof(T));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -62,7 +61,7 @@ namespace OpenTK
|
|||
/// <remarks>
|
||||
/// This property returns 0 for non-blittable types.
|
||||
/// </remarks>
|
||||
public static int Stride { get { return stride; } }
|
||||
public static int Stride { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Checks whether the current typename T is blittable.
|
||||
|
|
|
@ -40,21 +40,17 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public sealed class Configuration
|
||||
{
|
||||
static bool runningOnWindows, runningOnUnix, runningOnX11, runningOnMacOS, runningOnLinux;
|
||||
static bool runningOnMono;
|
||||
static bool runningOnUnix, runningOnMacOS, runningOnLinux;
|
||||
volatile static bool initialized;
|
||||
readonly static object InitLock = new object();
|
||||
|
||||
Configuration() { }
|
||||
|
||||
/// <summary>Gets a System.Boolean indicating whether OpenTK is running on a Windows platform.</summary>
|
||||
public static bool RunningOnWindows { get { return runningOnWindows; } }
|
||||
public static bool RunningOnWindows { get; private set; }
|
||||
|
||||
/// <summary>Gets a System.Boolean indicating whether OpenTK is running on an X11 platform.</summary>
|
||||
public static bool RunningOnX11
|
||||
{
|
||||
get { return runningOnX11; }
|
||||
}
|
||||
public static bool RunningOnX11 { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> indicating whether OpenTK is running on a Unix platform.
|
||||
|
@ -82,7 +78,7 @@ namespace OpenTK
|
|||
/// <summary>
|
||||
/// Gets a System.Boolean indicating whether OpenTK is running on the Mono runtime.
|
||||
/// </summary>
|
||||
public static bool RunningOnMono { get { return runningOnMono; } }
|
||||
public static bool RunningOnMono { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <c>System.Boolean</c> indicating whether
|
||||
|
@ -287,9 +283,9 @@ namespace OpenTK
|
|||
#if ANDROID || IPHONE
|
||||
runningOnMono = true;
|
||||
#else
|
||||
runningOnMono = DetectMono();
|
||||
runningOnWindows = DetectWindows();
|
||||
if (!runningOnWindows)
|
||||
RunningOnMono = DetectMono();
|
||||
RunningOnWindows = DetectWindows();
|
||||
if (!RunningOnWindows)
|
||||
{
|
||||
DetectUnix(out runningOnUnix, out runningOnLinux, out runningOnMacOS);
|
||||
}
|
||||
|
@ -301,7 +297,7 @@ namespace OpenTK
|
|||
|
||||
if ((runningOnLinux && !RunningOnSdl2) || options.Backend == PlatformBackend.PreferX11)
|
||||
{
|
||||
runningOnX11 = DetectX11();
|
||||
RunningOnX11 = DetectX11();
|
||||
}
|
||||
|
||||
initialized = true;
|
||||
|
|
|
@ -44,7 +44,6 @@ namespace OpenTK
|
|||
bool primary;
|
||||
Rectangle bounds;
|
||||
DisplayResolution current_resolution = new DisplayResolution();
|
||||
DisplayResolution original_resolution;
|
||||
List<DisplayResolution> available_resolutions = new List<DisplayResolution>();
|
||||
IList<DisplayResolution> available_resolutions_readonly;
|
||||
|
||||
|
@ -191,8 +190,8 @@ namespace OpenTK
|
|||
|
||||
if (implementation.TryChangeResolution(this, resolution))
|
||||
{
|
||||
if (original_resolution == null)
|
||||
original_resolution = current_resolution;
|
||||
if (OriginalResolution == null)
|
||||
OriginalResolution = current_resolution;
|
||||
current_resolution = resolution;
|
||||
}
|
||||
else throw new Graphics.GraphicsModeException(String.Format("Device {0}: Failed to change resolution to {1}.",
|
||||
|
@ -216,14 +215,14 @@ namespace OpenTK
|
|||
/// <exception cref="Graphics.GraphicsModeException">Thrown if the original resolution could not be restored.</exception>
|
||||
public void RestoreResolution()
|
||||
{
|
||||
if (original_resolution != null)
|
||||
if (OriginalResolution != null)
|
||||
{
|
||||
//effect.FadeOut();
|
||||
|
||||
if (implementation.TryRestoreResolution(this))
|
||||
{
|
||||
current_resolution = original_resolution;
|
||||
original_resolution = null;
|
||||
current_resolution = OriginalResolution;
|
||||
OriginalResolution = null;
|
||||
}
|
||||
else throw new Graphics.GraphicsModeException(String.Format("Device {0}: Failed to restore resolution.", this));
|
||||
|
||||
|
@ -250,11 +249,7 @@ namespace OpenTK
|
|||
/// <summary>
|
||||
/// Gets the original resolution of this instance.
|
||||
/// </summary>
|
||||
internal DisplayResolution OriginalResolution
|
||||
{
|
||||
get { return original_resolution; }
|
||||
set { original_resolution = value; }
|
||||
}
|
||||
internal DisplayResolution OriginalResolution { get; set; }
|
||||
|
||||
internal static DisplayDevice FromPoint(int x, int y)
|
||||
{
|
||||
|
|
|
@ -18,8 +18,6 @@ namespace OpenTK
|
|||
public class DisplayResolution
|
||||
{
|
||||
Rectangle bounds;
|
||||
int bits_per_pixel;
|
||||
float refresh_rate;
|
||||
|
||||
internal DisplayResolution() { }
|
||||
|
||||
|
@ -33,8 +31,8 @@ namespace OpenTK
|
|||
if (refreshRate < 0) throw new ArgumentOutOfRangeException("refreshRate", "Must be greater than, or equal to zero.");
|
||||
|
||||
this.bounds = new Rectangle(x, y, width, height);
|
||||
this.bits_per_pixel = bitsPerPixel;
|
||||
this.refresh_rate = refreshRate;
|
||||
this.BitsPerPixel = bitsPerPixel;
|
||||
this.RefreshRate = refreshRate;
|
||||
}
|
||||
|
||||
#if false
|
||||
|
@ -91,20 +89,12 @@ namespace OpenTK
|
|||
}
|
||||
|
||||
/// <summary>Gets a System.Int32 that contains number of bits per pixel of this display. Typical values include 8, 16, 24 and 32.</summary>
|
||||
public int BitsPerPixel
|
||||
{
|
||||
get { return bits_per_pixel; }
|
||||
internal set { bits_per_pixel = value; }
|
||||
}
|
||||
public int BitsPerPixel { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Single representing the vertical refresh rate of this display.
|
||||
/// </summary>
|
||||
public float RefreshRate
|
||||
{
|
||||
get { return refresh_rate; }
|
||||
internal set { refresh_rate = value; }
|
||||
}
|
||||
public float RefreshRate { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Returns a System.String representing this DisplayResolution.
|
||||
|
@ -113,7 +103,7 @@ namespace OpenTK
|
|||
public override string ToString()
|
||||
{
|
||||
#pragma warning disable 612,618
|
||||
return String.Format("{0}x{1}@{2}Hz", Bounds, bits_per_pixel, refresh_rate);
|
||||
return String.Format("{0}x{1}@{2}Hz", Bounds, BitsPerPixel, RefreshRate);
|
||||
#pragma warning restore 612,618
|
||||
}
|
||||
|
||||
|
@ -141,7 +131,7 @@ namespace OpenTK
|
|||
public override int GetHashCode()
|
||||
{
|
||||
#pragma warning disable 612,618
|
||||
return Bounds.GetHashCode() ^ bits_per_pixel ^ refresh_rate.GetHashCode();
|
||||
return Bounds.GetHashCode() ^ BitsPerPixel ^ RefreshRate.GetHashCode();
|
||||
#pragma warning restore 612,618
|
||||
}
|
||||
|
||||
|
|
|
@ -33,26 +33,18 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public class ContextExistsException : ApplicationException
|
||||
{
|
||||
string msg;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new ContextExistsException instance.
|
||||
/// </summary>
|
||||
/// <param name="message">A System.String explaining the cause of this exception.</param>
|
||||
public ContextExistsException(string message)
|
||||
{
|
||||
msg = message;
|
||||
Message = message;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.String explaining the cause of this exception.
|
||||
/// </summary>
|
||||
public override string Message
|
||||
{
|
||||
get
|
||||
{
|
||||
return msg;
|
||||
}
|
||||
}
|
||||
public override string Message { get; }
|
||||
}
|
||||
}
|
|
@ -37,8 +37,6 @@ namespace OpenTK.Graphics
|
|||
public struct ColorFormat : IComparable<ColorFormat>, IEquatable<ColorFormat>
|
||||
{
|
||||
byte red, green, blue, alpha;
|
||||
bool isIndexed;
|
||||
int bitsPerPixel;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new ColorFormat with the specified aggregate bits per pixel.
|
||||
|
@ -49,8 +47,8 @@ namespace OpenTK.Graphics
|
|||
if (bpp < 0)
|
||||
throw new ArgumentOutOfRangeException("bpp", "Must be greater or equal to zero.");
|
||||
red = green = blue = alpha = 0;
|
||||
bitsPerPixel = bpp;
|
||||
isIndexed = false;
|
||||
BitsPerPixel = bpp;
|
||||
IsIndexed = false;
|
||||
|
||||
switch (bpp)
|
||||
{
|
||||
|
@ -103,10 +101,10 @@ namespace OpenTK.Graphics
|
|||
this.green = (byte)green;
|
||||
this.blue = (byte)blue;
|
||||
this.alpha = (byte)alpha;
|
||||
this.bitsPerPixel = red + green + blue + alpha;
|
||||
this.isIndexed = false;
|
||||
if (this.bitsPerPixel < 15 && this.bitsPerPixel != 0)
|
||||
this.isIndexed = true;
|
||||
this.BitsPerPixel = red + green + blue + alpha;
|
||||
this.IsIndexed = false;
|
||||
if (this.BitsPerPixel < 15 && this.BitsPerPixel != 0)
|
||||
this.IsIndexed = true;
|
||||
}
|
||||
|
||||
/// <summary>Gets the bits per pixel for the Red channel.</summary>
|
||||
|
@ -118,9 +116,10 @@ namespace OpenTK.Graphics
|
|||
/// <summary>Gets the bits per pixel for the Alpha channel.</summary>
|
||||
public int Alpha { get { return alpha; } private set { alpha = (byte)value; } }
|
||||
/// <summary>Gets a System.Boolean indicating whether this ColorFormat is indexed.</summary>
|
||||
public bool IsIndexed { get { return isIndexed; } private set { isIndexed = value; } }
|
||||
public bool IsIndexed { get; private set; }
|
||||
|
||||
/// <summary>Gets the sum of Red, Green, Blue and Alpha bits per pixel.</summary>
|
||||
public int BitsPerPixel { get { return bitsPerPixel; } private set { bitsPerPixel = value; } }
|
||||
public int BitsPerPixel { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Defines an empty ColorFormat, where all properties are set to zero.
|
||||
|
|
|
@ -52,7 +52,7 @@ namespace OpenTK.Graphics
|
|||
|
||||
IGraphicsContext implementation; // The actual render context implementation for the underlying platform.
|
||||
bool disposed;
|
||||
bool check_errors = true;
|
||||
|
||||
// Cache for the context handle. We need this for RemoveContext()
|
||||
// in case the user does not call Dispose(). When this happens,
|
||||
// RemoveContext() is called by the finalizer, in which case
|
||||
|
@ -61,8 +61,6 @@ namespace OpenTK.Graphics
|
|||
// the handle.)
|
||||
ContextHandle handle_cached;
|
||||
|
||||
static bool share_contexts = true;
|
||||
static bool direct_rendering = true;
|
||||
readonly static object SyncRoot = new object();
|
||||
// Maps OS-specific context handles to GraphicsContext instances.
|
||||
readonly static Dictionary<ContextHandle, IGraphicsContext> available_contexts =
|
||||
|
@ -172,7 +170,7 @@ namespace OpenTK.Graphics
|
|||
GetCurrentContext = factory.CreateGetCurrentGraphicsContext();
|
||||
}
|
||||
|
||||
implementation = factory.CreateGLContext(mode, window, shareContext, direct_rendering, major, minor, flags);
|
||||
implementation = factory.CreateGLContext(mode, window, shareContext, DirectRendering, major, minor, flags);
|
||||
handle_cached = ((IGraphicsContextInternal)implementation).Context;
|
||||
factory.RegisterResource(this);
|
||||
}
|
||||
|
@ -392,7 +390,7 @@ namespace OpenTK.Graphics
|
|||
/// false, new GLContexts will not share resources.</para>
|
||||
/// <para>Changing this value will not affect already created GLContexts.</para>
|
||||
/// </remarks>
|
||||
public static bool ShareContexts { get { return share_contexts; } set { share_contexts = value; } }
|
||||
public static bool ShareContexts { get; set; } = true;
|
||||
|
||||
/// <summary>Gets or sets a System.Boolean, indicating whether GraphicsContexts will perform direct rendering.</summary>
|
||||
/// <remarks>
|
||||
|
@ -405,11 +403,7 @@ namespace OpenTK.Graphics
|
|||
/// This property is ignored on Operating Systems without support for indirect rendering, like Windows and OS X.
|
||||
/// </para>
|
||||
/// </remarks>
|
||||
public static bool DirectRendering
|
||||
{
|
||||
get { return direct_rendering; }
|
||||
set { direct_rendering = value; }
|
||||
}
|
||||
public static bool DirectRendering { get; set; } = true;
|
||||
|
||||
/// <summary>
|
||||
/// Gets or sets a System.Boolean, indicating whether automatic error checking should be performed.
|
||||
|
@ -417,11 +411,7 @@ namespace OpenTK.Graphics
|
|||
/// </summary>
|
||||
/// <remarks>Automatic error checking will clear the OpenGL error state. Set CheckErrors to false if you use
|
||||
/// the OpenGL error state in your code flow (e.g. for checking supported texture formats).</remarks>
|
||||
public bool ErrorChecking
|
||||
{
|
||||
get { return check_errors; }
|
||||
set { check_errors = value; }
|
||||
}
|
||||
public bool ErrorChecking { get; set; } = true;
|
||||
|
||||
/// <summary>
|
||||
/// Swaps buffers on a context. This presents the rendered scene to the user.
|
||||
|
|
|
@ -36,8 +36,6 @@ namespace OpenTK.Graphics
|
|||
// Provides the foundation for all IGraphicsContext implementations.
|
||||
abstract class GraphicsContextBase : IGraphicsContext, IGraphicsContextInternal, IEquatable<IGraphicsContextInternal>
|
||||
{
|
||||
bool disposed;
|
||||
|
||||
protected ContextHandle Handle;
|
||||
protected GraphicsMode Mode;
|
||||
|
||||
|
@ -47,11 +45,7 @@ namespace OpenTK.Graphics
|
|||
|
||||
public abstract bool IsCurrent { get; }
|
||||
|
||||
public bool IsDisposed
|
||||
{
|
||||
get { return disposed; }
|
||||
protected set { disposed = value; }
|
||||
}
|
||||
public bool IsDisposed { get; protected set; }
|
||||
|
||||
public bool VSync
|
||||
{
|
||||
|
|
|
@ -34,9 +34,6 @@ namespace OpenTK.Graphics
|
|||
/// </summary>
|
||||
public sealed class GraphicsContextVersion
|
||||
{
|
||||
int minor, major;
|
||||
string vendor = String.Empty, renderer = String.Empty;
|
||||
|
||||
internal GraphicsContextVersion(int minor, int major, string vendor, string renderer)
|
||||
{
|
||||
Minor = minor;
|
||||
|
@ -48,21 +45,21 @@ namespace OpenTK.Graphics
|
|||
/// <summary>
|
||||
/// Gets a System.Int32 indicating the minor version of a GraphicsContext instance.
|
||||
/// </summary>
|
||||
public int Minor { get { return minor; } private set { minor = value; } }
|
||||
public int Minor { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 indicating the major version of a GraphicsContext instance.
|
||||
/// </summary>
|
||||
public int Major { get { return major; } private set { major = value; } }
|
||||
public int Major { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.String indicating the vendor of a GraphicsContext instance.
|
||||
/// </summary>
|
||||
public string Vendor { get { return vendor; } private set { vendor = value; } }
|
||||
public string Vendor { get; private set; } = String.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.String indicating the renderer of a GraphicsContext instance.
|
||||
/// </summary>
|
||||
public string Renderer { get { return renderer; } private set { renderer = value; } }
|
||||
public string Renderer { get; private set; } = String.Empty;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -14,10 +14,7 @@ namespace OpenTK.Graphics
|
|||
/// <summary>Defines the format for graphics operations.</summary>
|
||||
public class GraphicsMode : IEquatable<GraphicsMode>
|
||||
{
|
||||
ColorFormat color_format, accumulator_format;
|
||||
int depth, stencil, buffers, samples;
|
||||
bool stereo;
|
||||
IntPtr? index = null; // The id of the pixel format or visual.
|
||||
int samples;
|
||||
|
||||
static GraphicsMode defaultMode;
|
||||
static readonly object SyncRoot = new object();
|
||||
|
@ -116,64 +113,29 @@ namespace OpenTK.Graphics
|
|||
/// <summary>
|
||||
/// Gets a nullable <see cref="System.IntPtr"/> value, indicating the platform-specific index for this GraphicsMode.
|
||||
/// </summary>
|
||||
public IntPtr? Index
|
||||
{
|
||||
get
|
||||
{
|
||||
return index;
|
||||
}
|
||||
set { index = value; }
|
||||
}
|
||||
public IntPtr? Index { get; set; } = null;
|
||||
|
||||
/// <summary>
|
||||
/// Gets an OpenTK.Graphics.ColorFormat that describes the color format for this GraphicsFormat.
|
||||
/// </summary>
|
||||
public ColorFormat ColorFormat
|
||||
{
|
||||
get
|
||||
{
|
||||
return color_format;
|
||||
}
|
||||
private set { color_format = value; }
|
||||
}
|
||||
public ColorFormat ColorFormat { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets an OpenTK.Graphics.ColorFormat that describes the accumulator format for this GraphicsFormat.
|
||||
/// </summary>
|
||||
public ColorFormat AccumulatorFormat
|
||||
{
|
||||
get
|
||||
{
|
||||
return accumulator_format;
|
||||
}
|
||||
private set { accumulator_format = value; }
|
||||
}
|
||||
public ColorFormat AccumulatorFormat { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 that contains the bits per pixel for the depth buffer
|
||||
/// for this GraphicsFormat.
|
||||
/// </summary>
|
||||
public int Depth
|
||||
{
|
||||
get
|
||||
{
|
||||
return depth;
|
||||
}
|
||||
private set { depth = value; }
|
||||
}
|
||||
public int Depth { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 that contains the bits per pixel for the stencil buffer
|
||||
/// of this GraphicsFormat.
|
||||
/// </summary>
|
||||
public int Stencil
|
||||
{
|
||||
get
|
||||
{
|
||||
return stencil;
|
||||
}
|
||||
private set { stencil = value; }
|
||||
}
|
||||
public int Stencil { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 that contains the number of FSAA samples per pixel for this GraphicsFormat.
|
||||
|
@ -197,27 +159,13 @@ namespace OpenTK.Graphics
|
|||
/// <summary>
|
||||
/// Gets a System.Boolean indicating whether this DisplayMode is stereoscopic.
|
||||
/// </summary>
|
||||
public bool Stereo
|
||||
{
|
||||
get
|
||||
{
|
||||
return stereo;
|
||||
}
|
||||
private set { stereo = value; }
|
||||
}
|
||||
public bool Stereo { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 containing the number of buffers associated with this
|
||||
/// DisplayMode.
|
||||
/// </summary>
|
||||
public int Buffers
|
||||
{
|
||||
get
|
||||
{
|
||||
return buffers;
|
||||
}
|
||||
private set { buffers = value; }
|
||||
}
|
||||
public int Buffers { get; private set; }
|
||||
|
||||
/// <summary>Returns an OpenTK.GraphicsFormat compatible with the underlying platform.</summary>
|
||||
public static GraphicsMode Default
|
||||
|
|
|
@ -37,8 +37,6 @@ namespace OpenTK.Input
|
|||
Buttons buttons;
|
||||
GamePadAxes axes;
|
||||
byte gamepad_type;
|
||||
bool is_connected;
|
||||
bool is_mapped;
|
||||
|
||||
internal GamePadCapabilities(GamePadType type, GamePadAxes axes, Buttons buttons, bool is_connected, bool is_mapped)
|
||||
: this()
|
||||
|
@ -46,8 +44,8 @@ namespace OpenTK.Input
|
|||
gamepad_type = (byte)type;
|
||||
this.axes = axes;
|
||||
this.buttons = buttons;
|
||||
this.is_connected = is_connected;
|
||||
this.is_mapped = is_mapped;
|
||||
this.IsConnected = is_connected;
|
||||
this.IsMapped = is_mapped;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -306,19 +304,13 @@ namespace OpenTK.Input
|
|||
/// currently connected.
|
||||
/// </summary>
|
||||
/// <value><c>true</c> if this instance is currently connected; otherwise, <c>false</c>.</value>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
}
|
||||
public bool IsConnected { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> value describing whether a valid button configuration
|
||||
/// exists for this <c>GamePad</c> in the GamePad configuration database.
|
||||
/// </summary>
|
||||
public bool IsMapped
|
||||
{
|
||||
get { return is_mapped; }
|
||||
}
|
||||
public bool IsMapped { get; }
|
||||
|
||||
/// <param name="left">A <see cref="GamePadCapabilities"/> structure to test for equality.</param>
|
||||
/// <param name="right">A <see cref="GamePadCapabilities"/> structure to test for equality.</param>
|
||||
|
@ -358,8 +350,8 @@ namespace OpenTK.Input
|
|||
{
|
||||
return
|
||||
buttons.GetHashCode() ^
|
||||
is_connected.GetHashCode() ^
|
||||
is_mapped.GetHashCode() ^
|
||||
IsConnected.GetHashCode() ^
|
||||
IsMapped.GetHashCode() ^
|
||||
gamepad_type.GetHashCode();
|
||||
}
|
||||
|
||||
|
@ -386,8 +378,8 @@ namespace OpenTK.Input
|
|||
{
|
||||
return
|
||||
buttons == other.buttons &&
|
||||
is_connected == other.is_connected &&
|
||||
is_mapped == other.is_mapped &&
|
||||
IsConnected == other.IsConnected &&
|
||||
IsMapped == other.IsMapped &&
|
||||
gamepad_type == other.gamepad_type;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -36,22 +36,12 @@ namespace OpenTK.Input
|
|||
{
|
||||
static readonly char[] ConfigurationSeparator = new char[] { ',' };
|
||||
|
||||
Guid guid;
|
||||
string name;
|
||||
readonly List<GamePadConfigurationItem> configuration_items =
|
||||
new List<GamePadConfigurationItem>();
|
||||
|
||||
public Guid Guid
|
||||
{
|
||||
get { return guid; }
|
||||
private set { guid = value; }
|
||||
}
|
||||
public Guid Guid { get; private set; }
|
||||
|
||||
public string Name
|
||||
{
|
||||
get { return name; }
|
||||
private set { name = value; }
|
||||
}
|
||||
public string Name { get; private set; }
|
||||
|
||||
public GamePadConfiguration(string configuration)
|
||||
{
|
||||
|
|
|
@ -31,26 +31,15 @@ namespace OpenTK.Input
|
|||
{
|
||||
class GamePadConfigurationItem
|
||||
{
|
||||
GamePadConfigurationSource source;
|
||||
GamePadConfigurationTarget target;
|
||||
|
||||
public GamePadConfigurationItem(GamePadConfigurationSource source, GamePadConfigurationTarget target)
|
||||
{
|
||||
Source = source;
|
||||
Target = target;
|
||||
}
|
||||
|
||||
public GamePadConfigurationSource Source
|
||||
{
|
||||
get { return source; }
|
||||
private set { source = value; }
|
||||
}
|
||||
public GamePadConfigurationSource Source { get; private set; }
|
||||
|
||||
public GamePadConfigurationTarget Target
|
||||
{
|
||||
get { return target; }
|
||||
private set { target = value; }
|
||||
}
|
||||
public GamePadConfigurationTarget Target { get; private set; }
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -31,7 +31,6 @@ namespace OpenTK.Input
|
|||
{
|
||||
struct GamePadConfigurationSource
|
||||
{
|
||||
ConfigurationType map_type;
|
||||
int? map_button;
|
||||
JoystickAxis? map_axis;
|
||||
JoystickHat? map_hat;
|
||||
|
@ -59,11 +58,7 @@ namespace OpenTK.Input
|
|||
map_hat_position = pos;
|
||||
}
|
||||
|
||||
public ConfigurationType Type
|
||||
{
|
||||
get { return map_type; }
|
||||
private set { map_type = value; }
|
||||
}
|
||||
public ConfigurationType Type { get; private set; }
|
||||
|
||||
public JoystickAxis Axis
|
||||
{
|
||||
|
|
|
@ -31,7 +31,6 @@ namespace OpenTK.Input
|
|||
{
|
||||
struct GamePadConfigurationTarget
|
||||
{
|
||||
ConfigurationType map_type;
|
||||
Nullable<Buttons> map_button;
|
||||
Nullable<GamePadAxes> map_axis;
|
||||
|
||||
|
@ -49,11 +48,7 @@ namespace OpenTK.Input
|
|||
map_axis = axis;
|
||||
}
|
||||
|
||||
public ConfigurationType Type
|
||||
{
|
||||
get { return map_type; }
|
||||
private set { map_type = value; }
|
||||
}
|
||||
public ConfigurationType Type { get; private set; }
|
||||
|
||||
public GamePadAxes Axis
|
||||
{
|
||||
|
|
|
@ -35,14 +35,12 @@ namespace OpenTK.Input
|
|||
const float RangeMultiplier = 1.0f / (short.MaxValue + 1);
|
||||
|
||||
Buttons buttons;
|
||||
int packet_number;
|
||||
short left_stick_x;
|
||||
short left_stick_y;
|
||||
short right_stick_x;
|
||||
short right_stick_y;
|
||||
byte left_trigger;
|
||||
byte right_trigger;
|
||||
bool is_connected;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="GamePadThumbSticks"/> structure describing the
|
||||
|
@ -84,20 +82,14 @@ namespace OpenTK.Input
|
|||
/// Gets a value indicating whether this <c>GamePad</c> instance is connected.
|
||||
/// </summary>
|
||||
/// <value><c>true</c> if this instance is connected; otherwise, <c>false</c>.</value>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
}
|
||||
public bool IsConnected { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the packet number for this <c>GamePadState</c> instance.
|
||||
/// Use the packet number to determine whether the state of a
|
||||
/// <c>GamePad</c> device has changed.
|
||||
/// </summary>
|
||||
public int PacketNumber
|
||||
{
|
||||
get { return packet_number; }
|
||||
}
|
||||
public int PacketNumber { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Returns a <see cref="System.String"/> that represents the current <see cref="OpenTK.Input.GamePadState"/>.
|
||||
|
@ -199,7 +191,7 @@ namespace OpenTK.Input
|
|||
|
||||
internal void SetConnected(bool connected)
|
||||
{
|
||||
is_connected = connected;
|
||||
IsConnected = connected;
|
||||
}
|
||||
|
||||
internal void SetTriggers(byte left, byte right)
|
||||
|
@ -210,7 +202,7 @@ namespace OpenTK.Input
|
|||
|
||||
internal void SetPacketNumber(int number)
|
||||
{
|
||||
packet_number = number;
|
||||
PacketNumber = number;
|
||||
}
|
||||
|
||||
bool IsAxisValid(GamePadAxes axis)
|
||||
|
|
|
@ -40,7 +40,6 @@ namespace OpenTK.Input
|
|||
byte axis_count;
|
||||
byte button_count;
|
||||
byte hat_count;
|
||||
bool is_connected;
|
||||
|
||||
internal JoystickCapabilities(int axis_count, int button_count, int hat_count, bool is_connected)
|
||||
{
|
||||
|
@ -61,12 +60,12 @@ namespace OpenTK.Input
|
|||
this.axis_count = (byte)axis_count;
|
||||
this.button_count = (byte)button_count;
|
||||
this.hat_count = (byte)hat_count;
|
||||
this.is_connected = is_connected;
|
||||
this.IsConnected = is_connected;
|
||||
}
|
||||
|
||||
internal void SetIsConnected(bool value)
|
||||
{
|
||||
is_connected = value;
|
||||
IsConnected = value;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -97,11 +96,7 @@ namespace OpenTK.Input
|
|||
/// Gets a value indicating whether this <see cref="JoystickDevice"/> is connected.
|
||||
/// </summary>
|
||||
/// <value><c>true</c> if this instance is connected; otherwise, <c>false</c>.</value>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
private set { is_connected = value; }
|
||||
}
|
||||
public bool IsConnected { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Returns a <see cref="System.String"/> that represents the current <see cref="OpenTK.Input.JoystickCapabilities"/>.
|
||||
|
|
|
@ -33,10 +33,6 @@ namespace OpenTK.Input
|
|||
/// </summary>
|
||||
public abstract class JoystickDevice : IInputDevice
|
||||
{
|
||||
int id;
|
||||
string description;
|
||||
JoystickAxisCollection axis_collection;
|
||||
JoystickButtonCollection button_collection;
|
||||
JoystickMoveEventArgs move_args = new JoystickMoveEventArgs(0, 0, 0);
|
||||
JoystickButtonEventArgs button_args = new JoystickButtonEventArgs(0, false);
|
||||
|
||||
|
@ -49,28 +45,24 @@ namespace OpenTK.Input
|
|||
throw new ArgumentOutOfRangeException("buttons");
|
||||
|
||||
Id = id;
|
||||
axis_collection = new JoystickAxisCollection(axes);
|
||||
button_collection = new JoystickButtonCollection(buttons);
|
||||
Axis = new JoystickAxisCollection(axes);
|
||||
Button = new JoystickButtonCollection(buttons);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a JoystickAxisCollection containing the state of each axis on this instance. Values are normalized in the [-1, 1] range.
|
||||
/// </summary>
|
||||
public JoystickAxisCollection Axis { get { return axis_collection; } }
|
||||
public JoystickAxisCollection Axis { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets JoystickButtonCollection containing the state of each button on this instance. True indicates that the button is pressed.
|
||||
/// </summary>
|
||||
public JoystickButtonCollection Button { get { return button_collection; } }
|
||||
public JoystickButtonCollection Button { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.String containing a unique description for this instance.
|
||||
/// </summary>
|
||||
public string Description
|
||||
{
|
||||
get { return description; }
|
||||
internal set { description = value; }
|
||||
}
|
||||
public string Description { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating the InputDeviceType of this InputDevice.
|
||||
|
@ -98,31 +90,27 @@ namespace OpenTK.Input
|
|||
public EventHandler<JoystickButtonEventArgs> ButtonUp =
|
||||
delegate(object sender, JoystickButtonEventArgs e) { };
|
||||
|
||||
internal int Id
|
||||
{
|
||||
get { return id; }
|
||||
set { id = value; }
|
||||
}
|
||||
internal int Id { get; set; }
|
||||
|
||||
internal void SetAxis(JoystickAxis axis, float @value)
|
||||
{
|
||||
if ((int)axis < axis_collection.Count)
|
||||
if ((int)axis < Axis.Count)
|
||||
{
|
||||
move_args.Axis = axis;
|
||||
move_args.Delta = move_args.Value - @value;
|
||||
axis_collection[axis] = move_args.Value = @value;
|
||||
Axis[axis] = move_args.Value = @value;
|
||||
Move(this, move_args);
|
||||
}
|
||||
}
|
||||
|
||||
internal void SetButton(int button, bool @value)
|
||||
{
|
||||
if (button < button_collection.Count)
|
||||
if (button < Button.Count)
|
||||
{
|
||||
if (button_collection[button] != @value)
|
||||
if (Button[button] != @value)
|
||||
{
|
||||
button_args.Button = button;
|
||||
button_collection[button] = button_args.Pressed = @value;
|
||||
Button[button] = button_args.Pressed = @value;
|
||||
if (@value)
|
||||
ButtonDown(this, button_args);
|
||||
else
|
||||
|
@ -156,9 +144,6 @@ namespace OpenTK.Input
|
|||
/// </summary>
|
||||
public class JoystickButtonEventArgs : EventArgs
|
||||
{
|
||||
int button;
|
||||
bool pressed;
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="JoystickButtonEventArgs"/> class.
|
||||
/// </summary>
|
||||
|
@ -166,19 +151,19 @@ namespace OpenTK.Input
|
|||
/// <param name="pressed">The current state of the button.</param>
|
||||
internal JoystickButtonEventArgs(int button, bool pressed)
|
||||
{
|
||||
this.button = button;
|
||||
this.pressed = pressed;
|
||||
this.Button = button;
|
||||
this.Pressed = pressed;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// The index of the joystick button for the event.
|
||||
/// </summary>
|
||||
public int Button { get { return this.button; } internal set { this.button = value; } }
|
||||
public int Button { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Boolean representing the state of the button for the event.
|
||||
/// </summary>
|
||||
public bool Pressed { get { return pressed; } internal set { this.pressed = value; } }
|
||||
public bool Pressed { get; internal set; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -187,10 +172,6 @@ namespace OpenTK.Input
|
|||
/// </summary>
|
||||
public class JoystickMoveEventArgs : JoystickEventArgs
|
||||
{
|
||||
JoystickAxis axis;
|
||||
float value;
|
||||
float delta;
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="JoystickMoveEventArgs"/> class.
|
||||
/// </summary>
|
||||
|
@ -199,25 +180,25 @@ namespace OpenTK.Input
|
|||
/// <param name="delta">The relative change in value of the joystick axis.</param>
|
||||
public JoystickMoveEventArgs(JoystickAxis axis, float value, float delta)
|
||||
{
|
||||
this.axis = axis;
|
||||
this.value = value;
|
||||
this.delta = delta;
|
||||
this.Axis = axis;
|
||||
this.Value = value;
|
||||
this.Delta = delta;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Int32 representing the index of the axis that was moved.
|
||||
/// </summary>
|
||||
public JoystickAxis Axis { get { return axis; } internal set { this.axis = value; } }
|
||||
public JoystickAxis Axis { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Single representing the absolute position of the axis.
|
||||
/// </summary>
|
||||
public float Value { get { return value; } internal set { this.value = value; } }
|
||||
public float Value { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Single representing the relative change in the position of the axis.
|
||||
/// </summary>
|
||||
public float Delta { get { return delta; } internal set { this.delta = value; } }
|
||||
public float Delta { get; internal set; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
|
|
@ -34,11 +34,9 @@ namespace OpenTK.Input
|
|||
/// </summary>
|
||||
public struct JoystickHatState : IEquatable<JoystickHatState>
|
||||
{
|
||||
HatPosition position;
|
||||
|
||||
internal JoystickHatState(HatPosition pos)
|
||||
{
|
||||
position = pos;
|
||||
Position = pos;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -46,7 +44,7 @@ namespace OpenTK.Input
|
|||
/// the position of this hat.
|
||||
/// </summary>
|
||||
/// <value>The position.</value>
|
||||
public HatPosition Position { get { return position; } }
|
||||
public HatPosition Position { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> indicating
|
||||
|
|
|
@ -44,14 +44,12 @@ namespace OpenTK.Input
|
|||
|
||||
const float ConversionFactor = 1.0f / (short.MaxValue + 0.5f);
|
||||
|
||||
int packet_number;
|
||||
long buttons;
|
||||
unsafe fixed short axes[MaxAxes];
|
||||
JoystickHatState hat0;
|
||||
JoystickHatState hat1;
|
||||
JoystickHatState hat2;
|
||||
JoystickHatState hat3;
|
||||
bool is_connected;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value between -1.0 and 1.0 representing the current offset of the specified <see cref="JoystickAxis"/>.
|
||||
|
@ -136,10 +134,7 @@ namespace OpenTK.Input
|
|||
/// Gets a value indicating whether this instance is connected.
|
||||
/// </summary>
|
||||
/// <value><c>true</c> if this instance is connected; otherwise, <c>false</c>.</value>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
}
|
||||
public bool IsConnected { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Returns a <see cref="System.String"/> that represents the current <see cref="OpenTK.Input.JoystickState"/>.
|
||||
|
@ -189,10 +184,7 @@ namespace OpenTK.Input
|
|||
Equals((JoystickState)obj);
|
||||
}
|
||||
|
||||
internal int PacketNumber
|
||||
{
|
||||
get { return packet_number; }
|
||||
}
|
||||
internal int PacketNumber { get; private set; }
|
||||
|
||||
internal short GetAxisRaw(JoystickAxis axis)
|
||||
{
|
||||
|
@ -271,12 +263,12 @@ namespace OpenTK.Input
|
|||
|
||||
internal void SetIsConnected(bool value)
|
||||
{
|
||||
is_connected = value;
|
||||
IsConnected = value;
|
||||
}
|
||||
|
||||
internal void SetPacketNumber(int number)
|
||||
{
|
||||
packet_number = number;
|
||||
PacketNumber = number;
|
||||
}
|
||||
|
||||
short GetAxisUnsafe(int index)
|
||||
|
|
|
@ -15,10 +15,8 @@ namespace OpenTK.Input
|
|||
public sealed class KeyboardDevice : IInputDevice
|
||||
{
|
||||
//private IKeyboard keyboard;
|
||||
private string description;
|
||||
private int numKeys, numFKeys, numLeds;
|
||||
|
||||
private IntPtr devID;
|
||||
private bool repeat;
|
||||
private KeyboardState state;
|
||||
|
||||
internal KeyboardDevice() { }
|
||||
|
@ -47,29 +45,17 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets an integer representing the number of keys on this KeyboardDevice.
|
||||
/// </summary>
|
||||
public int NumberOfKeys
|
||||
{
|
||||
get { return numKeys; }
|
||||
internal set { numKeys = value; }
|
||||
}
|
||||
public int NumberOfKeys { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets an integer representing the number of function keys (F-keys) on this KeyboardDevice.
|
||||
/// </summary>
|
||||
public int NumberOfFunctionKeys
|
||||
{
|
||||
get { return numFKeys; }
|
||||
internal set { numFKeys = value; }
|
||||
}
|
||||
public int NumberOfFunctionKeys { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating the number of led indicators on this KeyboardDevice.
|
||||
/// </summary>
|
||||
public int NumberOfLeds
|
||||
{
|
||||
get { return numLeds; }
|
||||
internal set { numLeds = value; }
|
||||
}
|
||||
public int NumberOfLeds { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets an IntPtr representing a device dependent ID.
|
||||
|
@ -96,11 +82,7 @@ namespace OpenTK.Input
|
|||
/// for game input.
|
||||
/// </para>
|
||||
/// </remarks>
|
||||
public bool KeyRepeat
|
||||
{
|
||||
get { return repeat; }
|
||||
set { repeat = value; }
|
||||
}
|
||||
public bool KeyRepeat { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Occurs when a key is pressed.
|
||||
|
@ -115,11 +97,7 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets a <see cref="System.String"/> which describes this instance.
|
||||
/// </summary>
|
||||
public string Description
|
||||
{
|
||||
get { return description; }
|
||||
internal set { description = value; }
|
||||
}
|
||||
public string Description { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the <see cref="InputDeviceType"/> for this instance.
|
||||
|
@ -157,7 +135,7 @@ namespace OpenTK.Input
|
|||
public override int GetHashCode()
|
||||
{
|
||||
//return base.GetHashCode();
|
||||
return (int)(numKeys ^ numFKeys ^ numLeds ^ devID.GetHashCode() ^ description.GetHashCode());
|
||||
return (int)(NumberOfKeys ^ NumberOfFunctionKeys ^ NumberOfLeds ^ devID.GetHashCode() ^ Description.GetHashCode());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
|
|
@ -41,10 +41,6 @@ namespace OpenTK.Input
|
|||
/// </remarks>
|
||||
public class KeyboardKeyEventArgs : EventArgs
|
||||
{
|
||||
Key key;
|
||||
bool repeat;
|
||||
KeyboardState state;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new KeyboardEventArgs instance.
|
||||
/// </summary>
|
||||
|
@ -62,11 +58,7 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets the <see cref="Key"/> that generated this event.
|
||||
/// </summary>
|
||||
public Key Key
|
||||
{
|
||||
get { return key; }
|
||||
internal set { key = value; }
|
||||
}
|
||||
public Key Key { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the scancode which generated this event.
|
||||
|
@ -83,7 +75,7 @@ namespace OpenTK.Input
|
|||
/// <value><c>true</c> if pressed; otherwise, <c>false</c>.</value>
|
||||
public bool Alt
|
||||
{
|
||||
get { return state[Key.AltLeft] || state[Key.AltRight]; }
|
||||
get { return Keyboard[Key.AltLeft] || Keyboard[Key.AltRight]; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -92,7 +84,7 @@ namespace OpenTK.Input
|
|||
/// <value><c>true</c> if pressed; otherwise, <c>false</c>.</value>
|
||||
public bool Control
|
||||
{
|
||||
get { return state[Key.ControlLeft] || state[Key.ControlRight]; }
|
||||
get { return Keyboard[Key.ControlLeft] || Keyboard[Key.ControlRight]; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -101,7 +93,7 @@ namespace OpenTK.Input
|
|||
/// <value><c>true</c> if pressed; otherwise, <c>false</c>.</value>
|
||||
public bool Shift
|
||||
{
|
||||
get { return state[Key.ShiftLeft] || state[Key.ShiftRight]; }
|
||||
get { return Keyboard[Key.ShiftLeft] || Keyboard[Key.ShiftRight]; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -125,11 +117,7 @@ namespace OpenTK.Input
|
|||
/// Gets the current <see cref="OpenTK.Input.KeyboardState"/>.
|
||||
/// </summary>
|
||||
/// <value>The keyboard.</value>
|
||||
public KeyboardState Keyboard
|
||||
{
|
||||
get { return state; }
|
||||
internal set { state = value; }
|
||||
}
|
||||
public KeyboardState Keyboard { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> indicating whether
|
||||
|
@ -140,10 +128,6 @@ namespace OpenTK.Input
|
|||
/// a key; false, if this was caused by the user pressing a
|
||||
/// key for the first time.
|
||||
/// </value>
|
||||
public bool IsRepeat
|
||||
{
|
||||
get { return repeat; }
|
||||
internal set { repeat = value; }
|
||||
}
|
||||
public bool IsRepeat { get; internal set; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -39,7 +39,6 @@ namespace OpenTK.Input
|
|||
const int NumInts = ((int)Key.LastKey + IntSize - 1) / IntSize;
|
||||
// The following line triggers bogus CS0214 in gmcs 2.0.1, sigh...
|
||||
unsafe fixed int Keys[NumInts];
|
||||
bool is_connected;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> indicating whether the specified
|
||||
|
@ -131,11 +130,7 @@ namespace OpenTK.Input
|
|||
/// Gets a <see cref="System.Boolean"/> indicating whether this keyboard
|
||||
/// is connected.
|
||||
/// </summary>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
internal set { is_connected = value; }
|
||||
}
|
||||
public bool IsConnected { get; internal set; }
|
||||
|
||||
#if false
|
||||
// Disabled until the correct cross-platform API can be determined.
|
||||
|
|
|
@ -40,9 +40,7 @@ namespace OpenTK.Input
|
|||
/// </summary>
|
||||
public sealed class MouseDevice : IInputDevice
|
||||
{
|
||||
string description;
|
||||
IntPtr id;
|
||||
int numButtons, numWheels;
|
||||
|
||||
MouseState state;
|
||||
#if COMPAT_REV1519
|
||||
|
@ -53,11 +51,7 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets a string describing this MouseDevice.
|
||||
/// </summary>
|
||||
public string Description
|
||||
{
|
||||
get { return description; }
|
||||
internal set { description = value; }
|
||||
}
|
||||
public string Description { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating the InputDeviceType of this InputDevice.
|
||||
|
@ -104,20 +98,12 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets an integer representing the number of buttons on this MouseDevice.
|
||||
/// </summary>
|
||||
public int NumberOfButtons
|
||||
{
|
||||
get { return numButtons; }
|
||||
internal set { numButtons = value; }
|
||||
}
|
||||
public int NumberOfButtons { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets an integer representing the number of wheels on this MouseDevice.
|
||||
/// </summary>
|
||||
public int NumberOfWheels
|
||||
{
|
||||
get { return numWheels; }
|
||||
internal set { numWheels = value; }
|
||||
}
|
||||
public int NumberOfWheels { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets an IntPtr representing a device dependent ID.
|
||||
|
@ -228,7 +214,7 @@ namespace OpenTK.Input
|
|||
/// <returns></returns>
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return (int)(numButtons ^ numWheels ^ id.GetHashCode() ^ description.GetHashCode());
|
||||
return (int)(NumberOfButtons ^ NumberOfWheels ^ id.GetHashCode() ^ Description.GetHashCode());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
|
|
@ -147,8 +147,6 @@ namespace OpenTK.Input
|
|||
/// </remarks>
|
||||
public class MouseMoveEventArgs : MouseEventArgs
|
||||
{
|
||||
int x_delta, y_delta;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new <see cref="MouseMoveEventArgs"/> instance.
|
||||
/// </summary>
|
||||
|
@ -180,12 +178,12 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets the change in X position produced by this event.
|
||||
/// </summary>
|
||||
public int XDelta { get { return x_delta; } internal set { x_delta = value; } }
|
||||
public int XDelta { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the change in Y position produced by this event.
|
||||
/// </summary>
|
||||
public int YDelta { get { return y_delta; } internal set { y_delta = value; } }
|
||||
public int YDelta { get; internal set; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -200,8 +198,6 @@ namespace OpenTK.Input
|
|||
/// </remarks>
|
||||
public class MouseButtonEventArgs : MouseEventArgs
|
||||
{
|
||||
MouseButton button;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new <see cref="MouseButtonEventArgs"/> instance.
|
||||
/// </summary>
|
||||
|
@ -217,7 +213,7 @@ namespace OpenTK.Input
|
|||
public MouseButtonEventArgs(int x, int y, MouseButton button, bool pressed)
|
||||
: base(x, y)
|
||||
{
|
||||
this.button = button;
|
||||
this.Button = button;
|
||||
this.IsPressed = pressed;
|
||||
}
|
||||
|
||||
|
@ -233,7 +229,7 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets the <see cref="MouseButton"/> that triggered this event.
|
||||
/// </summary>
|
||||
public MouseButton Button { get { return button; } internal set { button = value; } }
|
||||
public MouseButton Button { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets a System.Boolean representing the state of the mouse button for the event.
|
||||
|
@ -257,8 +253,6 @@ namespace OpenTK.Input
|
|||
/// </remarks>
|
||||
public class MouseWheelEventArgs : MouseEventArgs
|
||||
{
|
||||
float delta;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new <see cref="MouseWheelEventArgs"/> instance.
|
||||
/// </summary>
|
||||
|
@ -275,7 +269,7 @@ namespace OpenTK.Input
|
|||
: base(x, y)
|
||||
{
|
||||
Mouse.SetScrollAbsolute(Mouse.Scroll.X, value);
|
||||
this.delta = delta;
|
||||
this.DeltaPrecise = delta;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -297,7 +291,7 @@ namespace OpenTK.Input
|
|||
/// Gets the change in value of the wheel for this event in integer units.
|
||||
/// To support high-precision mice, it is recommended to use <see cref="DeltaPrecise"/> instead.
|
||||
/// </summary>
|
||||
public int Delta { get { return (int)Math.Round(delta, MidpointRounding.AwayFromZero); } }
|
||||
public int Delta { get { return (int)Math.Round(DeltaPrecise, MidpointRounding.AwayFromZero); } }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the precise value of the wheel in floating-point units.
|
||||
|
@ -310,7 +304,7 @@ namespace OpenTK.Input
|
|||
/// <summary>
|
||||
/// Gets the precise change in value of the wheel for this event in floating-point units.
|
||||
/// </summary>
|
||||
public float DeltaPrecise { get { return delta; } internal set { delta = value; } }
|
||||
public float DeltaPrecise { get; internal set; }
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -38,7 +38,6 @@ namespace OpenTK.Input
|
|||
Vector2 position;
|
||||
MouseScroll scroll;
|
||||
ushort buttons;
|
||||
bool is_connected;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a <see cref="System.Boolean"/> indicating whether the specified
|
||||
|
@ -191,11 +190,7 @@ namespace OpenTK.Input
|
|||
/// Gets a value indicating whether this instance is connected.
|
||||
/// </summary>
|
||||
/// <value><c>true</c> if this instance is connected; otherwise, <c>false</c>.</value>
|
||||
public bool IsConnected
|
||||
{
|
||||
get { return is_connected; }
|
||||
internal set { is_connected = value; }
|
||||
}
|
||||
public bool IsConnected { get; internal set; }
|
||||
|
||||
/// <summary>
|
||||
/// Checks whether two <see cref="MouseState" /> instances are equal.
|
||||
|
|
|
@ -33,8 +33,6 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public class KeyPressEventArgs : EventArgs
|
||||
{
|
||||
char key_char;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new instance.
|
||||
/// </summary>
|
||||
|
@ -47,10 +45,6 @@ namespace OpenTK
|
|||
/// <summary>
|
||||
/// Gets a <see cref="System.Char"/> that defines the ASCII character that was typed.
|
||||
/// </summary>
|
||||
public char KeyChar
|
||||
{
|
||||
get { return key_char; }
|
||||
internal set { key_char = value; }
|
||||
}
|
||||
public char KeyChar { get; internal set; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,13 +34,6 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public sealed class MouseCursor : WindowIcon
|
||||
{
|
||||
static readonly MouseCursor default_cursor = new MouseCursor();
|
||||
static readonly MouseCursor empty_cursor = new MouseCursor(
|
||||
0, 0, 16, 16, new byte[16 * 16 * 4]);
|
||||
|
||||
int x;
|
||||
int y;
|
||||
|
||||
MouseCursor()
|
||||
{
|
||||
}
|
||||
|
@ -71,8 +64,8 @@ namespace OpenTK
|
|||
if (hotx < 0 || hotx >= Width || hoty < 0 || hoty >= Height)
|
||||
throw new ArgumentOutOfRangeException();
|
||||
|
||||
x = hotx;
|
||||
y = hoty;
|
||||
X = hotx;
|
||||
Y = hoty;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -100,34 +93,23 @@ namespace OpenTK
|
|||
if (hotx < 0 || hotx >= Width || hoty < 0 || hoty >= Height)
|
||||
throw new ArgumentOutOfRangeException();
|
||||
|
||||
x = hotx;
|
||||
y = hoty;
|
||||
X = hotx;
|
||||
Y = hoty;
|
||||
}
|
||||
|
||||
internal int X { get { return x; } }
|
||||
internal int Y { get { return y; } }
|
||||
internal int X { get; }
|
||||
internal int Y { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the default mouse cursor for this platform.
|
||||
/// </summary>
|
||||
public static MouseCursor Default
|
||||
{
|
||||
get
|
||||
{
|
||||
return default_cursor;
|
||||
}
|
||||
}
|
||||
public static MouseCursor Default { get; } = new MouseCursor();
|
||||
|
||||
/// <summary>
|
||||
/// Gets an empty (invisible) mouse cursor.
|
||||
/// </summary>
|
||||
public static MouseCursor Empty
|
||||
{
|
||||
get
|
||||
{
|
||||
return empty_cursor;
|
||||
}
|
||||
}
|
||||
public static MouseCursor Empty { get; } = new MouseCursor(
|
||||
0, 0, 16, 16, new byte[16 * 16 * 4]);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -46,7 +46,7 @@ namespace OpenTK
|
|||
|
||||
private readonly INativeWindow implementation;
|
||||
|
||||
private bool disposed, events;
|
||||
private bool events;
|
||||
private bool cursor_visible = true;
|
||||
private bool previous_cursor_visible = true;
|
||||
|
||||
|
@ -619,11 +619,7 @@ namespace OpenTK
|
|||
/// Gets or sets a <see cref="System.Boolean"/>, which indicates whether
|
||||
/// this instance has been disposed.
|
||||
/// </summary>
|
||||
protected bool IsDisposed
|
||||
{
|
||||
get { return disposed; }
|
||||
set { disposed = value; }
|
||||
}
|
||||
protected bool IsDisposed { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Called when the NativeWindow has closed.
|
||||
|
|
|
@ -22,7 +22,6 @@ namespace OpenTK.Platform.Dummy
|
|||
{
|
||||
readonly GraphicsContext.GetAddressDelegate Loader;
|
||||
|
||||
int swap_interval;
|
||||
static int handle_count;
|
||||
Thread current_thread;
|
||||
|
||||
|
@ -77,17 +76,7 @@ namespace OpenTK.Platform.Dummy
|
|||
return Loader(str);
|
||||
}
|
||||
|
||||
public override int SwapInterval
|
||||
{
|
||||
get
|
||||
{
|
||||
return swap_interval;
|
||||
}
|
||||
set
|
||||
{
|
||||
swap_interval = value;
|
||||
}
|
||||
}
|
||||
public override int SwapInterval { get; set; }
|
||||
|
||||
public override void Update(IWindowInfo window)
|
||||
{ }
|
||||
|
|
|
@ -53,18 +53,14 @@ namespace OpenTK.Platform.Egl
|
|||
|
||||
internal class AngleWindowInfo : IAngleWindowInfoInternal
|
||||
{
|
||||
private readonly IWindowInfo _platform_window;
|
||||
private bool _disposed;
|
||||
|
||||
public AngleWindowInfo(IWindowInfo platform_window)
|
||||
{
|
||||
_platform_window = platform_window;
|
||||
PlatformWindow = platform_window;
|
||||
}
|
||||
|
||||
public IWindowInfo PlatformWindow
|
||||
{
|
||||
get { return _platform_window; }
|
||||
}
|
||||
public IWindowInfo PlatformWindow { get; }
|
||||
|
||||
public IWindowInfo WindowInfo
|
||||
{
|
||||
|
@ -75,7 +71,7 @@ namespace OpenTK.Platform.Egl
|
|||
{
|
||||
get
|
||||
{
|
||||
var win_win = _platform_window as WinWindowInfo;
|
||||
var win_win = PlatformWindow as WinWindowInfo;
|
||||
if (win_win != null)
|
||||
{
|
||||
return win_win.DeviceContext;
|
||||
|
@ -104,7 +100,7 @@ namespace OpenTK.Platform.Egl
|
|||
|
||||
public IntPtr Handle
|
||||
{
|
||||
get { return _platform_window.Handle; }
|
||||
get { return PlatformWindow.Handle; }
|
||||
}
|
||||
|
||||
~AngleWindowInfo()
|
||||
|
@ -120,7 +116,7 @@ namespace OpenTK.Platform.Egl
|
|||
}
|
||||
if (!called_from_finalizer)
|
||||
{
|
||||
_platform_window.Dispose();
|
||||
PlatformWindow.Dispose();
|
||||
}
|
||||
// dispose unmanaged
|
||||
|
||||
|
|
|
@ -34,8 +34,6 @@ namespace OpenTK.Platform.Egl
|
|||
// Holds information about an EGL window.
|
||||
class EglWindowInfo : IWindowInfo
|
||||
{
|
||||
IntPtr handle;
|
||||
IntPtr display;
|
||||
IntPtr surface;
|
||||
bool disposed;
|
||||
|
||||
|
@ -63,9 +61,9 @@ namespace OpenTK.Platform.Egl
|
|||
}
|
||||
}
|
||||
|
||||
public IntPtr Handle { get { return handle; } set { handle = value; } }
|
||||
public IntPtr Handle { get; set; }
|
||||
|
||||
public IntPtr Display { get { return display; } private set { display = value; } }
|
||||
public IntPtr Display { get; private set; }
|
||||
|
||||
public IntPtr Surface { get { return surface; } private set { surface = value; } }
|
||||
|
||||
|
|
|
@ -34,9 +34,6 @@ namespace OpenTK.Platform
|
|||
sealed class Factory : IPlatformFactory
|
||||
{
|
||||
private bool disposed;
|
||||
private static IPlatformFactory defaultImplementation;
|
||||
private static IPlatformFactory embeddedImplementation;
|
||||
private static IPlatformFactory angleImplementation;
|
||||
|
||||
static Factory()
|
||||
{
|
||||
|
@ -112,73 +109,61 @@ namespace OpenTK.Platform
|
|||
Default = Embedded;
|
||||
}
|
||||
|
||||
public static IPlatformFactory Default
|
||||
{
|
||||
get { return defaultImplementation; }
|
||||
private set { defaultImplementation = value; }
|
||||
}
|
||||
public static IPlatformFactory Default { get; private set; }
|
||||
|
||||
public static IPlatformFactory Embedded
|
||||
{
|
||||
get { return embeddedImplementation; }
|
||||
private set { embeddedImplementation = value; }
|
||||
}
|
||||
public static IPlatformFactory Embedded { get; private set; }
|
||||
|
||||
public static IPlatformFactory Angle
|
||||
{
|
||||
get { return angleImplementation; }
|
||||
private set { angleImplementation = value; }
|
||||
}
|
||||
public static IPlatformFactory Angle { get; private set; }
|
||||
|
||||
public INativeWindow CreateNativeWindow(int x, int y, int width, int height, string title,
|
||||
GraphicsMode mode, GameWindowFlags options, DisplayDevice device)
|
||||
{
|
||||
return defaultImplementation.CreateNativeWindow(x, y, width, height, title, mode, options, device);
|
||||
return Default.CreateNativeWindow(x, y, width, height, title, mode, options, device);
|
||||
}
|
||||
|
||||
public IDisplayDeviceDriver CreateDisplayDeviceDriver()
|
||||
{
|
||||
return defaultImplementation.CreateDisplayDeviceDriver();
|
||||
return Default.CreateDisplayDeviceDriver();
|
||||
}
|
||||
|
||||
public IGraphicsContext CreateGLContext(GraphicsMode mode, IWindowInfo window, IGraphicsContext shareContext, bool directRendering, int major, int minor, GraphicsContextFlags flags)
|
||||
{
|
||||
return defaultImplementation.CreateGLContext(mode, window, shareContext, directRendering, major, minor, flags);
|
||||
return Default.CreateGLContext(mode, window, shareContext, directRendering, major, minor, flags);
|
||||
}
|
||||
|
||||
public IGraphicsContext CreateGLContext(ContextHandle handle, IWindowInfo window, IGraphicsContext shareContext, bool directRendering, int major, int minor, GraphicsContextFlags flags)
|
||||
{
|
||||
return defaultImplementation.CreateGLContext(handle, window, shareContext, directRendering, major, minor, flags);
|
||||
return Default.CreateGLContext(handle, window, shareContext, directRendering, major, minor, flags);
|
||||
}
|
||||
|
||||
public GraphicsContext.GetCurrentContextDelegate CreateGetCurrentGraphicsContext()
|
||||
{
|
||||
return defaultImplementation.CreateGetCurrentGraphicsContext();
|
||||
return Default.CreateGetCurrentGraphicsContext();
|
||||
}
|
||||
|
||||
public IKeyboardDriver2 CreateKeyboardDriver()
|
||||
{
|
||||
return defaultImplementation.CreateKeyboardDriver();
|
||||
return Default.CreateKeyboardDriver();
|
||||
}
|
||||
|
||||
public IMouseDriver2 CreateMouseDriver()
|
||||
{
|
||||
return defaultImplementation.CreateMouseDriver();
|
||||
return Default.CreateMouseDriver();
|
||||
}
|
||||
|
||||
public IGamePadDriver CreateGamePadDriver()
|
||||
{
|
||||
return defaultImplementation.CreateGamePadDriver();
|
||||
return Default.CreateGamePadDriver();
|
||||
}
|
||||
|
||||
public IJoystickDriver2 CreateJoystickDriver()
|
||||
{
|
||||
return defaultImplementation.CreateJoystickDriver();
|
||||
return Default.CreateJoystickDriver();
|
||||
}
|
||||
|
||||
public void RegisterResource(IDisposable resource)
|
||||
{
|
||||
defaultImplementation.RegisterResource(resource);
|
||||
Default.RegisterResource(resource);
|
||||
}
|
||||
|
||||
class UnsupportedPlatform : PlatformFactoryBase
|
||||
|
|
|
@ -214,14 +214,12 @@ namespace OpenTK.Platform.Linux
|
|||
[StructLayout(LayoutKind.Sequential)]
|
||||
struct KeyboardEvent
|
||||
{
|
||||
IntPtr @event;
|
||||
|
||||
public IntPtr BaseEvent { get { return GetBaseEvent(@event); } }
|
||||
public IntPtr Event { get { return @event; } }
|
||||
public uint Time { get { return GetTime(@event); } }
|
||||
public uint Key { get { return GetKey(@event); } }
|
||||
public uint KeyCount { get { return GetSeatKeyCount(@event); } }
|
||||
public KeyState KeyState { get { return GetKeyState(@event); } }
|
||||
public IntPtr BaseEvent { get { return GetBaseEvent(Event); } }
|
||||
public IntPtr Event { get; }
|
||||
public uint Time { get { return GetTime(Event); } }
|
||||
public uint Key { get { return GetKey(Event); } }
|
||||
public uint KeyCount { get { return GetSeatKeyCount(Event); } }
|
||||
public KeyState KeyState { get { return GetKeyState(Event); } }
|
||||
|
||||
[DllImport(LibInput.lib, EntryPoint = "libinput_event_keyboard_get_time", CallingConvention = CallingConvention.Cdecl)]
|
||||
static extern uint GetTime(IntPtr @event);
|
||||
|
@ -243,22 +241,20 @@ namespace OpenTK.Platform.Linux
|
|||
[StructLayout(LayoutKind.Sequential)]
|
||||
struct PointerEvent
|
||||
{
|
||||
IntPtr @event;
|
||||
|
||||
public IntPtr BaseEvent { get { return GetBaseEvent(@event); } }
|
||||
public IntPtr Event { get { return @event; } }
|
||||
public uint Time { get { return GetTime(@event); } }
|
||||
public EvdevButton Button { get { return (EvdevButton)GetButton(@event); } }
|
||||
public uint ButtonCount { get { return GetButtonCount(@event); } }
|
||||
public ButtonState ButtonState { get { return GetButtonState(@event); } }
|
||||
public bool HasAxis(PointerAxis axis) { return HasAxis(@event, axis) != 0; }
|
||||
public double AxisValue(PointerAxis axis) { return GetAxisValue(@event, axis); }
|
||||
public double DeltaX { get { return GetDX(@event); } }
|
||||
public double DeltaY { get { return GetDY(@event); } }
|
||||
public double X { get { return GetAbsX(@event); } }
|
||||
public double Y { get { return GetAbsY(@event); } }
|
||||
public double TransformedX(int width) { return GetAbsXTransformed(@event, width); }
|
||||
public double TransformedY(int height) { return GetAbsYTransformed(@event, height); }
|
||||
public IntPtr BaseEvent { get { return GetBaseEvent(Event); } }
|
||||
public IntPtr Event { get; }
|
||||
public uint Time { get { return GetTime(Event); } }
|
||||
public EvdevButton Button { get { return (EvdevButton)GetButton(Event); } }
|
||||
public uint ButtonCount { get { return GetButtonCount(Event); } }
|
||||
public ButtonState ButtonState { get { return GetButtonState(Event); } }
|
||||
public bool HasAxis(PointerAxis axis) { return HasAxis(Event, axis) != 0; }
|
||||
public double AxisValue(PointerAxis axis) { return GetAxisValue(Event, axis); }
|
||||
public double DeltaX { get { return GetDX(Event); } }
|
||||
public double DeltaY { get { return GetDY(Event); } }
|
||||
public double X { get { return GetAbsX(Event); } }
|
||||
public double Y { get { return GetAbsY(Event); } }
|
||||
public double TransformedX(int width) { return GetAbsXTransformed(Event, width); }
|
||||
public double TransformedY(int height) { return GetAbsYTransformed(Event, height); }
|
||||
|
||||
[DllImport(LibInput.lib, EntryPoint = "libinput_event_pointer_get_time", CallingConvention = CallingConvention.Cdecl)]
|
||||
static extern uint GetTime(IntPtr @event);
|
||||
|
|
|
@ -36,15 +36,8 @@ namespace OpenTK.Platform.MacOS
|
|||
/// </summary>
|
||||
sealed class CarbonWindowInfo : IWindowInfo
|
||||
{
|
||||
IntPtr windowRef;
|
||||
bool ownHandle = false;
|
||||
bool disposed = false;
|
||||
bool isControl = true;
|
||||
bool goFullScreenHack = false;
|
||||
bool goWindowedHack = false;
|
||||
|
||||
GetInt xOffset;
|
||||
GetInt yOffset;
|
||||
|
||||
/// <summary>
|
||||
/// Constructs a new instance with the specified parameters.
|
||||
|
@ -54,44 +47,30 @@ namespace OpenTK.Platform.MacOS
|
|||
/// <param name="isControl"></param>
|
||||
public CarbonWindowInfo(IntPtr windowRef, bool ownHandle, bool isControl)
|
||||
{
|
||||
this.windowRef = windowRef;
|
||||
this.Handle = windowRef;
|
||||
this.ownHandle = ownHandle;
|
||||
this.isControl = isControl;
|
||||
this.IsControl = isControl;
|
||||
}
|
||||
|
||||
public CarbonWindowInfo(IntPtr windowRef, bool ownHandle, bool isControl, GetInt getX, GetInt getY) : this(windowRef, ownHandle, isControl)
|
||||
{
|
||||
this.xOffset = getX;
|
||||
this.yOffset = getY;
|
||||
this.XOffset = getX;
|
||||
this.YOffset = getY;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets the window reference for this instance.
|
||||
/// </summary>
|
||||
public IntPtr Handle
|
||||
{
|
||||
get { return this.windowRef; }
|
||||
set { this.windowRef = value; }
|
||||
}
|
||||
public IntPtr Handle { get; set; }
|
||||
|
||||
internal bool GoFullScreenHack
|
||||
{
|
||||
get { return goFullScreenHack; }
|
||||
set { goFullScreenHack = value; }
|
||||
}
|
||||
internal bool GoWindowedHack
|
||||
{
|
||||
get { return goWindowedHack; }
|
||||
set { goWindowedHack = value; }
|
||||
}
|
||||
internal bool GoFullScreenHack { get; set; } = false;
|
||||
|
||||
internal bool GoWindowedHack { get; set; } = false;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating whether this instance refers to a System.Windows.Forms.Control.
|
||||
/// </summary>
|
||||
public bool IsControl
|
||||
{
|
||||
get { return isControl; }
|
||||
}
|
||||
public bool IsControl { get; } = true;
|
||||
|
||||
/// <summary>Returns a System.String that represents the current window.</summary>
|
||||
/// <returns>A System.String that represents the current window.</returns>
|
||||
|
@ -105,16 +84,10 @@ namespace OpenTK.Platform.MacOS
|
|||
// (e.g. MonoGame)
|
||||
public IntPtr WindowHandle { get { return Handle; } set { Handle = value; } }
|
||||
|
||||
public GetInt XOffset
|
||||
{
|
||||
get { return xOffset; }
|
||||
set { xOffset = value; }
|
||||
}
|
||||
public GetInt YOffset
|
||||
{
|
||||
get { return yOffset; }
|
||||
set { yOffset = value; }
|
||||
}
|
||||
public GetInt XOffset { get; set; }
|
||||
|
||||
public GetInt YOffset { get; set; }
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
Dispose(true);
|
||||
|
@ -132,7 +105,7 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
if (ownHandle)
|
||||
{
|
||||
windowRef = IntPtr.Zero;
|
||||
Handle = IntPtr.Zero;
|
||||
}
|
||||
|
||||
disposed = true;
|
||||
|
|
|
@ -41,33 +41,27 @@ namespace OpenTK.Platform.MacOS
|
|||
// However, NSFloat is used internally in places where this precision loss does not matter.
|
||||
struct NSFloat
|
||||
{
|
||||
IntPtr value;
|
||||
private IntPtr _value;
|
||||
|
||||
public IntPtr Value
|
||||
{
|
||||
get
|
||||
{
|
||||
return value;
|
||||
}
|
||||
set
|
||||
{
|
||||
this.value = value;
|
||||
}
|
||||
get { return _value; }
|
||||
set { _value = value; }
|
||||
}
|
||||
|
||||
public static implicit operator NSFloat(float v)
|
||||
{
|
||||
NSFloat f;
|
||||
NSFloat f = new NSFloat();
|
||||
unsafe
|
||||
{
|
||||
if (IntPtr.Size == 4)
|
||||
{
|
||||
f.value = *(IntPtr*)&v;
|
||||
f.Value = *(IntPtr*)&v;
|
||||
}
|
||||
else
|
||||
{
|
||||
double d = v;
|
||||
f.value = *(IntPtr*)&d;
|
||||
f.Value = *(IntPtr*)&d;
|
||||
}
|
||||
}
|
||||
return f;
|
||||
|
@ -75,17 +69,17 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
public static implicit operator NSFloat(double v)
|
||||
{
|
||||
NSFloat f;
|
||||
NSFloat f = new NSFloat();
|
||||
unsafe
|
||||
{
|
||||
if (IntPtr.Size == 4)
|
||||
{
|
||||
float fv = (float)v;
|
||||
f.value = *(IntPtr*)&fv;
|
||||
f.Value = *(IntPtr*)&fv;
|
||||
}
|
||||
else
|
||||
{
|
||||
f.value = *(IntPtr*)&v;
|
||||
f.Value = *(IntPtr*)&v;
|
||||
}
|
||||
}
|
||||
return f;
|
||||
|
@ -97,11 +91,11 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
if (IntPtr.Size == 4)
|
||||
{
|
||||
return *(float*)&f.value;
|
||||
return *(float*)f._value;
|
||||
}
|
||||
else
|
||||
{
|
||||
return (float)*(double*)&f.value;
|
||||
return (float)*(double*)&f._value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -112,11 +106,11 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
if (IntPtr.Size == 4)
|
||||
{
|
||||
return (double)*(float*)&f.value;
|
||||
return (double)*(float*)&f._value;
|
||||
}
|
||||
else
|
||||
{
|
||||
return *(double*)&f.value;
|
||||
return *(double*)&f._value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,9 +40,6 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
static readonly IntPtr selContentView = Selector.Get("contentView");
|
||||
|
||||
IntPtr nsWindowRef;
|
||||
IntPtr nsViewRef;
|
||||
|
||||
bool disposed = false;
|
||||
|
||||
/// <summary>
|
||||
|
@ -62,26 +59,26 @@ namespace OpenTK.Platform.MacOS
|
|||
/// <param name="nsViewRef">A valid NSView reference.</param>
|
||||
public CocoaWindowInfo(IntPtr nsWindowRef, IntPtr nsViewRef)
|
||||
{
|
||||
this.nsWindowRef = nsWindowRef;
|
||||
this.nsViewRef = nsViewRef;
|
||||
this.Handle = nsWindowRef;
|
||||
this.ViewHandle = nsViewRef;
|
||||
Cocoa.SendVoid(nsWindowRef, Selector.Retain);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets the window reference for this instance.
|
||||
/// </summary>
|
||||
public IntPtr Handle { get { return nsWindowRef; } }
|
||||
public IntPtr Handle { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the view reference for this instance.
|
||||
/// </summary>
|
||||
public IntPtr ViewHandle { get { return nsViewRef; } }
|
||||
public IntPtr ViewHandle { get; }
|
||||
|
||||
/// <summary>Returns a System.String that represents the current window.</summary>
|
||||
/// <returns>A System.String that represents the current window.</returns>
|
||||
public override string ToString()
|
||||
{
|
||||
return String.Format("MacOS.CocoaWindowInfo: NSWindow {0}, NSView {1}", nsWindowRef, nsViewRef);
|
||||
return String.Format("MacOS.CocoaWindowInfo: NSWindow {0}, NSView {1}", Handle, ViewHandle);
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
|
@ -96,11 +93,11 @@ namespace OpenTK.Platform.MacOS
|
|||
|
||||
if (disposing)
|
||||
{
|
||||
Cocoa.SendVoid(nsWindowRef, Selector.Release);
|
||||
Cocoa.SendVoid(Handle, Selector.Release);
|
||||
}
|
||||
else
|
||||
{
|
||||
Debug.Print("CocoaWindowInfo:{0} leaked, did you forget to call Dispose()?", nsWindowRef);
|
||||
Debug.Print("CocoaWindowInfo:{0} leaked, did you forget to call Dispose()?", Handle);
|
||||
}
|
||||
|
||||
disposed = true;
|
||||
|
|
|
@ -31,30 +31,25 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
internal class MacOSException : Exception
|
||||
{
|
||||
OSStatus errorCode;
|
||||
|
||||
public MacOSException()
|
||||
{}
|
||||
public MacOSException(OSStatus errorCode)
|
||||
: base("Error Code " + ((int)errorCode).ToString() + ": " + errorCode.ToString())
|
||||
{
|
||||
this.errorCode = errorCode;
|
||||
this.ErrorCode = errorCode;
|
||||
}
|
||||
public MacOSException(OSStatus errorCode, string message)
|
||||
: base(message)
|
||||
{
|
||||
this.errorCode = errorCode;
|
||||
this.ErrorCode = errorCode;
|
||||
}
|
||||
internal MacOSException(int errorCode, string message)
|
||||
: base(message)
|
||||
{
|
||||
this.errorCode = (OSStatus)errorCode;
|
||||
this.ErrorCode = (OSStatus)errorCode;
|
||||
}
|
||||
|
||||
public OSStatus ErrorCode
|
||||
{
|
||||
get { return errorCode; }
|
||||
}
|
||||
public OSStatus ErrorCode { get; }
|
||||
}
|
||||
|
||||
internal enum OSStatus
|
||||
|
|
|
@ -41,17 +41,16 @@ namespace OpenTK.Platform.MacOS.Carbon
|
|||
|
||||
struct CFArray
|
||||
{
|
||||
IntPtr arrayRef;
|
||||
public IntPtr Ref { get { return arrayRef; } set { arrayRef = value; } }
|
||||
public IntPtr Ref { get; set; }
|
||||
|
||||
public CFArray(IntPtr reference)
|
||||
{
|
||||
arrayRef = reference;
|
||||
Ref = reference;
|
||||
}
|
||||
|
||||
public int Count
|
||||
{
|
||||
get { return CF.CFArrayGetCount(arrayRef); }
|
||||
get { return CF.CFArrayGetCount(Ref); }
|
||||
}
|
||||
public IntPtr this[int index]
|
||||
{
|
||||
|
@ -60,7 +59,7 @@ namespace OpenTK.Platform.MacOS.Carbon
|
|||
if (index >= Count || index < 0)
|
||||
throw new IndexOutOfRangeException();
|
||||
|
||||
return CF.CFArrayGetValueAtIndex(arrayRef, index);
|
||||
return CF.CFArrayGetValueAtIndex(Ref, index);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -69,24 +68,23 @@ namespace OpenTK.Platform.MacOS.Carbon
|
|||
{
|
||||
public CFDictionary(IntPtr reference)
|
||||
{
|
||||
dictionaryRef = reference;
|
||||
Ref = reference;
|
||||
}
|
||||
|
||||
IntPtr dictionaryRef;
|
||||
public IntPtr Ref { get { return dictionaryRef; } set { dictionaryRef = value; } }
|
||||
public IntPtr Ref { get; set; }
|
||||
|
||||
public int Count
|
||||
{
|
||||
get
|
||||
{
|
||||
return CF.CFDictionaryGetCount(dictionaryRef);
|
||||
return CF.CFDictionaryGetCount(Ref);
|
||||
}
|
||||
}
|
||||
|
||||
public double GetNumberValue(string key)
|
||||
{
|
||||
double retval;
|
||||
IntPtr cfnum = CF.CFDictionaryGetValue(dictionaryRef,
|
||||
IntPtr cfnum = CF.CFDictionaryGetValue(Ref,
|
||||
CF.CFSTR(key));
|
||||
|
||||
CF.CFNumberGetValue(cfnum, CF.CFNumberType.kCFNumberDoubleType, out retval);
|
||||
|
|
|
@ -23,7 +23,6 @@ namespace OpenTK.Platform.Windows
|
|||
{
|
||||
static readonly object LoadLock = new object();
|
||||
|
||||
IntPtr device_context;
|
||||
bool vsync_supported;
|
||||
bool vsync_tear_supported;
|
||||
|
||||
|
@ -262,12 +261,12 @@ namespace OpenTK.Platform.Windows
|
|||
throw new ArgumentException("window", "Must point to a valid window.");
|
||||
|
||||
success = Wgl.MakeCurrent(wnd.DeviceContext, Handle.Handle);
|
||||
device_context = wnd.DeviceContext;
|
||||
DeviceContext = wnd.DeviceContext;
|
||||
}
|
||||
else
|
||||
{
|
||||
success = Wgl.MakeCurrent(IntPtr.Zero, IntPtr.Zero);
|
||||
device_context = IntPtr.Zero;
|
||||
DeviceContext = IntPtr.Zero;
|
||||
}
|
||||
|
||||
if (!success)
|
||||
|
@ -387,13 +386,7 @@ namespace OpenTK.Platform.Windows
|
|||
return mode;
|
||||
}
|
||||
|
||||
internal IntPtr DeviceContext
|
||||
{
|
||||
get
|
||||
{
|
||||
return device_context;
|
||||
}
|
||||
}
|
||||
internal IntPtr DeviceContext { get; private set; }
|
||||
|
||||
/// <summary>Returns a System.String describing this OpenGL context.</summary>
|
||||
/// <returns>A System.String describing this OpenGL context.</returns>
|
||||
|
|
|
@ -38,9 +38,9 @@ namespace OpenTK.Platform.Windows
|
|||
readonly AutoResetEvent InputReady = new AutoResetEvent(false);
|
||||
|
||||
IntPtr OldWndProc;
|
||||
INativeWindow native;
|
||||
|
||||
protected INativeWindow Native { get { return native; } private set { native = value; } }
|
||||
protected INativeWindow Native { get; private set; }
|
||||
|
||||
protected WinWindowInfo Parent { get { return (WinWindowInfo)Native.WindowInfo; } }
|
||||
|
||||
static readonly IntPtr Unhandled = new IntPtr(-1);
|
||||
|
|
|
@ -36,7 +36,6 @@ namespace OpenTK.Platform.Windows
|
|||
sealed class WinWindowInfo : IWindowInfo
|
||||
{
|
||||
IntPtr handle, dc;
|
||||
WinWindowInfo parent;
|
||||
bool disposed;
|
||||
|
||||
/// <summary>
|
||||
|
@ -54,7 +53,7 @@ namespace OpenTK.Platform.Windows
|
|||
public WinWindowInfo(IntPtr handle, WinWindowInfo parent)
|
||||
{
|
||||
this.handle = handle;
|
||||
this.parent = parent;
|
||||
this.Parent = parent;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -65,7 +64,7 @@ namespace OpenTK.Platform.Windows
|
|||
/// <summary>
|
||||
/// Gets or sets the Parent of the window (may be null).
|
||||
/// </summary>
|
||||
public WinWindowInfo Parent { get { return parent; } set { parent = value; } }
|
||||
public WinWindowInfo Parent { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Gets the device context for this window instance.
|
||||
|
@ -132,8 +131,8 @@ namespace OpenTK.Platform.Windows
|
|||
|
||||
if (manual)
|
||||
{
|
||||
if (parent != null)
|
||||
parent.Dispose();
|
||||
if (Parent != null)
|
||||
Parent.Dispose();
|
||||
}
|
||||
|
||||
disposed = true;
|
||||
|
|
|
@ -67,15 +67,14 @@ namespace OpenTK.Platform.X11
|
|||
private const string _dll_name = "libX11";
|
||||
private const string _dll_name_vid = "libXxf86vm";
|
||||
|
||||
static Display defaultDisplay;
|
||||
static int defaultScreen;
|
||||
static Window rootWindow;
|
||||
static int screenCount;
|
||||
|
||||
internal static Display DefaultDisplay { get { return defaultDisplay; } }
|
||||
static int DefaultScreen { get { return defaultScreen; } }
|
||||
internal static Display DefaultDisplay { get; private set; }
|
||||
|
||||
private static int DefaultScreen { get; set; }
|
||||
|
||||
//internal static Window RootWindow { get { return rootWindow; } }
|
||||
internal static int ScreenCount { get { return screenCount; } }
|
||||
internal static int ScreenCount { get; }
|
||||
|
||||
internal static object Lock = new object();
|
||||
|
||||
|
@ -84,14 +83,14 @@ namespace OpenTK.Platform.X11
|
|||
int has_threaded_x = Functions.XInitThreads();
|
||||
Debug.Print("Initializing threaded X11: {0}.", has_threaded_x.ToString());
|
||||
|
||||
defaultDisplay = Functions.XOpenDisplay(IntPtr.Zero);
|
||||
DefaultDisplay = Functions.XOpenDisplay(IntPtr.Zero);
|
||||
|
||||
if (defaultDisplay == IntPtr.Zero)
|
||||
if (DefaultDisplay == IntPtr.Zero)
|
||||
throw new PlatformException("Could not establish connection to the X-Server.");
|
||||
|
||||
using (new XLock(defaultDisplay))
|
||||
using (new XLock(DefaultDisplay))
|
||||
{
|
||||
screenCount = Functions.XScreenCount(DefaultDisplay);
|
||||
ScreenCount = Functions.XScreenCount(DefaultDisplay);
|
||||
}
|
||||
Debug.Print("Display connection: {0}, Screen count: {1}", DefaultDisplay, ScreenCount);
|
||||
|
||||
|
@ -100,11 +99,11 @@ namespace OpenTK.Platform.X11
|
|||
|
||||
static void CurrentDomain_ProcessExit(object sender, EventArgs e)
|
||||
{
|
||||
if (defaultDisplay != IntPtr.Zero)
|
||||
if (DefaultDisplay != IntPtr.Zero)
|
||||
{
|
||||
Functions.XCloseDisplay(defaultDisplay);
|
||||
defaultDisplay = IntPtr.Zero;
|
||||
defaultScreen = 0;
|
||||
Functions.XCloseDisplay(DefaultDisplay);
|
||||
DefaultDisplay = IntPtr.Zero;
|
||||
DefaultScreen = 0;
|
||||
rootWindow = IntPtr.Zero;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -36,7 +36,6 @@ namespace OpenTK.Platform.X11
|
|||
readonly X11Mouse mouse = new X11Mouse();
|
||||
readonly X11Keyboard keyboard = new X11Keyboard();
|
||||
readonly Linux.LinuxJoystick joystick = new Linux.LinuxJoystick();
|
||||
readonly IGamePadDriver gamepad = new MappedGamePadDriver();
|
||||
|
||||
internal X11Input()
|
||||
{
|
||||
|
@ -61,13 +60,7 @@ namespace OpenTK.Platform.X11
|
|||
}
|
||||
}
|
||||
|
||||
public IGamePadDriver GamePadDriver
|
||||
{
|
||||
get
|
||||
{
|
||||
return gamepad;
|
||||
}
|
||||
}
|
||||
public IGamePadDriver GamePadDriver { get; } = new MappedGamePadDriver();
|
||||
|
||||
public IJoystickDriver2 JoystickDriver
|
||||
{
|
||||
|
|
|
@ -34,11 +34,8 @@ namespace OpenTK.Platform.X11
|
|||
/// <summary>Describes an X11 window.</summary>
|
||||
sealed class X11WindowInfo : IWindowInfo
|
||||
{
|
||||
IntPtr handle, rootWindow, display;
|
||||
X11WindowInfo parent;
|
||||
int screen;
|
||||
IntPtr handle, display;
|
||||
XVisualInfo visualInfo;
|
||||
EventMask eventMask;
|
||||
|
||||
/// <summary>Constructs a new X11WindowInfo class.</summary>
|
||||
public X11WindowInfo() { }
|
||||
|
@ -51,12 +48,12 @@ namespace OpenTK.Platform.X11
|
|||
public X11WindowInfo(IntPtr handle, X11WindowInfo parent)
|
||||
{
|
||||
this.handle = handle;
|
||||
this.parent = parent;
|
||||
this.Parent = parent;
|
||||
if (parent != null)
|
||||
{
|
||||
this.rootWindow = parent.rootWindow;
|
||||
this.RootWindow = parent.RootWindow;
|
||||
this.display = parent.display;
|
||||
this.screen = parent.screen;
|
||||
this.Screen = parent.Screen;
|
||||
this.visualInfo = parent.visualInfo;
|
||||
}
|
||||
}
|
||||
|
@ -64,13 +61,16 @@ namespace OpenTK.Platform.X11
|
|||
/// <summary>Gets or sets the handle of the window.</summary>
|
||||
public IntPtr Handle { get { return handle; } set { handle = value; } }
|
||||
/// <summary>Gets or sets the parent of the window.</summary>
|
||||
public X11WindowInfo Parent { get { return parent; } set { parent = value; } }
|
||||
public X11WindowInfo Parent { get; set; }
|
||||
|
||||
/// <summary>Gets or sets the X11 root window.</summary>
|
||||
public IntPtr RootWindow { get { return rootWindow; } set { rootWindow = value; } }
|
||||
public IntPtr RootWindow { get; set; }
|
||||
|
||||
/// <summary>Gets or sets the connection to the X11 display.</summary>
|
||||
public IntPtr Display { get { return display; } set { display = value; } }
|
||||
/// <summary>Gets or sets the X11 screen.</summary>
|
||||
public int Screen { get { return screen; } set { screen = value; } }
|
||||
public int Screen { get; set; }
|
||||
|
||||
/// <summary>Gets or sets the X11 VisualInfo.</summary>
|
||||
public XVisualInfo VisualInfo
|
||||
{
|
||||
|
@ -84,7 +84,7 @@ namespace OpenTK.Platform.X11
|
|||
}
|
||||
}
|
||||
/// <summary>Gets or sets the X11 EventMask.</summary>
|
||||
public EventMask EventMask { get { return eventMask; } set { eventMask = value; } }
|
||||
public EventMask EventMask { get; set; }
|
||||
|
||||
// For compatibility with whoever thought it would be
|
||||
// a good idea to access internal APIs through reflection
|
||||
|
|
|
@ -35,7 +35,6 @@ namespace OpenTK.Platform.X11
|
|||
{
|
||||
readonly XI2MouseKeyboard mouse_keyboard = new XI2MouseKeyboard();
|
||||
readonly Linux.LinuxJoystick joystick = new Linux.LinuxJoystick();
|
||||
readonly IGamePadDriver gamepad = new MappedGamePadDriver();
|
||||
|
||||
internal XI2Input()
|
||||
{
|
||||
|
@ -58,13 +57,7 @@ namespace OpenTK.Platform.X11
|
|||
}
|
||||
}
|
||||
|
||||
public IGamePadDriver GamePadDriver
|
||||
{
|
||||
get
|
||||
{
|
||||
return gamepad;
|
||||
}
|
||||
}
|
||||
public IGamePadDriver GamePadDriver { get; } = new MappedGamePadDriver();
|
||||
|
||||
public IJoystickDriver2 JoystickDriver
|
||||
{
|
||||
|
|
|
@ -36,10 +36,6 @@ namespace OpenTK
|
|||
/// </summary>
|
||||
public class WindowIcon
|
||||
{
|
||||
byte[] data;
|
||||
int width;
|
||||
int height;
|
||||
|
||||
/// \internal
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="OpenTK.WindowIcon"/> class.
|
||||
|
@ -53,8 +49,8 @@ namespace OpenTK
|
|||
if (width < 0 || width > 256 || height < 0 || height > 256)
|
||||
throw new ArgumentOutOfRangeException();
|
||||
|
||||
this.width = width;
|
||||
this.height = height;
|
||||
this.Width = width;
|
||||
this.Height = height;
|
||||
}
|
||||
|
||||
internal WindowIcon(int width, int height, byte[] data)
|
||||
|
@ -65,7 +61,7 @@ namespace OpenTK
|
|||
if (data.Length < Width * Height * 4)
|
||||
throw new ArgumentOutOfRangeException();
|
||||
|
||||
this.data = data;
|
||||
this.Data = data;
|
||||
}
|
||||
|
||||
internal WindowIcon(int width, int height, IntPtr data)
|
||||
|
@ -77,13 +73,13 @@ namespace OpenTK
|
|||
// We assume that width and height are correctly set.
|
||||
// If they are not, we will read garbage and probably
|
||||
// crash.
|
||||
this.data = new byte[width * height * 4];
|
||||
Marshal.Copy(data, this.data, 0, this.data.Length);
|
||||
this.Data = new byte[width * height * 4];
|
||||
Marshal.Copy(data, this.Data, 0, this.Data.Length);
|
||||
}
|
||||
|
||||
internal byte[] Data { get { return data; } }
|
||||
internal int Width { get { return width; } }
|
||||
internal int Height { get { return height; } }
|
||||
internal byte[] Data { get; }
|
||||
internal int Width { get; }
|
||||
internal int Height { get; }
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue