mirror of
				https://github.com/raylib-cs/raylib-cs
				synced 2025-10-25 05:39:50 -04:00 
			
		
		
		
	Fixed VR issue
- Fixed werid graphical bug with VR. Issue was with the struct for VrDeviceInfo.
This commit is contained in:
		| @@ -31,12 +31,18 @@ | |||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|     <OutputPath>bin\Debug</OutputPath> |     <OutputPath>bin\Debug</OutputPath> | ||||||
|     <AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath> |     <AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |  | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x86'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x86'"> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |  | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> | ||||||
|  |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|  |   </PropertyGroup> | ||||||
|  |  | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="System.Memory" Version="4.5.1" /> |     <PackageReference Include="System.Memory" Version="4.5.1" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   | |||||||
| @@ -1,10 +1,7 @@ | |||||||
| // Raylib - https://github.com/raysan5/raylib/blob/master/src/raylib.h | // Raylib - https://github.com/raysan5/raylib/blob/master/src/raylib.h | ||||||
|  |  | ||||||
| using System; | using System; | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.IO; |  | ||||||
| using System.Runtime.InteropServices; | using System.Runtime.InteropServices; | ||||||
| using System.Security; |  | ||||||
|  |  | ||||||
| namespace Raylib | namespace Raylib | ||||||
| { | { | ||||||
| @@ -371,10 +368,10 @@ namespace Raylib | |||||||
|  |  | ||||||
|         public Color(int r, int g, int b, int a) |         public Color(int r, int g, int b, int a) | ||||||
|         { |         { | ||||||
|             this.r = (byte)r; |             this.r = Convert.ToByte(r); | ||||||
|             this.g = (byte)g; |             this.g = Convert.ToByte(g); | ||||||
|             this.b = (byte)b; |             this.b = Convert.ToByte(b); | ||||||
|             this.a = (byte)a; |             this.a = Convert.ToByte(a); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // extension to access colours from struct |         // extension to access colours from struct | ||||||
| @@ -569,7 +566,7 @@ namespace Raylib | |||||||
|         // public IntPtr locs; |         // public IntPtr locs; | ||||||
|         // [MarshalAs(UnmanagedType.ByValArray, ArraySubType = UnmanagedType.I1, SizeConst = Raylib.MAX_SHADER_LOCATIONS)] |         // [MarshalAs(UnmanagedType.ByValArray, ArraySubType = UnmanagedType.I1, SizeConst = Raylib.MAX_SHADER_LOCATIONS)] | ||||||
|         // [MarshalAs(UnmanagedType.ByValArray, SizeConst = Raylib.MAX_SHADER_LOCATIONS)] |         // [MarshalAs(UnmanagedType.ByValArray, SizeConst = Raylib.MAX_SHADER_LOCATIONS)] | ||||||
|         //[MarshalAs(UnmanagedType.SafeArray, SafeArraySubType = VarEnum.VT_I4)] |         // [MarshalAs(UnmanagedType.SafeArray, SafeArraySubType = VarEnum.VT_I4)] | ||||||
|         // public int[] locs; |         // public int[] locs; | ||||||
|         public fixed int locs[Raylib.MAX_SHADER_LOCATIONS]; |         public fixed int locs[Raylib.MAX_SHADER_LOCATIONS]; | ||||||
|     } |     } | ||||||
| @@ -644,20 +641,21 @@ namespace Raylib | |||||||
|     [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] |     [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] | ||||||
|     public struct RayHitInfo |     public struct RayHitInfo | ||||||
|     { |     { | ||||||
|         public bool hit |         public byte bHit; | ||||||
|         { |  | ||||||
|             get { return Convert.ToBoolean(isHit); } |  | ||||||
|             set { isHit = Convert.ToByte(hit);  } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public byte isHit; |  | ||||||
|         public float distance; |         public float distance; | ||||||
|         public Vector3 position; |         public Vector3 position; | ||||||
|         public Vector3 normal; |         public Vector3 normal; | ||||||
|  |  | ||||||
|  |         // convert c bool(stored as byte) to bool | ||||||
|  |         public bool hit | ||||||
|  |         { | ||||||
|  |             get { return Convert.ToBoolean(bHit); } | ||||||
|  |             set { bHit = Convert.ToByte(hit); } | ||||||
|  |         } | ||||||
|  |  | ||||||
|         public RayHitInfo(bool hit, float distance, Vector3 position, Vector3 normal) |         public RayHitInfo(bool hit, float distance, Vector3 position, Vector3 normal) | ||||||
|         { |         { | ||||||
|             this.isHit = Convert.ToByte(hit); |             this.bHit = Convert.ToByte(hit); | ||||||
|             this.distance = distance; |             this.distance = distance; | ||||||
|             this.position = position; |             this.position = position; | ||||||
|             this.normal = normal; |             this.normal = normal; | ||||||
| @@ -702,7 +700,7 @@ namespace Raylib | |||||||
|  |  | ||||||
|     // Head-Mounted-Display device parameters |     // Head-Mounted-Display device parameters | ||||||
|     [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] |     [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] | ||||||
|     public struct VrDeviceInfo |     public unsafe struct VrDeviceInfo | ||||||
|     { |     { | ||||||
|         public int hResolution; |         public int hResolution; | ||||||
|         public int vResolution; |         public int vResolution; | ||||||
| @@ -712,13 +710,15 @@ namespace Raylib | |||||||
|         public float eyeToScreenDistance; |         public float eyeToScreenDistance; | ||||||
|         public float lensSeparationDistance; |         public float lensSeparationDistance; | ||||||
|         public float interpupillaryDistance; |         public float interpupillaryDistance; | ||||||
|         public float[] lensDistortionValues; |         public fixed float lensDistortionValues[4]; | ||||||
|         public float[] chromaAbCorrection; |         public fixed float chromaAbCorrection[4]; | ||||||
|  |         //public float[] lensDistortionValues; | ||||||
|  |         //public float[] chromaAbCorrection; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     #endregion |     #endregion | ||||||
|  |  | ||||||
|     [SuppressUnmanagedCodeSecurity] |     //[SuppressUnmanagedCodeSecurity] | ||||||
|     public static partial class Raylib |     public static partial class Raylib | ||||||
|     { |     { | ||||||
|         #region Raylib-cs Variables |         #region Raylib-cs Variables | ||||||
| @@ -2202,92 +2202,9 @@ namespace Raylib | |||||||
|         public static extern void EndBlendMode(); |         public static extern void EndBlendMode(); | ||||||
|  |  | ||||||
|         // VR control functions |         // VR control functions | ||||||
| 		// TODO: fix this, it's not using the original raylib dll function |  | ||||||
|         // Get VR device information for some standard devices |         // Get VR device information for some standard devices | ||||||
|         //[DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] |         [DllImport(nativeLibName, CallingConvention = CallingConvention.Cdecl)] | ||||||
|         //public static extern VrDeviceInfo GetVrDeviceInfo(int vrDeviceType); |         public static extern VrDeviceInfo GetVrDeviceInfo(int vrDeviceType); | ||||||
| 		public static VrDeviceInfo GetVrDeviceInfo(VrDeviceType vrDeviceType) |  | ||||||
| 		{ |  | ||||||
| 			VrDeviceInfo hmd = new VrDeviceInfo(); // Current VR device info |  | ||||||
|  |  | ||||||
|             hmd.lensDistortionValues = new float[4]; |  | ||||||
|             hmd.chromaAbCorrection = new float[4]; |  | ||||||
|  |  | ||||||
|             switch (vrDeviceType) |  | ||||||
| 			{ |  | ||||||
| 				case VrDeviceType.HMD_DEFAULT_DEVICE: |  | ||||||
| 				case VrDeviceType.HMD_OCULUS_RIFT_CV1: |  | ||||||
| 					{ |  | ||||||
| 						// Oculus Rift CV1 parameters |  | ||||||
| 						// NOTE: CV1 represents a complete HMD redesign compared to previous versions, |  | ||||||
| 						// new Fresnel-hybrid-asymmetric lenses have been added and, consequently, |  | ||||||
| 						// previous parameters (DK2) and distortion shader (DK2) doesn't work any more. |  | ||||||
| 						// I just defined a set of parameters for simulator that approximate to CV1 stereo rendering |  | ||||||
| 						// but result is not the same obtained with Oculus PC SDK. |  | ||||||
| 						hmd.hResolution = 2160;                 // HMD horizontal resolution in pixels |  | ||||||
| 						hmd.vResolution = 1200;                 // HMD vertical resolution in pixels |  | ||||||
| 						hmd.hScreenSize = 0.133793f;            // HMD horizontal size in meters |  | ||||||
| 						hmd.vScreenSize = 0.0669f;              // HMD vertical size in meters |  | ||||||
| 						hmd.vScreenCenter = 0.04678f;           // HMD screen center in meters |  | ||||||
| 						hmd.eyeToScreenDistance = 0.041f;       // HMD distance between eye and display in meters |  | ||||||
| 						hmd.lensSeparationDistance = 0.07f;     // HMD lens separation distance in meters |  | ||||||
| 						hmd.interpupillaryDistance = 0.07f;     // HMD IPD (distance between pupils) in meters |  | ||||||
| 						hmd.lensDistortionValues[0] = 1.0f;     // HMD lens distortion constant parameter 0 |  | ||||||
| 						hmd.lensDistortionValues[1] = 0.22f;    // HMD lens distortion constant parameter 1 |  | ||||||
| 						hmd.lensDistortionValues[2] = 0.24f;    // HMD lens distortion constant parameter 2 |  | ||||||
| 						hmd.lensDistortionValues[3] = 0.0f;     // HMD lens distortion constant parameter 3 |  | ||||||
| 						hmd.chromaAbCorrection[0] = 0.996f;     // HMD chromatic aberration correction parameter 0 |  | ||||||
| 						hmd.chromaAbCorrection[1] = -0.004f;    // HMD chromatic aberration correction parameter 1 |  | ||||||
| 						hmd.chromaAbCorrection[2] = 1.014f;     // HMD chromatic aberration correction parameter 2 |  | ||||||
| 						hmd.chromaAbCorrection[3] = 0.0f;       // HMD chromatic aberration correction parameter 3 |  | ||||||
|  |  | ||||||
| 						TraceLog((int)LogType.LOG_INFO, "Initializing VR Simulator (Oculus Rift CV1)"); |  | ||||||
| 					} |  | ||||||
| 					break; |  | ||||||
| 				case VrDeviceType.HMD_OCULUS_RIFT_DK2: |  | ||||||
| 					{ |  | ||||||
| 						// Oculus Rift DK2 parameters |  | ||||||
| 						hmd.hResolution = 1280;                 // HMD horizontal resolution in pixels |  | ||||||
| 						hmd.vResolution = 800;                  // HMD vertical resolution in pixels |  | ||||||
| 						hmd.hScreenSize = 0.14976f;             // HMD horizontal size in meters |  | ||||||
| 						hmd.vScreenSize = 0.09356f;             // HMD vertical size in meters |  | ||||||
| 						hmd.vScreenCenter = 0.04678f;           // HMD screen center in meters |  | ||||||
| 						hmd.eyeToScreenDistance = 0.041f;       // HMD distance between eye and display in meters |  | ||||||
| 						hmd.lensSeparationDistance = 0.0635f;   // HMD lens separation distance in meters |  | ||||||
| 						hmd.interpupillaryDistance = 0.064f;    // HMD IPD (distance between pupils) in meters |  | ||||||
| 						hmd.lensDistortionValues[0] = 1.0f;     // HMD lens distortion constant parameter 0 |  | ||||||
| 						hmd.lensDistortionValues[1] = 0.22f;    // HMD lens distortion constant parameter 1 |  | ||||||
| 						hmd.lensDistortionValues[2] = 0.24f;    // HMD lens distortion constant parameter 2 |  | ||||||
| 						hmd.lensDistortionValues[3] = 0.0f;     // HMD lens distortion constant parameter 3 |  | ||||||
| 						hmd.chromaAbCorrection[0] = 0.996f;     // HMD chromatic aberration correction parameter 0 |  | ||||||
| 						hmd.chromaAbCorrection[1] = -0.004f;    // HMD chromatic aberration correction parameter 1 |  | ||||||
| 						hmd.chromaAbCorrection[2] = 1.014f;     // HMD chromatic aberration correction parameter 2 |  | ||||||
| 						hmd.chromaAbCorrection[3] = 0.0f;       // HMD chromatic aberration correction parameter 3 |  | ||||||
|  |  | ||||||
| 						TraceLog((int)LogType.LOG_INFO, "Initializing VR Simulator (Oculus Rift DK2)"); |  | ||||||
| 					} |  | ||||||
| 					break; |  | ||||||
| 				case VrDeviceType.HMD_OCULUS_GO: |  | ||||||
| 					{ |  | ||||||
| 						// TODO: Provide device display and lens parameters |  | ||||||
| 						break; |  | ||||||
| 					} |  | ||||||
| 				case VrDeviceType.HMD_VALVE_HTC_VIVE: |  | ||||||
| 					{ |  | ||||||
| 						// TODO: Provide device display and lens parameters |  | ||||||
| 						break; |  | ||||||
| 					} |  | ||||||
| 				case VrDeviceType.HMD_SONY_PSVR: |  | ||||||
| 					{ |  | ||||||
| 						// TODO: Provide device display and lens parameters |  | ||||||
| 						break; |  | ||||||
| 					} |  | ||||||
| 				default: break; |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			return hmd; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         // Init VR simulator for selected device parameters |         // Init VR simulator for selected device parameters | ||||||
|         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] |         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] | ||||||
| @@ -2475,8 +2392,20 @@ namespace Raylib | |||||||
|         public static extern AudioStream InitAudioStream(uint sampleRate, uint sampleSize, uint channels); |         public static extern AudioStream InitAudioStream(uint sampleRate, uint sampleSize, uint channels); | ||||||
|  |  | ||||||
|         // Update audio stream buffers with data |         // Update audio stream buffers with data | ||||||
|         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] |         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl, EntryPoint = "UpdateAudioStream")] | ||||||
|         public static extern void UpdateAudioStream(AudioStream stream, short[] data, int samplesCount); |         private static extern void UpdateAudioStreamInternal(AudioStream stream, IntPtr data, int samplesCount); | ||||||
|  |  | ||||||
|  |         // Update audio stream buffers with data(byte) | ||||||
|  |         [DllImport(nativeLibName, CallingConvention = CallingConvention.Cdecl)] | ||||||
|  |         public static extern void UpdateAudioStream(AudioStream stream, ref byte[] data, int samplesCount); | ||||||
|  |  | ||||||
|  |         // Update audio stream buffers with data(short) | ||||||
|  |         [DllImport(nativeLibName, CallingConvention = CallingConvention.Cdecl)] | ||||||
|  |         public static extern void UpdateAudioStream(AudioStream stream, ref short[] data, int samplesCount); | ||||||
|  |  | ||||||
|  |         // Update audio stream buffers with data(float) | ||||||
|  |         [DllImport(nativeLibName, CallingConvention = CallingConvention.Cdecl)] | ||||||
|  |         public static extern void UpdateAudioStream(AudioStream stream, ref float[] data, int samplesCount); | ||||||
|  |  | ||||||
|         // Close audio stream and free memory |         // Close audio stream and free memory | ||||||
|         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] |         [DllImport(nativeLibName,CallingConvention = CallingConvention.Cdecl)] | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ namespace Examples | |||||||
|                 var filePath = Console.ReadLine(); |                 var filePath = Console.ReadLine(); | ||||||
|                 var name = Path.GetFileNameWithoutExtension(filePath); |                 var name = Path.GetFileNameWithoutExtension(filePath); | ||||||
|                 var dir = examples + filePath + ".cs"; |                 var dir = examples + filePath + ".cs"; | ||||||
|                |  | ||||||
|                 // run example if it exists |                 // run example if it exists | ||||||
|                 if (File.Exists(dir)) |                 if (File.Exists(dir)) | ||||||
|                 { |                 { | ||||||
| @@ -46,14 +46,14 @@ namespace Examples | |||||||
|                     catch(TargetInvocationException e) |                     catch(TargetInvocationException e) | ||||||
|                     { |                     { | ||||||
|                         Console.WriteLine(e.InnerException.Message); |                         Console.WriteLine(e.InnerException.Message); | ||||||
|                         Console.WriteLine(e.InnerException.StackTrace);       |                         Console.WriteLine(e.InnerException.StackTrace); | ||||||
|                     } |                     } | ||||||
|                     Console.WriteLine(); |                     Console.WriteLine(); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|                     Console.WriteLine(filePath + " is not a valid example"); |                     Console.WriteLine(filePath + " is not a valid example"); | ||||||
|                 }  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -26,19 +26,18 @@ public partial class core_vr_simulator | |||||||
|         int screenHeight = 600; |         int screenHeight = 600; | ||||||
|  |  | ||||||
|         // NOTE: screenWidth/screenHeight should match VR device aspect ratio |         // NOTE: screenWidth/screenHeight should match VR device aspect ratio | ||||||
|  |  | ||||||
|         InitWindow(screenWidth, screenHeight, "raylib [core] example - vr simulator"); |         InitWindow(screenWidth, screenHeight, "raylib [core] example - vr simulator"); | ||||||
|  |  | ||||||
| 		// Init VR simulator (Oculus Rift CV1 parameters) | 		// Init VR simulator (Oculus Rift CV1 parameters) | ||||||
|         InitVrSimulator(GetVrDeviceInfo(HMD_OCULUS_RIFT_CV1)); |         InitVrSimulator(GetVrDeviceInfo((int)HMD_OCULUS_RIFT_CV1)); | ||||||
|  |  | ||||||
|         // Define the camera to look into our 3d world |         // Define the camera to look into our 3d world | ||||||
|         Camera3D camera; |         Camera3D camera; | ||||||
|         camera.position = new Vector3( 5.0f, 2.0f, 5.0f );    // Camera3D position |         camera.position = new Vector3( 5.0f, 2.0f, 5.0f );    // Camera3D position | ||||||
|         camera.target = new Vector3( 0.0f, 2.0f, 0.0f );      // Camera3D looking at point |         camera.target = new Vector3( 0.0f, 2.0f, 0.0f );      // Camera3D looking at point | ||||||
|         camera.up = new Vector3( 0.0f, 1.0f, 0.0f );          // Camera3D up vector (rotation towards target) |         camera.up = new Vector3( 0.0f, 1.0f, 0.0f );          // Camera3D up vector (rotation towards target) | ||||||
|         camera.fovy = 60.0f;                                // Camera3D field-of-view Y |         camera.fovy = 60.0f;                                  // Camera3D field-of-view Y | ||||||
|         camera.type = (int)CAMERA_PERSPECTIVE;                   // Camera3D type |         camera.type = (int)CAMERA_PERSPECTIVE;                // Camera3D type | ||||||
|  |  | ||||||
|         Vector3 cubePosition = new Vector3( 0.0f, 0.0f, 0.0f ); |         Vector3 cubePosition = new Vector3( 0.0f, 0.0f, 0.0f ); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,5 @@ | |||||||
| using Raylib; | using Raylib; | ||||||
| using static Raylib.Raylib; | using static Raylib.Raylib; | ||||||
| using static Raylib.Model; |  | ||||||
| using static Raylib.CameraMode; |  | ||||||
| using System; |  | ||||||
|  |  | ||||||
| public enum LightType | public enum LightType | ||||||
| { | { | ||||||
| @@ -26,18 +23,8 @@ public struct Light | |||||||
| 	public int colorLoc; | 	public int colorLoc; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| public partial class models_material_pbr | public partial class models_material_pbr | ||||||
| { | { | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/******************************************************************************************* | 	/******************************************************************************************* | ||||||
| 	* | 	* | ||||||
| 	*   raylib [models] example - PBR material | 	*   raylib [models] example - PBR material | ||||||
| @@ -124,7 +111,6 @@ public partial class models_material_pbr | |||||||
| 				DrawFPS(10, 10); | 				DrawFPS(10, 10); | ||||||
|  |  | ||||||
| 			EndDrawing(); | 			EndDrawing(); | ||||||
| 			//---------------------------------------------------------------------------------- |  | ||||||
| 			//---------------------------------------------------------------------------------- | 			//---------------------------------------------------------------------------------- | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -262,5 +248,3 @@ public partial class models_material_pbr | |||||||
|  |  | ||||||
| 			UpdateLightValues(shader, light); | 			UpdateLightValues(shader, light); | ||||||
| 			lightsCount++; | 			lightsCount++; | ||||||
| 		} |  | ||||||
| 		return light; |  | ||||||
|   | |||||||
| @@ -4,13 +4,14 @@ | |||||||
|     <TargetFramework>netcoreapp2.1</TargetFramework> |     <TargetFramework>netcoreapp2.1</TargetFramework> | ||||||
|     <ApplicationIcon>raylib-cs.ico</ApplicationIcon> |     <ApplicationIcon>raylib-cs.ico</ApplicationIcon> | ||||||
|     <Platforms>AnyCPU;x64;x86</Platforms> |     <Platforms>AnyCPU;x64;x86</Platforms> | ||||||
|     <StartupObject>Test.NetCore.Program</StartupObject> |     <StartupObject>physics_demo</StartupObject> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x86'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x86'"> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> | ||||||
|     <Optimize>false</Optimize> |     <Optimize>false</Optimize> | ||||||
| @@ -18,6 +19,10 @@ | |||||||
|     <Prefer32Bit>true</Prefer32Bit> |     <Prefer32Bit>true</Prefer32Bit> | ||||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> |     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> | ||||||
|  |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|  |   </PropertyGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <ProjectReference Include="..\Bindings\Bindings.csproj" /> |     <ProjectReference Include="..\Bindings\Bindings.csproj" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   | |||||||
| @@ -11,10 +11,15 @@ | |||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> | ||||||
|  |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|  |   </PropertyGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <ProjectReference Include="..\Bindings\Bindings.csproj" /> |     <ProjectReference Include="..\Bindings\Bindings.csproj" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   | |||||||
| @@ -46,6 +46,7 @@ | |||||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> |     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||||
|     <Prefer32Bit>true</Prefer32Bit> |     <Prefer32Bit>true</Prefer32Bit> | ||||||
|     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     <Optimize>false</Optimize> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x64'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x64'"> | ||||||
|     <OutputPath>bin\x64\Release\</OutputPath> |     <OutputPath>bin\x64\Release\</OutputPath> | ||||||
| @@ -56,6 +57,7 @@ | |||||||
|     <ErrorReport>prompt</ErrorReport> |     <ErrorReport>prompt</ErrorReport> | ||||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> |     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||||
|     <Prefer32Bit>true</Prefer32Bit> |     <Prefer32Bit>true</Prefer32Bit> | ||||||
|  |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'"> | ||||||
|     <DebugSymbols>true</DebugSymbols> |     <DebugSymbols>true</DebugSymbols> | ||||||
| @@ -66,6 +68,7 @@ | |||||||
|     <ErrorReport>prompt</ErrorReport> |     <ErrorReport>prompt</ErrorReport> | ||||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> |     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||||
|     <Prefer32Bit>true</Prefer32Bit> |     <Prefer32Bit>true</Prefer32Bit> | ||||||
|  |     <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'"> | ||||||
|     <OutputPath>bin\x86\Release\</OutputPath> |     <OutputPath>bin\x86\Release\</OutputPath> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user