move math stuff into client

This commit is contained in:
UnknownShadow200 2018-07-12 22:07:58 +10:00
parent 3cb3831f96
commit 62f0ad560c
15 changed files with 633 additions and 996 deletions

View file

@ -184,6 +184,7 @@
<Compile Include="Map\Lighting\BasicLighting.cs" />
<Compile Include="Map\Lighting\BasicLighting.Heightmap.cs" />
<Compile Include="Map\WorldEnv.cs" />
<Compile Include="Math\Matrix4.cs" />
<Compile Include="Math\Physics\AABB.cs" />
<Compile Include="Math\Physics\IntersectionUtils.cs" />
<Compile Include="Math\Physics\Searcher.cs" />
@ -191,6 +192,8 @@
<Compile Include="Entities\Model\CustomModel.cs" />
<Compile Include="Entities\Model\HumanModels.cs" />
<Compile Include="Entities\Model\ModelBuilder.cs" />
<Compile Include="Math\Vector3.cs" />
<Compile Include="Math\Vector4.cs" />
<Compile Include="MeshBuilder\Builder.cs" />
<Compile Include="MeshBuilder\FloodFill.cs" />
<Compile Include="MeshBuilder\CuboidDrawer.cs" />

View file

@ -437,9 +437,7 @@ namespace SharpDX.Direct3D9 {
FogStart = 36,
FogEnd = 37,
FogDensity = 38,
Clipping = 136,
Lighting = 137,
Ambient = 139,
FogVertexMode = 140,
ColorVertex = 141,
LocalViewer = 142,
@ -521,10 +519,10 @@ namespace SharpDX.Direct3D9 {
public unsafe static class DataBuffser { // Either 'VertexBuffer' or 'IndexBuffer
public static IntPtr Lock(IntPtr ptr, int offsetToLock, int sizeToLock, LockFlags flags) {
IntPtr pOut;
int res = Interop.Calli(ptr, offsetToLock, sizeToLock, (IntPtr)(void*)&pOut, (int)flags, (*(IntPtr**)ptr)[11]);
IntPtr data;
int res = Interop.Calli(ptr, offsetToLock, sizeToLock, (IntPtr)(void*)&data, (int)flags, (*(IntPtr**)ptr)[11]);
if (res < 0) { throw new SharpDXException(res); }
return pOut;
return data;
}
public static void SetData(IntPtr ptr, IntPtr data, int bytes, LockFlags flags) {

View file

@ -1,4 +1,4 @@
#region --- License ---
#region --- License ---
/*
Copyright (c) 2006 - 2008 The Open Toolkit library.
@ -43,10 +43,7 @@ namespace OpenTK {
public static Matrix4 Identity = new Matrix4(Vector4.UnitX, Vector4.UnitY, Vector4.UnitZ, Vector4.UnitW);
public Matrix4(Vector4 row0, Vector4 row1, Vector4 row2, Vector4 row3) {
Row0 = row0;
Row1 = row1;
Row2 = row2;
Row3 = row3;
Row0 = row0; Row1 = row1; Row2 = row2; Row3 = row3;
}
public Matrix4(
@ -214,6 +211,5 @@ namespace OpenTK {
public override string ToString() {
return string.Format("Row0={0},\r\n Row1={1},\r\n Row2={2},\r\n Row3={3}]", Row0, Row1, Row2, Row3);
}
}
}

View file

@ -1,4 +1,4 @@
#region --- License ---
#region --- License ---
/*
Copyright (c) 2006 - 2008 The Open Toolkit library.
@ -30,11 +30,7 @@ namespace OpenTK {
[StructLayout(LayoutKind.Sequential)]
public struct Vector3 : IEquatable<Vector3>
{
public float X;
public float Y;
public float Z;
public float X, Y, Z;
public Vector3(float x, float y, float z) {
X = x; Y = y; Z = z;
@ -44,49 +40,15 @@ namespace OpenTK {
X = value; Y = value; Z = value;
}
public float Length {
get { return (float)Math.Sqrt(X * X + Y * Y + Z * Z); }
}
public float LengthSquared {
get { return X * X + Y * Y + Z * Z; }
}
public float LengthSquared { get { return X * X + Y * Y + Z * Z; } }
public static readonly Vector3 UnitX = new Vector3(1, 0, 0);
public static readonly Vector3 UnitY = new Vector3(0, 1, 0);
public static readonly Vector3 UnitZ = new Vector3(0, 0, 1);
public static readonly Vector3 Zero = new Vector3(0, 0, 0);
public static readonly Vector3 One = new Vector3(1, 1, 1);
public static void Add(ref Vector3 a, ref Vector3 b, out Vector3 result) {
result = new Vector3(a.X + b.X, a.Y + b.Y, a.Z + b.Z);
}
public static void Subtract(ref Vector3 a, ref Vector3 b, out Vector3 result) {
result = new Vector3(a.X - b.X, a.Y - b.Y, a.Z - b.Z);
}
public static void Multiply(ref Vector3 vector, float scale, out Vector3 result) {
result = new Vector3(vector.X * scale, vector.Y * scale, vector.Z * scale);
}
public static void Multiply(ref Vector3 vector, ref Vector3 scale, out Vector3 result) {
result = new Vector3(vector.X * scale.X, vector.Y * scale.Y, vector.Z * scale.Z);
}
public static void Divide(ref Vector3 vector, float scale, out Vector3 result) {
float invScale = 1 / scale;
result = new Vector3(vector.X * invScale, vector.Y * invScale, vector.Z * invScale);
}
public static void Divide(ref Vector3 vector, ref Vector3 scale, out Vector3 result) {
result = new Vector3(vector.X / scale.X, vector.Y / scale.Y, vector.Z / scale.Z);
}
public static Vector3 Lerp(Vector3 a, Vector3 b, float blend) {
a.X = blend * (b.X - a.X) + a.X;
a.Y = blend * (b.Y - a.Y) + a.Y;
@ -121,10 +83,8 @@ namespace OpenTK {
}
public static Vector3 Normalize(Vector3 vec) {
float scale = 1f / vec.Length;
vec.X *= scale;
vec.Y *= scale;
vec.Z *= scale;
float scale = 1f / (float)Math.Sqrt(vec.LengthSquared);
vec.X *= scale; vec.Y *= scale; vec.Z *= scale;
return vec;
}
@ -133,37 +93,18 @@ namespace OpenTK {
return new Vector3(x * scale, y * scale, z * scale);
}
public static void Normalize(ref Vector3 vec, out Vector3 result) {
float scale = 1f / vec.Length;
result.X = vec.X * scale;
result.Y = vec.Y * scale;
result.Z = vec.Z * scale;
}
public static void Transform(ref Vector3 vec, ref Matrix4 mat, out Vector3 result) {
result.X = vec.X * mat.Row0.X + vec.Y * mat.Row1.X + vec.Z * mat.Row2.X + mat.Row3.X;
result.Y = vec.X * mat.Row0.Y + vec.Y * mat.Row1.Y + vec.Z * mat.Row2.Y + mat.Row3.Y;
result.Z = vec.X * mat.Row0.Z + vec.Y * mat.Row1.Z + vec.Z * mat.Row2.Z + mat.Row3.Z;
}
public static void TransformX(float x, ref Matrix4 mat, out Vector3 result) {
result.X = x * mat.Row0.X + mat.Row3.X;
result.Y = x * mat.Row0.Y + mat.Row3.Y;
result.Z = x * mat.Row0.Z + mat.Row3.Z;
}
public static void TransformY(float y, ref Matrix4 mat, out Vector3 result) {
result.X = y * mat.Row1.X + mat.Row3.X;
result.Y = y * mat.Row1.Y + mat.Row3.Y;
result.Z = y * mat.Row1.Z + mat.Row3.Z;
}
public static void TransformZ(float z, ref Matrix4 mat, out Vector3 result) {
result.X = z * mat.Row2.X + mat.Row3.X;
result.Y = z * mat.Row2.Y + mat.Row3.Y;
result.Z = z * mat.Row2.Z + mat.Row3.Z;
}
public static Vector3 operator + (Vector3 left, Vector3 right) {
left.X += right.X;
left.Y += right.Y;

View file

@ -1,4 +1,4 @@
#region --- License ---
#region --- License ---
/*
Copyright (c) 2006 - 2008 The Open Toolkit library.
@ -30,37 +30,17 @@ namespace OpenTK {
[StructLayout(LayoutKind.Sequential)]
public struct Vector4 : IEquatable<Vector4> {
public float X;
public float Y;
public float Z;
public float W;
public float X, Y, Z, W;
public static Vector4 UnitX = new Vector4(1, 0, 0, 0);
public static Vector4 UnitY = new Vector4(0, 1, 0, 0);
public static Vector4 UnitZ = new Vector4(0, 0, 1, 0);
public static Vector4 UnitW = new Vector4(0, 0, 0, 1);
public static Vector4 Zero = new Vector4(0, 0, 0, 0);
public static readonly Vector4 One = new Vector4(1, 1, 1, 1);
public static readonly int SizeInBytes = 4 * sizeof(float);
public Vector4(float x, float y, float z, float w) {
X = x;
Y = y;
Z = z;
W = w;
X = x; Y = y; Z = z; W = w;
}
public static bool operator == (Vector4 left, Vector4 right) {
return left.Equals(right);
}

View file

@ -62,9 +62,6 @@
<Compile Include="Input\Keyboard.cs" />
<Compile Include="Input\MouseButton.cs" />
<Compile Include="Input\Mouse.cs" />
<Compile Include="Math\Matrix4.cs" />
<Compile Include="Math\Vector3.cs" />
<Compile Include="Math\Vector4.cs" />
<Compile Include="Platform\Configuration.cs" />
<Compile Include="Platform\IPlatformFactory.cs" />
<Compile Include="Platform\MacOS\AglContext.cs" />
@ -96,7 +93,6 @@
<ItemGroup>
<Folder Include="Graphics" />
<Folder Include="Input" />
<Folder Include="Math" />
<Folder Include="Platform" />
<Folder Include="Platform\MacOS" />
<Folder Include="Platform\MacOS\CarbonBindings" />

View file

@ -168,9 +168,6 @@ namespace OpenTK.Platform.MacOS {
mIsFullscreen = false;
}
#region IGraphicsContext Members
public override void SwapBuffers() {
Agl.aglSwapBuffers(ContextHandle);
Agl.CheckReturnValue(0, "aglSwapBuffers");
@ -182,7 +179,7 @@ namespace OpenTK.Platform.MacOS {
}
public override bool IsCurrent {
get { return ContextHandle == Agl.aglGetCurrentContext(); }
get { return ContextHandle == Agl.aglGetCurrentContext(); }
}
public override bool VSync {
@ -194,10 +191,6 @@ namespace OpenTK.Platform.MacOS {
}
}
#endregion
#region IDisposable Members
bool IsDisposed;
protected override void Dispose(bool disposing) {
if (IsDisposed || ContextHandle == IntPtr.Zero) return;
@ -217,43 +210,31 @@ namespace OpenTK.Platform.MacOS {
Agl.CheckReturnValue(code, "aglDestroyContext");
ContextHandle = IntPtr.Zero;
Debug.Print("Context destruction completed successfully.");
} catch(MacOSException) {
} catch (MacOSException) {
Debug.Print("Failed to destroy context.");
if (disposing)
throw;
if (disposing) throw;
}
IsDisposed = true;
}
#endregion
const string lib = "libdl.dylib";
[DllImport(lib, EntryPoint = "NSIsSymbolNameDefined")]
static extern bool NSIsSymbolNameDefined(string s);
[DllImport(lib, EntryPoint = "NSLookupAndBindSymbol")]
static extern IntPtr NSLookupAndBindSymbol(string s);
[DllImport(lib, EntryPoint = "NSAddressOfSymbol")]
static extern IntPtr NSAddressOfSymbol(IntPtr symbol);
#region IGraphicsContextInternal Members
private const string Library = "libdl.dylib";
[DllImport(Library, EntryPoint = "NSIsSymbolNameDefined")]
private static extern bool NSIsSymbolNameDefined(string s);
[DllImport(Library, EntryPoint = "NSLookupAndBindSymbol")]
private static extern IntPtr NSLookupAndBindSymbol(string s);
[DllImport(Library, EntryPoint = "NSAddressOfSymbol")]
private static extern IntPtr NSAddressOfSymbol(IntPtr symbol);
public override IntPtr GetAddress(string function)
{
public override IntPtr GetAddress(string function) {
string fname = "_" + function;
if (!NSIsSymbolNameDefined(fname))
return IntPtr.Zero;
if (!NSIsSymbolNameDefined(fname)) return IntPtr.Zero;
IntPtr symbol = NSLookupAndBindSymbol(fname);
if (symbol != IntPtr.Zero)
symbol = NSAddressOfSymbol(symbol);
return symbol;
}
public override void LoadAll() {
}
#endregion
public override void LoadAll() { }
}
}

View file

@ -12,41 +12,31 @@ using System.Collections.Generic;
using System.IO;
using System.Text;
namespace OpenTK.Platform.MacOS.Carbon
{
static class Application
{
static bool mInitialized = false;
namespace OpenTK.Platform.MacOS.Carbon {
static class Application {
static bool mInitialized;
static IntPtr uppHandler;
static CarbonWindow eventHandler;
static int osMajor, osMinor, osBugfix;
static MacOSEventHandler handler = EventHandler;
internal static CarbonWindow WindowEventHandler;
static Application()
{
Initialize();
}
static Application() { Initialize(); }
internal static void Initialize()
{
internal static void Initialize() {
if (mInitialized) return;
API.AcquireRootMenu();
ConnectEvents();
int osMajor, osMinor, osBugfix;
API.Gestalt(GestaltSelector.SystemVersionMajor, out osMajor);
API.Gestalt(GestaltSelector.SystemVersionMinor, out osMinor);
API.Gestalt(GestaltSelector.SystemVersionBugFix, out osBugfix);
Debug.Print("Running on Mac OS X {0}.{1}.{2}.", osMajor, osMinor, osBugfix);
TransformProcessToForeground();
}
private static void TransformProcessToForeground()
{
static void TransformProcessToForeground() {
ProcessSerialNumber psn = new ProcessSerialNumber();
Debug.Print("Setting process to be foreground application.");
API.GetCurrentProcess(ref psn);
@ -54,16 +44,8 @@ namespace OpenTK.Platform.MacOS.Carbon
API.SetFrontProcess(ref psn);
}
internal static CarbonWindow WindowEventHandler
{
get { return eventHandler; }
set { eventHandler = value; }
}
static void ConnectEvents()
{
EventTypeSpec[] eventTypes = new EventTypeSpec[]
{
static void ConnectEvents() {
EventTypeSpec[] eventTypes = new EventTypeSpec[] {
new EventTypeSpec(EventClass.Application, AppEventKind.AppActivated),
new EventTypeSpec(EventClass.Application, AppEventKind.AppDeactivated),
new EventTypeSpec(EventClass.Application, AppEventKind.AppQuit),
@ -84,21 +66,15 @@ namespace OpenTK.Platform.MacOS.Carbon
new EventTypeSpec(EventClass.AppleEvent, AppleEventKind.AppleEvent),
};
MacOSEventHandler handler = EventHandler;
uppHandler = API.NewEventHandlerUPP(handler);
API.InstallApplicationEventHandler(
uppHandler, eventTypes, IntPtr.Zero, IntPtr.Zero);
mInitialized = true;
}
static OSStatus EventHandler(IntPtr inCaller, IntPtr inEvent, IntPtr userData)
{
static OSStatus EventHandler(IntPtr inCaller, IntPtr inEvent, IntPtr userData) {
EventInfo evt = new EventInfo(inEvent);
switch (evt.EventClass)
{
switch (evt.EventClass) {
case EventClass.AppleEvent:
// only event here is the apple event.
Debug.Print("Processing apple event.");

View file

@ -402,8 +402,7 @@ namespace OpenTK.Platform.MacOS {
#region --- Carbon API Methods ---
public static class API
{
public static class API {
const string carbon = "/System/Library/Frameworks/Carbon.framework/Versions/Current/Carbon";
[DllImport(carbon)]
@ -435,77 +434,28 @@ namespace OpenTK.Platform.MacOS {
[DllImport(carbon)]
static extern OSStatus GetWindowBounds(IntPtr window, WindowRegionCode regionCode, out Rect globalBounds);
public static Rect GetWindowBounds(IntPtr window, WindowRegionCode regionCode) {
Rect retval;
OSStatus error = GetWindowBounds(window, regionCode, out retval);
CheckReturn(error);
return retval;
Rect rect;
OSStatus result = GetWindowBounds(window, regionCode, out rect);
CheckReturn(result);
return rect;
}
[DllImport(carbon)]
static extern IntPtr GetEventDispatcherTarget();
[DllImport(carbon,EntryPoint="ReceiveNextEvent")]
static extern OSStatus ReceiveNextEvent(uint inNumTypes,
IntPtr inList,
double inTimeout,
bool inPullEvent,
out IntPtr outEvent);
internal static extern IntPtr GetEventDispatcherTarget();
[DllImport(carbon)]
internal static extern OSStatus ReceiveNextEvent(uint numTypes, IntPtr list,
double timeout, bool pullEvent,
out IntPtr theEvent);
[DllImport(carbon)]
static extern void SendEventToEventTarget(IntPtr theEvent, IntPtr theTarget);
internal static extern void SendEventToEventTarget(IntPtr theEvent, IntPtr theTarget);
[DllImport(carbon)]
static extern void ReleaseEvent(IntPtr theEvent);
public static void SendEvent(IntPtr theEvent)
{
IntPtr theTarget = GetEventDispatcherTarget();
SendEventToEventTarget(theEvent, theTarget);
}
// Processes events in the queue and then returns.
public static void ProcessEvents()
{
IntPtr theEvent;
IntPtr theTarget = GetEventDispatcherTarget();
for (;;)
{
OSStatus status = ReceiveNextEvent(0, IntPtr.Zero, 0.0, true, out theEvent);
if (status == OSStatus.EventLoopTimedOut)
break;
if (status != OSStatus.NoError)
{
Debug.Print("Message Loop status: {0}", status);
break;
}
if (theEvent == IntPtr.Zero)
break;
try
{
SendEventToEventTarget(theEvent, theTarget);
}
catch (System.ExecutionEngineException e)
{
Console.Error.WriteLine("ExecutionEngineException caught.");
Console.Error.WriteLine("theEvent: " + new EventInfo(theEvent).ToString());
Console.Error.WriteLine(e.Message);
Console.Error.WriteLine(e.StackTrace);
}
ReleaseEvent(theEvent);
}
}
internal static extern void ReleaseEvent(IntPtr theEvent);
#region --- Processing apple event ---
[StructLayout(LayoutKind.Sequential)]
struct EventRecord
{
struct EventRecord {
public ushort what;
public uint message;
public uint when;
@ -515,14 +465,11 @@ namespace OpenTK.Platform.MacOS {
[DllImport(carbon)]
static extern bool ConvertEventRefToEventRecord(IntPtr inEvent, out EventRecord outEvent);
[DllImport(carbon)]
static extern OSStatus AEProcessAppleEvent(ref EventRecord theEventRecord);
static public void ProcessAppleEvent(IntPtr inEvent)
{
public static void ProcessAppleEvent(IntPtr inEvent) {
EventRecord record;
ConvertEventRefToEventRecord(inEvent, out record);
AEProcessAppleEvent(ref record);
}
@ -557,9 +504,7 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.KeyCode, EventParamType.typeUInt32, IntPtr.Zero,
sizeof(uint), IntPtr.Zero, (IntPtr)(void*)&code);
if (result != OSStatus.NoError)
throw new MacOSException(result);
CheckReturn(result);
return (MacOSKeyCode)code;
}
@ -568,9 +513,7 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.KeyMacCharCode, EventParamType.typeChar, IntPtr.Zero,
Marshal.SizeOf(typeof(char)), IntPtr.Zero, (IntPtr)(void*)&code);
if (result != OSStatus.NoError)
throw new MacOSException(result);
CheckReturn(result);
return code;
}
@ -579,9 +522,7 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.MouseButton, EventParamType.typeMouseButton, IntPtr.Zero,
sizeof(short), IntPtr.Zero, (IntPtr)(void*)&button);
if (result != OSStatus.NoError)
throw new MacOSException(result);
CheckReturn(result);
return (MacOSMouseButton)button;
}
@ -590,9 +531,7 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.MouseWheelDelta, EventParamType.typeSInt32,
IntPtr.Zero, sizeof(int), IntPtr.Zero, (IntPtr)(void*)&delta);
if (result != OSStatus.NoError)
throw new MacOSException(result);
CheckReturn(result);
return delta;
}
@ -601,27 +540,15 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.WindowMouseLocation, EventParamType.typeHIPoint, IntPtr.Zero,
Marshal.SizeOf(typeof(HIPoint)), IntPtr.Zero, (IntPtr)(void*)&point);
pt = point;
return result;
}
public unsafe static OSStatus GetEventWindowRef(IntPtr inEvent, out IntPtr windowRef) {
IntPtr retval;
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.WindowRef, EventParamType.typeWindowRef, IntPtr.Zero,
sizeof(IntPtr), IntPtr.Zero, (IntPtr)(void*)&retval);
windowRef = retval;
return result;
}
public unsafe static OSStatus GetEventMouseLocation(IntPtr inEvent, out HIPoint pt) {
HIPoint point;
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.MouseLocation, EventParamType.typeHIPoint, IntPtr.Zero,
Marshal.SizeOf(typeof(HIPoint)), IntPtr.Zero, (IntPtr)(void*)&point);
pt = point;
return result;
}
@ -631,63 +558,45 @@ namespace OpenTK.Platform.MacOS {
OSStatus result = API.GetEventParameter(inEvent,
EventParamName.KeyModifiers, EventParamType.typeUInt32, IntPtr.Zero,
sizeof(uint), IntPtr.Zero, (IntPtr)(void*)&code);
if (result != OSStatus.NoError)
throw new MacOSException(result);
CheckReturn(result);
return (MacOSKeyModifiers)code;
}
#endregion
#region --- Event Handlers ---
public static void InstallWindowEventHandler(IntPtr windowRef, IntPtr uppHandlerProc,
EventTypeSpec[] eventTypes, IntPtr userData, IntPtr handlerRef) {
IntPtr target = GetWindowEventTarget(windowRef);
OSStatus result = InstallEventHandler(target, uppHandlerProc, eventTypes.Length,
eventTypes, userData, handlerRef);
CheckReturn(result);
}
public static void InstallApplicationEventHandler(IntPtr uppHandlerProc,
EventTypeSpec[] eventTypes, IntPtr userData, IntPtr handlerRef) {
IntPtr target = GetApplicationEventTarget();
OSStatus result = InstallEventHandler(target, uppHandlerProc, eventTypes.Length,
eventTypes, userData, handlerRef);
CheckReturn(result);
}
[DllImport(carbon)]
static extern OSStatus InstallEventHandler(IntPtr eventTargetRef, IntPtr handlerProc,
int numtypes, EventTypeSpec[] typeList,
IntPtr userData, IntPtr handlerRef);
public static void InstallWindowEventHandler(IntPtr windowRef, IntPtr uppHandlerProc,
EventTypeSpec[] eventTypes, IntPtr userData, IntPtr handlerRef)
{
IntPtr windowTarget = GetWindowEventTarget(windowRef);
OSStatus error = InstallEventHandler(windowTarget, uppHandlerProc,
eventTypes.Length, eventTypes,
userData, handlerRef);
CheckReturn(error);
}
public static void InstallApplicationEventHandler(IntPtr uppHandlerProc,
EventTypeSpec[] eventTypes, IntPtr userData, IntPtr handlerRef)
{
OSStatus error = InstallEventHandler(GetApplicationEventTarget(), uppHandlerProc,
eventTypes.Length, eventTypes,
userData, handlerRef);
CheckReturn(error);
}
[DllImport(carbon)]
public static extern OSStatus RemoveEventHandler(IntPtr inHandlerRef);
#endregion
#region --- GetWindowEventTarget ---
[DllImport(carbon)]
public static extern IntPtr GetWindowEventTarget(IntPtr window);
[DllImport(carbon)]
public static extern IntPtr GetApplicationEventTarget();
#endregion
#region --- UPP Event Handlers ---
[DllImport(carbon)]
public static extern IntPtr NewEventHandlerUPP(MacOSEventHandler handler);
[DllImport(carbon)]
public static extern void DisposeEventHandlerUPP(IntPtr userUPP);
#endregion
#region --- Process Manager ---
[DllImport(carbon)]
public static extern int TransformProcessType(ref ProcessSerialNumber psn, ProcessApplicationTransformState type);
[DllImport(carbon)]
@ -695,9 +604,6 @@ namespace OpenTK.Platform.MacOS {
[DllImport(carbon)]
public static extern int SetFrontProcess(ref ProcessSerialNumber psn);
#endregion
#region --- Setting Dock Tile ---
[DllImport(carbon)]
public extern static IntPtr CGColorSpaceCreateDeviceRGB();
[DllImport(carbon)]
@ -706,15 +612,17 @@ namespace OpenTK.Platform.MacOS {
public extern static IntPtr CGImageCreate(int width, int height, int bitsPerComponent, int bitsPerPixel, int bytesPerRow, IntPtr colorspace,
uint bitmapInfo, IntPtr provider, IntPtr decode, int shouldInterpolate, int intent);
[DllImport(carbon)]
public extern static void SetApplicationDockTileImage(IntPtr imageRef);
[DllImport(carbon)]
public extern static void RestoreApplicationDockTileImage();
[DllImport(carbon)]
public extern static void CGImageRelease(IntPtr image);
[DllImport(carbon)]
public extern static void CGDataProviderRelease(IntPtr provider);
[DllImport(carbon)]
public extern static void CGColorSpaceRelease(IntPtr space);
[DllImport(carbon)]
public extern static void SetApplicationDockTileImage(IntPtr imageRef);
[DllImport(carbon)]
public extern static void RestoreApplicationDockTileImage();
[DllImport(carbon)]
public extern static void CGContextDrawImage(IntPtr context, HIRect rect, IntPtr image);
[DllImport(carbon)]
@ -723,8 +631,6 @@ namespace OpenTK.Platform.MacOS {
public extern static OSStatus QDBeginCGContext(IntPtr port, ref IntPtr context);
[DllImport(carbon)]
public extern static OSStatus QDEndCGContext(IntPtr port, ref IntPtr context);
#endregion
#region --- Clipboard ---
[DllImport (carbon)]
public static extern IntPtr CFDataCreate(IntPtr allocator, IntPtr buf, Int32 length);
@ -746,62 +652,24 @@ namespace OpenTK.Platform.MacOS {
[DllImport (carbon)]
public static extern OSStatus PasteboardPutItemFlavor(IntPtr pbref, UInt32 itemid, IntPtr key, IntPtr data, UInt32 flags);
#endregion
[DllImport(carbon)]
public static extern OSStatus ActivateWindow (IntPtr inWindow, bool inActivate);
public static extern OSStatus ActivateWindow(IntPtr inWindow, bool inActivate);
[DllImport(carbon)]
public static extern void RunApplicationEventLoop();
[DllImport(carbon)]
public static extern void QuitApplicationEventLoop();
#region --- SetWindowTitle ---
[DllImport(carbon)]
static extern void SetWindowTitleWithCFString(IntPtr windowRef, IntPtr title);
public static void SetWindowTitle(IntPtr windowRef, string title)
{
IntPtr str = __CFStringMakeConstantString(title);
Debug.Print("Setting window title: {0}, CFstring : {1}, Text : {2}", windowRef, str, title);
SetWindowTitleWithCFString(windowRef, str);
// Apparently releasing this reference to the CFConstantString here
// causes the program to crash on the fourth window created. But I am
// afraid that not releasing the string would result in a memory leak, but that would
// only be a serious issue if the window title is changed a lot.
//CFRelease(str);
}
#endregion
[DllImport(carbon)]
static extern IntPtr __CFStringMakeConstantString(string cStr);
[DllImport(carbon)]
static extern void CFRelease(IntPtr cfStr);
[DllImport(carbon)]
public static extern OSStatus CallNextEventHandler(IntPtr nextHandler, IntPtr theEvent);
internal static extern void SetWindowTitleWithCFString(IntPtr windowRef, IntPtr title);
[DllImport(carbon)]
public static extern IntPtr GetWindowPort(IntPtr windowRef);
#region --- Menus ---
[DllImport(carbon)]
public static extern IntPtr AcquireRootMenu();
#endregion
[DllImport(carbon)]
public static extern bool IsWindowCollapsed(IntPtr windowRef);
[DllImport(carbon)]
public static extern OSStatus CollapseWindow(IntPtr windowRef, bool collapse);
@ -810,20 +678,17 @@ namespace OpenTK.Platform.MacOS {
throw new MacOSException(error);
}
[DllImport(carbon, EntryPoint="IsWindowInStandardState")]
static extern bool _IsWindowInStandardState(IntPtr windowRef, IntPtr inIdealSize, IntPtr outIdealStandardState);
public static bool IsWindowInStandardState(IntPtr windowRef)
{
return _IsWindowInStandardState(windowRef, IntPtr.Zero, IntPtr.Zero);
[DllImport(carbon)]
static extern bool IsWindowInStandardState(IntPtr windowRef, IntPtr inIdealSize, IntPtr outIdealStandardState);
public static bool IsWindowInStandardState(IntPtr windowRef) {
return IsWindowInStandardState(windowRef, IntPtr.Zero, IntPtr.Zero);
}
[DllImport(carbon)]
public unsafe static extern OSStatus ZoomWindowIdeal(IntPtr windowRef, short inPartCode, ref CarbonPoint toIdealSize);
public static extern OSStatus ZoomWindowIdeal(IntPtr windowRef, short inPartCode, ref CarbonPoint toIdealSize);
[DllImport(carbon)]
public unsafe static extern OSStatus DMGetGDeviceByDisplayID(
IntPtr displayID, out IntPtr displayDevice, Boolean failToMain);
public static extern OSStatus DMGetGDeviceByDisplayID(IntPtr displayID, out IntPtr displayDevice, Boolean failToMain);
[DllImport(carbon)]
public unsafe static extern IntPtr HIGetMousePosition(HICoordinateSpace space, IntPtr obj, ref HIPoint point);

View file

@ -81,16 +81,11 @@ namespace OpenTK.Platform.MacOS {
DisposeUPP();
}
#region Private Members
void DisposeUPP()
{
if (uppHandler != IntPtr.Zero)
{
void DisposeUPP() {
if (uppHandler != IntPtr.Zero) {
//API.RemoveEventHandler(uppHandler);
//API.DisposeEventHandlerUPP(uppHandler);
}
uppHandler = IntPtr.Zero;
}
@ -101,7 +96,10 @@ namespace OpenTK.Platform.MacOS {
OSStatus err = API.CreateNewWindow(@class, attrib, ref r, out windowRef);
API.CheckReturn(err);
Debug.Print("Created window " + windowRef.ToString());
API.SetWindowTitle(windowRef, title);
IntPtr titleCF = CF.CFSTR(title);
Debug.Print("Setting window title: {0}, CFstring : {1}, Text : {2}", windowRef, titleCF, title);
API.SetWindowTitleWithCFString(windowRef, titleCF);
SetLocation(r.X, r.Y);
SetSize(r.Width, r.Height);
@ -114,10 +112,8 @@ namespace OpenTK.Platform.MacOS {
Debug.Print("Attached window events.");
}
void ConnectEvents()
{
EventTypeSpec[] eventTypes = new EventTypeSpec[]
{
void ConnectEvents() {
EventTypeSpec[] eventTypes = new EventTypeSpec[] {
new EventTypeSpec(EventClass.Window, WindowEventKind.WindowClose),
new EventTypeSpec(EventClass.Window, WindowEventKind.WindowClosed),
new EventTypeSpec(EventClass.Window, WindowEventKind.WindowBoundsChanged),
@ -159,26 +155,20 @@ namespace OpenTK.Platform.MacOS {
internal void UnsetFullscreen(AglContext context) {
context.UnsetFullScreen(this);
Debug.Print("Telling Carbon to reset window state to " + windowState.ToString());
SetCarbonWindowState();
SetCarbonWindowState();
SetSize((short)windowedBounds.Width, (short)windowedBounds.Height);
}
internal OSStatus DispatchEvent(IntPtr inCaller, IntPtr inEvent, EventInfo evt, IntPtr userData)
{
switch (evt.EventClass)
{
internal OSStatus DispatchEvent(IntPtr inCaller, IntPtr inEvent, EventInfo evt, IntPtr userData) {
switch (evt.EventClass) {
case EventClass.Window:
return ProcessWindowEvent(inCaller, inEvent, evt, userData);
case EventClass.Mouse:
return ProcessMouseEvent(inCaller, inEvent, evt, userData);
case EventClass.Keyboard:
return ProcessKeyboardEvent(inCaller, inEvent, evt, userData);
default:
return OSStatus.EventNotHandled;
}
@ -192,15 +182,14 @@ namespace OpenTK.Platform.MacOS {
OSStatus ProcessKeyboardEvent(IntPtr inCaller, IntPtr inEvent, EventInfo evt, IntPtr userData) {
MacOSKeyCode code = (MacOSKeyCode)0;
char charCode = '\0';
//Debug.Print("Processing Keyboard event {0}", (KeyboardEventKind)evt.EventKind);
switch ((KeyboardEventKind)evt.EventKind)
{
switch ((KeyboardEventKind)evt.EventKind) {
case KeyboardEventKind.RawKeyDown:
case KeyboardEventKind.RawKeyRepeat:
case KeyboardEventKind.RawKeyUp:
GetCharCodes(inEvent, out code, out charCode);
code = API.GetEventKeyboardKeyCode(inEvent);
charCode = API.GetEventKeyboardChar(inEvent);
break;
}
@ -210,8 +199,7 @@ namespace OpenTK.Platform.MacOS {
return OSStatus.NoError;
}
switch ((KeyboardEventKind)evt.EventKind)
{
switch ((KeyboardEventKind)evt.EventKind) {
case KeyboardEventKind.RawKeyRepeat:
Keyboard.KeyRepeat = true;
goto case KeyboardEventKind.RawKeyDown;
@ -228,15 +216,12 @@ namespace OpenTK.Platform.MacOS {
case KeyboardEventKind.RawKeyModifiersChanged:
ProcessModifierKey(inEvent);
return OSStatus.NoError;
default:
return OSStatus.EventNotHandled;
}
return OSStatus.EventNotHandled;
}
OSStatus ProcessWindowEvent(IntPtr inCaller, IntPtr inEvent, EventInfo evt, IntPtr userData) {
switch ((WindowEventKind)evt.EventKind)
{
switch ((WindowEventKind)evt.EventKind) {
case WindowEventKind.WindowClose:
RaiseClosing();
return OSStatus.EventNotHandled;
@ -247,28 +232,25 @@ namespace OpenTK.Platform.MacOS {
return OSStatus.NoError;
case WindowEventKind.WindowBoundsChanged:
int thisWidth = ClientRectangle.Width;
int thisHeight = ClientRectangle.Height;
int curWidth = ClientRectangle.Width;
int curHeight = ClientRectangle.Height;
LoadSize();
if (thisWidth != ClientRectangle.Width || thisHeight != ClientRectangle.Height)
if (curWidth != ClientRectangle.Width || curHeight != ClientRectangle.Height)
OnResize();
return OSStatus.EventNotHandled;
case WindowEventKind.WindowActivate:
OnActivate();
mIsActive = true;
RaiseFocusedChanged();
return OSStatus.EventNotHandled;
case WindowEventKind.WindowDeactivate:
OnDeactivate();
return OSStatus.EventNotHandled;
default:
Debug.Print("{0}", evt);
mIsActive = false;
RaiseFocusedChanged();
return OSStatus.EventNotHandled;
}
return OSStatus.EventNotHandled;
}
OSStatus ProcessMouseEvent(IntPtr inCaller, IntPtr inEvent, EventInfo evt, IntPtr userData) {
@ -277,70 +259,49 @@ namespace OpenTK.Platform.MacOS {
HIPoint screenLoc = new HIPoint();
OSStatus err = API.GetEventMouseLocation(inEvent, out screenLoc);
if (this.windowState == WindowState.Fullscreen)
{
if (windowState == WindowState.Fullscreen) {
pt = screenLoc;
}
else
{
} else {
err = API.GetEventWindowMouseLocation(inEvent, out pt);
}
if (err != OSStatus.NoError)
{
if (err != OSStatus.NoError) {
// this error comes up from the application event handler.
if (err != OSStatus.EventParameterNotFound)
{
if (err != OSStatus.EventParameterNotFound) {
throw new MacOSException(err);
}
}
Point mousePosInClient = new Point((int)pt.X, (int)pt.Y);
if (this.windowState != WindowState.Fullscreen)
{
if (windowState != WindowState.Fullscreen) {
mousePosInClient.Y -= mTitlebarHeight;
}
switch ((MouseEventKind)evt.EventKind)
{
switch ((MouseEventKind)evt.EventKind) {
case MouseEventKind.MouseDown:
button = API.GetEventMouseButton(inEvent);
switch (button)
{
switch (button) {
case MacOSMouseButton.Primary:
Mouse.Set(MouseButton.Left, true);
break;
Mouse.Set(MouseButton.Left, true); break;
case MacOSMouseButton.Secondary:
Mouse.Set(MouseButton.Right, true);
break;
Mouse.Set(MouseButton.Right, true); break;
case MacOSMouseButton.Tertiary:
Mouse.Set(MouseButton.Middle, true);
break;
Mouse.Set(MouseButton.Middle, true); break;
}
return OSStatus.NoError;
case MouseEventKind.MouseUp:
button = API.GetEventMouseButton(inEvent);
switch (button)
{
switch (button) {
case MacOSMouseButton.Primary:
Mouse.Set(MouseButton.Left, false);
break;
Mouse.Set(MouseButton.Left, false); break;
case MacOSMouseButton.Secondary:
Mouse.Set(MouseButton.Right, false);
break;
Mouse.Set(MouseButton.Right, false); break;
case MacOSMouseButton.Tertiary:
Mouse.Set(MouseButton.Middle, false);
break;
Mouse.Set(MouseButton.Middle, false); break;
}
button = API.GetEventMouseButton(inEvent);
return OSStatus.NoError;
case MouseEventKind.WheelMoved:
@ -366,21 +327,11 @@ namespace OpenTK.Platform.MacOS {
}
}
return OSStatus.EventNotHandled;
default:
Debug.Print("{0}", evt);
return OSStatus.EventNotHandled;
}
return OSStatus.EventNotHandled;
}
private static void GetCharCodes(IntPtr inEvent, out MacOSKeyCode code, out char charCode)
{
code = API.GetEventKeyboardKeyCode(inEvent);
charCode = API.GetEventKeyboardChar(inEvent);
}
private void ProcessModifierKey(IntPtr inEvent)
{
void ProcessModifierKey(IntPtr inEvent) {
MacOSKeyModifiers modifiers = API.GetEventKeyModifiers(inEvent);
bool caps = (modifiers & MacOSKeyModifiers.CapsLock) != 0;
@ -402,20 +353,13 @@ namespace OpenTK.Platform.MacOS {
Keyboard.KeyRepeat = repeat;
}
Rect GetRegion() {
return API.GetWindowBounds(WinHandle, WindowRegionCode.ContentRegion);
}
void SetLocation(short x, short y) {
if (windowState == WindowState.Fullscreen)
return;
if (windowState == WindowState.Fullscreen) return;
API.MoveWindow(WinHandle, x, y, false);
}
void SetSize(short width, short height) {
if (WindowState == WindowState.Fullscreen)
return;
if (WindowState == WindowState.Fullscreen) return;
// The bounds of the window should be the size specified, but
// API.SizeWindow sets the content region size. So
@ -427,20 +371,17 @@ namespace OpenTK.Platform.MacOS {
}
void SetClientSize(short width, short height) {
if (WindowState == WindowState.Fullscreen)
return;
if (WindowState == WindowState.Fullscreen) return;
API.SizeWindow(WinHandle, width, height, true);
}
protected void OnResize() {
void OnResize() {
LoadSize();
RaiseResize();
}
private void LoadSize() {
if (WindowState == WindowState.Fullscreen)
return;
void LoadSize() {
if (WindowState == WindowState.Fullscreen) return;
Rect r = API.GetWindowBounds(WinHandle, WindowRegionCode.StructureRegion);
bounds = new Rectangle(r.X, r.Y, r.Width, r.Height);
@ -449,12 +390,8 @@ namespace OpenTK.Platform.MacOS {
clientRectangle = new Rectangle(0, 0, r.Width, r.Height);
}
#endregion
#region INativeWindow Members
IntPtr pbStr, utf16, utf8;
public override string GetClipboardText() {
public override string GetClipboardText() {
IntPtr pbRef = GetPasteboard();
API.PasteboardSynchronize(pbRef);
@ -527,8 +464,23 @@ namespace OpenTK.Platform.MacOS {
return pbRef;
}
// Processes events in the queue and then returns.
public override void ProcessEvents() {
API.ProcessEvents();
IntPtr theEvent;
IntPtr target = API.GetEventDispatcherTarget();
for (;;) {
OSStatus status = API.ReceiveNextEvent(0, IntPtr.Zero, 0.0, true, out theEvent);
if (status == OSStatus.EventLoopTimedOut) break;
if (status != OSStatus.NoError) {
Debug.Print("Message Loop status: {0}", status); break;
}
if (theEvent == IntPtr.Zero) break;
API.SendEventToEventTarget(theEvent, target);
API.ReleaseEvent(theEvent);
}
}
public override Point PointToClient(Point point) {
@ -550,8 +502,7 @@ namespace OpenTK.Platform.MacOS {
set { SetIcon(value); }
}
private unsafe void SetIcon(Icon icon)
{
unsafe void SetIcon(Icon icon) {
// The code for this function was adapted from Mono's
// XplatUICarbon implementation, written by Geoff Norton
// http://anonsvn.mono-project.com/viewvc/trunk/mcs/class/Managed.Windows.Forms/System.Windows.Forms/XplatUICarbon.cs?view=markup&pathrev=136932
@ -666,7 +617,6 @@ namespace OpenTK.Platform.MacOS {
get {
if (windowState == WindowState.Fullscreen)
return WindowState.Fullscreen;
if (API.IsWindowCollapsed(WinHandle))
return WindowState.Minimized;
if (API.IsWindowInStandardState(WinHandle))
@ -678,7 +628,6 @@ namespace OpenTK.Platform.MacOS {
if (value == WindowState) return;
Debug.Print("Switching window state from {0} to {1}", WindowState, value);
WindowState oldState = WindowState;
windowState = value;
if (oldState == WindowState.Fullscreen) {
@ -692,17 +641,15 @@ namespace OpenTK.Platform.MacOS {
OSStatus err = API.CollapseWindow(WinHandle, false);
API.CheckReturn(err);
}
SetCarbonWindowState();
}
}
private void SetCarbonWindowState() {
void SetCarbonWindowState() {
CarbonPoint idealSize;
OSStatus err;
OSStatus result;
switch (windowState)
{
switch (windowState) {
case WindowState.Fullscreen:
goFullScreenHack = true;
break;
@ -712,22 +659,21 @@ namespace OpenTK.Platform.MacOS {
// meaning they are maximized up to their reported ideal size. So we report a
// large ideal size.
idealSize = new CarbonPoint(9000, 9000);
err = API.ZoomWindowIdeal(WinHandle, (short)WindowPartCode.inZoomOut, ref idealSize);
API.CheckReturn(err);
result = API.ZoomWindowIdeal(WinHandle, (short)WindowPartCode.inZoomOut, ref idealSize);
API.CheckReturn(result);
break;
case WindowState.Normal:
if (WindowState == WindowState.Maximized)
{
if (WindowState == WindowState.Maximized) {
idealSize = new CarbonPoint();
err = API.ZoomWindowIdeal(WinHandle, (short)WindowPartCode.inZoomIn, ref idealSize);
API.CheckReturn(err);
result = API.ZoomWindowIdeal(WinHandle, (short)WindowPartCode.inZoomIn, ref idealSize);
API.CheckReturn(result);
}
break;
case WindowState.Minimized:
err = API.CollapseWindow(WinHandle, true);
API.CheckReturn(err);
result = API.CollapseWindow(WinHandle, true);
API.CheckReturn(result);
break;
}
@ -735,24 +681,6 @@ namespace OpenTK.Platform.MacOS {
OnResize();
}
#region --- Event wrappers ---
private void OnActivate() {
mIsActive = true;
RaiseFocusedChanged();
}
private void OnDeactivate() {
mIsActive = false;
RaiseFocusedChanged();
}
#endregion
#endregion
#region IInputDriver Members
public override Point DesktopCursorPos {
get {
HIPoint point = default(HIPoint);
@ -780,7 +708,5 @@ namespace OpenTK.Platform.MacOS {
CG.CGDisplayHideCursor(CG.CGMainDisplayID());
}
}
#endregion
}
}

View file

@ -24,11 +24,9 @@ namespace OpenTK.Platform.Windows {
internal static extern bool SetWindowPos(IntPtr handle, IntPtr insertAfter, int x, int y, int cx, int cy, SetWindowPosFlags flags);
[DllImport("user32.dll", SetLastError = true)]
internal static extern bool AdjustWindowRect([In, Out] ref Win32Rectangle lpRect, WindowStyle dwStyle, bool bMenu);
[DllImport("user32.dll", SetLastError = true)]
internal static extern bool AdjustWindowRectEx(ref Win32Rectangle lpRect, WindowStyle dwStyle, bool bMenu, ExtendedWindowStyle dwExStyle);
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
internal static extern IntPtr CreateWindowEx(ExtendedWindowStyle ExStyle, IntPtr ClassAtom, IntPtr WindowName, WindowStyle Style,
internal static extern IntPtr CreateWindowEx(int exStyle, IntPtr ClassAtom, IntPtr WindowName, WindowStyle Style,
int X, int Y, int Width, int Height, IntPtr HandleToParentWindow, IntPtr Menu, IntPtr Instance, IntPtr Param);
[DllImport("user32.dll", SetLastError = true)]
internal static extern bool DestroyWindow(IntPtr windowHandle);
@ -201,7 +199,7 @@ namespace OpenTK.Platform.Windows {
internal byte StencilBits;
internal byte AuxBuffers;
internal byte LayerType;
private byte Reserved;
byte Reserved;
internal int LayerMask;
internal int VisibleMask;
internal int DamageMask;
@ -220,7 +218,7 @@ namespace OpenTK.Platform.Windows {
internal string DeviceName;
internal short SpecVersion;
internal short DriverVersion;
private short Size;
short Size;
internal short DriverExtra;
internal int Fields;
@ -468,12 +466,6 @@ namespace OpenTK.Platform.Windows {
ChildWindow = Child
}
[Flags]
internal enum ExtendedWindowStyle : uint {
WindowEdge = 0x00000100,
ApplicationWindow = 0x00040000,
}
internal enum GetWindowLongOffsets : int {
STYLE = (-16),
}

View file

@ -34,7 +34,6 @@ using OpenTK.Input;
namespace OpenTK.Platform.Windows {
public sealed class WinWindow : INativeWindow {
const ExtendedWindowStyle ParentStyleEx = ExtendedWindowStyle.WindowEdge | ExtendedWindowStyle.ApplicationWindow;
readonly IntPtr Instance = Marshal.GetHINSTANCE(typeof(WinWindow).Module);
readonly IntPtr ClassName = Marshal.StringToHGlobalAuto("CS_WindowClass");
readonly WindowProcedure WindowProcedureDelegate;
@ -330,12 +329,11 @@ namespace OpenTK.Platform.Windows {
// The style of a parent window is different than that of a child window.
// Note: the child window should always be visible, even if the parent isn't.
WindowStyle style = WindowStyle.OverlappedWindow | WindowStyle.ClipChildren;
ExtendedWindowStyle ex_style = ParentStyleEx;
// Find out the final window rectangle, after the WM has added its chrome (titlebar, sidebars etc).
Win32Rectangle rect = new Win32Rectangle();
rect.left = x; rect.top = y; rect.right = x + width; rect.bottom = y + height;
API.AdjustWindowRectEx(ref rect, style, false, ex_style);
API.AdjustWindowRect(ref rect, style, false);
// Create the window class that we will use for this window.
// The current approach is to register a new class for each top-level WinGLWindow we create.
@ -360,7 +358,7 @@ namespace OpenTK.Platform.Windows {
IntPtr window_name = Marshal.StringToHGlobalAuto(title);
IntPtr handle = API.CreateWindowEx(
ex_style, ClassName, window_name, style,
0, ClassName, window_name, style,
rect.left, rect.top, rect.Width, rect.Height,
IntPtr.Zero, IntPtr.Zero, Instance, IntPtr.Zero);
@ -614,7 +612,7 @@ namespace OpenTK.Platform.Windows {
// Make sure client size doesn't change when changing the border style.
Win32Rectangle rect = Win32Rectangle.From(bounds);
API.AdjustWindowRectEx(ref rect, style, false, ParentStyleEx);
API.AdjustWindowRect(ref rect, style, false);
// This avoids leaving garbage on the background window.
if (was_visible)

View file

@ -80,24 +80,12 @@ void Vector3_Transform(Vector3* result, Vector3* a, Matrix* mat) {
result->X = x; result->Y = y; result->Z = z;
}
void Vector3_TransformX(Vector3* result, Real32 x, Matrix* mat) {
result->X = x * mat->Row0.X + mat->Row3.X;
result->Y = x * mat->Row0.Y + mat->Row3.Y;
result->Z = x * mat->Row0.Z + mat->Row3.Z;
}
void Vector3_TransformY(Vector3* result, Real32 y, Matrix* mat) {
result->X = y * mat->Row1.X + mat->Row3.X;
result->Y = y * mat->Row1.Y + mat->Row3.Y;
result->Z = y * mat->Row1.Z + mat->Row3.Z;
}
void Vector3_TransformZ(Vector3* result, Real32 z, Matrix* mat) {
result->X = z * mat->Row2.X + mat->Row3.X;
result->Y = z * mat->Row2.Y + mat->Row3.Y;
result->Z = z * mat->Row2.Z + mat->Row3.Z;
}
Vector3 Vector3_RotateX(Vector3 v, Real32 angle) {
Real32 cosA = Math_CosF(angle), sinA = Math_SinF(angle);
return Vector3_Create3(v.X, cosA * v.Y + sinA * v.Z, -sinA * v.Y + cosA * v.Z);

View file

@ -45,9 +45,7 @@ void Vector3_Cross(Vector3* result, Vector3* a, Vector3* b);
void Vector3_Normalize(Vector3* result, Vector3* a);
void Vector3_Transform(Vector3* result, Vector3* a, Matrix* mat);
void Vector3_TransformX(Vector3* result, Real32 x, Matrix* mat);
void Vector3_TransformY(Vector3* result, Real32 y, Matrix* mat);
void Vector3_TransformZ(Vector3* result, Real32 z, Matrix* mat);
Vector3 Vector3_RotateX(Vector3 v, Real32 angle);
Vector3 Vector3_RotateY(Vector3 v, Real32 angle);

View file

@ -11,7 +11,6 @@
#include <Windows.h>
#define win_Style WS_OVERLAPPEDWINDOW | WS_CLIPCHILDREN
#define win_StyleEx WS_EX_WINDOWEDGE | WS_EX_APPWINDOW
#define win_ClassName "ClassiCube_Window"
#define RECT_WIDTH(rect) (rect.right - rect.left)
#define RECT_HEIGHT(rect) (rect.bottom - rect.top)
@ -72,7 +71,7 @@ static void Window_DoSetHiddenBorder(bool value) {
rect.left = win_Bounds.X; rect.top = win_Bounds.Y;
rect.right = rect.left + win_Bounds.Width;
rect.bottom = rect.top + win_Bounds.Height;
AdjustWindowRectEx(&rect, style, false, win_StyleEx);
AdjustWindowRect(&rect, style, false);
/* This avoids leaving garbage on the background window. */
if (was_visible) Window_SetVisible(false);
@ -403,7 +402,7 @@ void Window_Create(Int32 x, Int32 y, Int32 width, Int32 height, STRING_REF Strin
/* Find out the final window rectangle, after the WM has added its chrome (titlebar, sidebars etc). */
RECT rect; rect.left = x; rect.top = y; rect.right = x + width; rect.bottom = y + height;
AdjustWindowRectEx(&rect, win_Style, false, win_StyleEx);
AdjustWindowRect(&rect, win_Style, false);
WNDCLASSEXA wc = { 0 };
wc.cbSize = sizeof(WNDCLASSEXA);
@ -419,7 +418,7 @@ void Window_Create(Int32 x, Int32 y, Int32 width, Int32 height, STRING_REF Strin
ErrorHandler_FailWithCode(GetLastError(), "Failed to register window class");
}
win_Handle = CreateWindowExA(
win_StyleEx, atom, title->buffer, win_Style,
0, atom, title->buffer, win_Style,
rect.left, rect.top, RECT_WIDTH(rect), RECT_HEIGHT(rect),
NULL, NULL, win_Instance, NULL);