2
0
mirror of https://github.com/raylib-cs/raylib-cs synced 2025-10-23 05:29:50 -04:00

Fixed VR issue

- Fixed werid graphical bug with VR. Issue was with the struct for VrDeviceInfo.
This commit is contained in:
2018-11-22 15:00:25 +00:00
parent 654d9c4347
commit 2e6a583193
8 changed files with 62 additions and 131 deletions

View File

@@ -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>

View File

@@ -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)]

View File

@@ -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 );

View File

@@ -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;

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>