Skip to content

Commit

Permalink
Move common types to separate project
Browse files Browse the repository at this point in the history
The Aardvark.Rendering project contains some types that are used
by projects that do not actually require a full blown Aardvark.Rendering
dependency. This commit moves types such as IndexedGeometry and
Camera to a separate project that can be referenced without pulling
in a plethora of unrelated dependencies.
  • Loading branch information
hyazinthh committed May 14, 2024
1 parent 6332233 commit 3e7fc9d
Show file tree
Hide file tree
Showing 30 changed files with 749 additions and 705 deletions.
8 changes: 4 additions & 4 deletions paket.lock
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ NUGET
NETStandard.Library (>= 1.6.1) - restriction: || (&& (== net471) (< net40)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
SharpDX.Direct3D9 (4.0.1)
Microsoft.NETCore.App (>= 1.0.5) - restriction: || (&& (== net471) (>= netcoreapp1.0)) (== net6.0) (== net6.0-windows7.0) (&& (== netstandard2.0) (>= netcoreapp1.0))
NETStandard.Library (>= 1.6.1) - restriction: || (&& (== net471) (< net40)) (&& (== net6.0) (< netcoreapp1.0)) (&& (== net6.0-windows7.0) (< netcoreapp1.0)) (== netstandard2.0)
NETStandard.Library (>= 1.6.1) - restriction: || (&& (== net471) (== net6.0)) (&& (== net471) (== net6.0-windows7.0)) (&& (== net471) (< net40)) (&& (== net6.0) (< netcoreapp1.0)) (&& (== net6.0-windows7.0) (< netcoreapp1.0)) (== netstandard2.0)
SharpDX (>= 4.0.1)
SharpZipLib (1.4.2)
System.Memory (>= 4.5.4) - restriction: || (== net471) (&& (== net6.0) (< netstandard2.1)) (&& (== net6.0-windows7.0) (< netstandard2.1)) (== netstandard2.0)
Expand Down Expand Up @@ -241,7 +241,7 @@ NUGET
System.Threading (>= 4.3) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
System.Memory (4.5.5)
System.Buffers (>= 4.5.1) - restriction: || (== net471) (&& (== net6.0) (>= monotouch)) (&& (== net6.0) (>= net461)) (&& (== net6.0) (< netcoreapp2.0)) (&& (== net6.0) (< netstandard1.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (>= xamarinios)) (&& (== net6.0) (>= xamarinmac)) (&& (== net6.0) (>= xamarintvos)) (&& (== net6.0) (>= xamarinwatchos)) (&& (== net6.0-windows7.0) (>= monotouch)) (&& (== net6.0-windows7.0) (>= net461)) (&& (== net6.0-windows7.0) (< netcoreapp2.0)) (&& (== net6.0-windows7.0) (< netstandard1.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (>= xamarinios)) (&& (== net6.0-windows7.0) (>= xamarinmac)) (&& (== net6.0-windows7.0) (>= xamarintvos)) (&& (== net6.0-windows7.0) (>= xamarinwatchos)) (== netstandard2.0)
System.Numerics.Vectors (>= 4.4) - restriction: || (&& (== net471) (< net45)) (&& (== net6.0) (< netcoreapp2.0)) (&& (== net6.0-windows7.0) (< netcoreapp2.0)) (== netstandard2.0)
System.Numerics.Vectors (>= 4.4) - restriction: || (&& (== net471) (== net6.0)) (&& (== net471) (== net6.0-windows7.0)) (&& (== net471) (< net45)) (&& (== net6.0) (< netcoreapp2.0)) (&& (== net6.0-windows7.0) (< netcoreapp2.0)) (== netstandard2.0)
System.Numerics.Vectors (>= 4.5) - restriction: || (== net471) (&& (== net6.0) (>= net461)) (&& (== net6.0-windows7.0) (>= net461)) (&& (== netstandard2.0) (>= net461))
System.Runtime.CompilerServices.Unsafe (>= 4.5.3) - restriction: || (== net471) (&& (== net6.0) (>= monotouch)) (&& (== net6.0) (>= net461)) (&& (== net6.0) (< netcoreapp2.0)) (&& (== net6.0) (< netcoreapp2.1)) (&& (== net6.0) (< netstandard1.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (>= uap10.1)) (&& (== net6.0) (>= xamarinios)) (&& (== net6.0) (>= xamarinmac)) (&& (== net6.0) (>= xamarintvos)) (&& (== net6.0) (>= xamarinwatchos)) (&& (== net6.0-windows7.0) (>= monotouch)) (&& (== net6.0-windows7.0) (>= net461)) (&& (== net6.0-windows7.0) (< netcoreapp2.0)) (&& (== net6.0-windows7.0) (< netcoreapp2.1)) (&& (== net6.0-windows7.0) (< netstandard1.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (>= uap10.1)) (&& (== net6.0-windows7.0) (>= xamarinios)) (&& (== net6.0-windows7.0) (>= xamarinmac)) (&& (== net6.0-windows7.0) (>= xamarintvos)) (&& (== net6.0-windows7.0) (>= xamarinwatchos)) (== netstandard2.0)
System.Numerics.Vectors (4.5)
Expand All @@ -258,10 +258,10 @@ NUGET
System.Reflection.Primitives (>= 4.3) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
System.Runtime (>= 4.3) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
System.Reflection.Emit (4.7) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
System.Reflection.Emit.ILGeneration (>= 4.7) - restriction: || (&& (== net471) (< net45)) (&& (== net471) (< netstandard1.1)) (&& (== net471) (< netstandard2.0) (>= wpa81)) (&& (== net471) (>= uap10.1)) (&& (== net6.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0) (< netstandard1.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (>= uap10.1)) (&& (== net6.0-windows7.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0-windows7.0) (< netstandard1.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (>= uap10.1)) (== netstandard2.0)
System.Reflection.Emit.ILGeneration (>= 4.7) - restriction: || (&& (== net471) (== net6.0)) (&& (== net471) (== net6.0-windows7.0)) (&& (== net471) (< net45)) (&& (== net471) (< netstandard1.1)) (&& (== net471) (< netstandard2.0) (>= wpa81)) (&& (== net471) (>= uap10.1)) (&& (== net6.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0) (< netstandard1.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (>= uap10.1)) (&& (== net6.0-windows7.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0-windows7.0) (< netstandard1.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (>= uap10.1)) (== netstandard2.0)
System.Reflection.Emit.ILGeneration (4.7) - restriction: || (&& (== net471) (< net45)) (&& (== net471) (< netstandard2.0) (>= wpa81)) (&& (== net471) (< portable-net45+wp8)) (&& (== net471) (>= uap10.1)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
System.Reflection.Emit.Lightweight (4.7)
System.Reflection.Emit.ILGeneration (>= 4.7) - restriction: || (&& (== net471) (< net45)) (&& (== net471) (< netstandard2.0) (>= wpa81)) (&& (== net471) (< portable-net45+wp8)) (&& (== net471) (>= uap10.1)) (&& (== net6.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (< portable-net45+wp8)) (&& (== net6.0) (>= uap10.1)) (&& (== net6.0-windows7.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (< portable-net45+wp8)) (&& (== net6.0-windows7.0) (>= uap10.1)) (== netstandard2.0)
System.Reflection.Emit.ILGeneration (>= 4.7) - restriction: || (&& (== net471) (== net6.0)) (&& (== net471) (== net6.0-windows7.0)) (&& (== net471) (< net45)) (&& (== net471) (< netstandard2.0) (>= wpa81)) (&& (== net471) (< portable-net45+wp8)) (&& (== net471) (>= uap10.1)) (&& (== net6.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0) (< netstandard2.0)) (&& (== net6.0) (< portable-net45+wp8)) (&& (== net6.0) (>= uap10.1)) (&& (== net6.0-windows7.0) (< netcoreapp2.0) (< netstandard2.1)) (&& (== net6.0-windows7.0) (< netstandard2.0)) (&& (== net6.0-windows7.0) (< portable-net45+wp8)) (&& (== net6.0-windows7.0) (>= uap10.1)) (== netstandard2.0)
System.Reflection.Extensions (4.3) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
Microsoft.NETCore.Platforms (>= 1.1) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
Microsoft.NETCore.Targets (>= 1.1) - restriction: || (&& (== net471) (< net45)) (== net6.0) (== net6.0-windows7.0) (== netstandard2.0)
Expand Down
40 changes: 40 additions & 0 deletions src/Aardvark.Rendering.Common/Aardvark.Rendering.Common.fsproj
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netstandard2.0</TargetFramework>
<AssemblyName>Aardvark.Rendering.Common</AssemblyName>
<OutputType>Library</OutputType>
<DisableImplicitFSharpCoreReference>true</DisableImplicitFSharpCoreReference>
<GenerateDocumentationFile>true</GenerateDocumentationFile>
<WarnOn>3389;3390;3395</WarnOn>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<OutputPath>..\..\bin\Debug\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">
<OutputPath>..\..\bin\Release</OutputPath>
</PropertyGroup>
<ItemGroup>
<Compile Include="Modes\ComparisonFunction.fs" />
<Compile Include="Modes\FillMode.fs" />
<Compile Include="Modes\CullMode.fs" />
<Compile Include="Modes\WindingOrder.fs" />
<Compile Include="Modes\BlendMode.fs" />
<Compile Include="Modes\StencilMode.fs" />
<Compile Include="Modes\DepthRange.fs" />
<Compile Include="Modes\DepthTest.fs" />
<Compile Include="Modes\DepthBias.fs" />
<Compile Include="Modes\ColorMask.fs" />
<Compile Include="Sampler\TextureFilter.fs" />
<Compile Include="Sampler\SamplerState.fs" />
<Compile Include="ArrayVisitor.fs" />
<Compile Include="IndexedGeometry.fs" />
<Compile Include="DefaultSemantic.fs" />
<Compile Include="Camera\Frustum.fs" />
<Compile Include="Camera\CameraView.fs" />
<Compile Include="Camera\Camera.fs" />
<None Include="paket.references" />
</ItemGroup>
<Import Project="..\..\.paket\Paket.Restore.targets" />
</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ type ArrayVisitor<'r>() =

static let get (t : Type) =
cache.GetOrAdd(t, Func<_,_>(fun t ->
let dMeth =
let dMeth =
DynamicMethod(
"ArrayVisitor",
MethodAttributes.Static ||| MethodAttributes.Public,
Expand All @@ -32,7 +32,7 @@ type ArrayVisitor<'r>() =
il.Emit(OpCodes.Ldarg_1)
il.EmitCall(OpCodes.Callvirt, mRun, null)
il.Emit(OpCodes.Ret)

let t = typeof<Func<ArrayVisitor<'r>, Array, 'r>>
let del = dMeth.CreateDelegate(t) |> unbox<Func<ArrayVisitor<'r>, Array, 'r>>
fun v a -> del.Invoke(v,a)
Expand Down
274 changes: 274 additions & 0 deletions src/Aardvark.Rendering.Common/Camera/Camera.fs
Original file line number Diff line number Diff line change
@@ -0,0 +1,274 @@
namespace Aardvark.Rendering

open System
open Aardvark.Base

type Camera =
{
cameraView : CameraView
frustum : Frustum
}

[<CompilationRepresentation(CompilationRepresentationFlags.ModuleSuffix)>]
module Camera =

let inline create (view : CameraView) (frustum : Frustum) = { cameraView = view; frustum = frustum }
let inline viewTrafo (cam : Camera) = cam.cameraView |> CameraView.viewTrafo
let inline projTrafo (cam : Camera) = cam.frustum |> Frustum.projTrafo
let inline viewProjTrafo (cam : Camera) = (CameraView.viewTrafo cam.cameraView) * (Frustum.projTrafo cam.frustum)
let inline cameraView (cam : Camera) = cam.cameraView
let inline frustum (cam : Camera) = cam.frustum

let inline location (cam : Camera) = cam.cameraView |> CameraView.location
let inline forward (cam : Camera) = cam.cameraView |> CameraView.forward
let inline up (cam : Camera) = cam.cameraView |> CameraView.up
let inline right (cam : Camera) = cam.cameraView |> CameraView.right
let inline backward (cam : Camera) = cam.cameraView |> CameraView.backward
let inline down (cam : Camera) = cam.cameraView |> CameraView.down
let inline left (cam : Camera) = cam.cameraView |> CameraView.left
let inline near (cam : Camera) = cam.frustum.near
let inline far (cam : Camera) = cam.frustum.far

[<CompilationRepresentation(CompilationRepresentationFlags.ModuleSuffix)>]
module ViewProjection =

[<AutoOpen>]
module private Helpers =
let inline toPlane (v : V4d) =
Plane3d(-v.XYZ, v.W)

let inline maxDir (dir : V3d) (b : Box3d) =
V4d(
(if dir.X > 0.0 then b.Max.X else b.Min.X),
(if dir.Y > 0.0 then b.Max.Y else b.Min.Y),
(if dir.Z > 0.0 then b.Max.Z else b.Min.Z),
1.0
)

let inline height (plane : V4d) (b : Box3d) =
plane.Dot(maxDir plane.XYZ b)


let intersect (a : Plane3d) (b : Plane3d) (c : Plane3d) =
let mutable pt = V3d.Zero
if a.Intersects(b,c, &pt) then
pt
else
failwith "no plane intersection"


let inline proj (pt : V3d) = V3d(pt.XY / -pt.Z, -pt.Z)

let containing (viewPos : V3d) (bounds : Box3d) =
let angularRange =
bounds.ComputeCorners()
|> Array.map (fun world ->
let dir = world - viewPos
dir.SphericalFromCartesian()
)
|> Box2d

let forward = angularRange.Center.CartesianFromSpherical()

let mutable closest = V3d.Zero
let mutable farthest = V3d.Zero
bounds.GetMinMaxInDirection(forward, &closest, &farthest)
let near = Vec.Distance(viewPos, closest)
let far = Vec.Distance(viewPos, farthest)

let halfAngularSize = angularRange.Size * 0.5
let l = -near * Fun.Tan(halfAngularSize.X)
let r = -l
let t = near * Fun.Tan(halfAngularSize.Y)
let b = -t

let sky =
if Fun.ApproximateEquals(abs forward.Z, 1.0, Constant.PositiveTinyValue) then V3d.OIO
else V3d.OOI

let view = CameraView.lookAt viewPos (viewPos + forward) sky
let proj =
{
left = l
right = r
top = t
bottom = b
near = near
far = far
isOrtho = false
}

view, proj

let intersects (b : Box3d) (viewProj : Trafo3d) =
let fw = viewProj.Forward
let r0 = fw.R0
let r1 = fw.R1
let r2 = fw.R2
let r3 = fw.R3

height (r3 + r0) b >= 0.0 &&
height (r3 - r0) b >= 0.0 &&
height (r3 + r1) b >= 0.0 &&
height (r3 - r1) b >= 0.0 &&
height (r3 + r2) b >= 0.0 &&
height (r3 - r2) b >= 0.0

let contains (point : V3d) (viewProj : Trafo3d) =
let fw = viewProj.Forward
let r0 = fw.R0
let r1 = fw.R1
let r2 = fw.R2
let r3 = fw.R3
let p = V4d(point, 1.0)

Vec.Dot((r3 + r0), p) >= 0.0 &&
Vec.Dot((r3 - r0), p) >= 0.0 &&
Vec.Dot((r3 + r1), p) >= 0.0 &&
Vec.Dot((r3 - r1), p) >= 0.0 &&
Vec.Dot((r3 + r2), p) >= 0.0 &&
Vec.Dot((r3 - r2), p) >= 0.0

let private frustumCorners =
[|
V3d(-1.0, -1.0, -1.0)
V3d( 1.0, -1.0, -1.0)
V3d( 1.0, 1.0, -1.0)
V3d(-1.0, 1.0, -1.0)
V3d(-1.0, -1.0, 1.0)
V3d( 1.0, -1.0, 1.0)
V3d( 1.0, 1.0, 1.0)
V3d(-1.0, 1.0, 1.0)
|]

let private cornerIndices =
[|
1;2; 2;6; 6;5; 5;1;
2;3; 3;7; 7;6; 4;5;
7;4; 3;0; 0;4; 0;1;
|]

let toIndexedGeometry (v : CameraView) (p : Frustum) (color : C4b) =
let invViewProj = (CameraView.viewTrafo v * Frustum.projTrafo p).Inverse
let positions = frustumCorners |> Array.map (invViewProj.Forward.TransformPosProj >> V3f)

let attributes = SymbolDict<Array>()
attributes.[DefaultSemantic.Positions] <- cornerIndices |> Array.map (fun i -> positions.[i])
attributes.[DefaultSemantic.Colors] <- Array.create cornerIndices.Length color

IndexedGeometry(
Mode = IndexedGeometryMode.LineList,
IndexedAttributes = attributes
)

let leftPlane (viewProj : Trafo3d) =
let r0 = viewProj.Forward.R0
let r3 = viewProj.Forward.R3
r3 - r0

let rightPlane (viewProj : Trafo3d) =
let r0 = viewProj.Forward.R0
let r3 = viewProj.Forward.R3
r3 + r0

let toHull3d (viewProj : Trafo3d) =
let r0 = viewProj.Forward.R0
let r1 = viewProj.Forward.R1
let r2 = viewProj.Forward.R2
let r3 = viewProj.Forward.R3

Hull3d [|
r3 - r0 |> toPlane // right
r3 + r0 |> toPlane // left
r3 + r1 |> toPlane // bottom
r3 - r1 |> toPlane // top
r3 + r2 |> toPlane // near
r3 - r2 |> toPlane // far
|]

let inline toFastHull3d (viewProj : Trafo3d) =
FastHull3d(toHull3d viewProj)

let intersectsDX (b : Box3d) (viewProj : Trafo3d) =
let fw = viewProj.Forward
let r0 = fw.R0
let r1 = fw.R1
let r2 = fw.R2
let r3 = fw.R3

height (r3 + r0) b >= 0.0 &&
height (r3 - r0) b >= 0.0 &&
height (r3 + r1) b >= 0.0 &&
height (r3 - r1) b >= 0.0 &&
height ( r2) b >= 0.0 &&
height (r3 - r2) b >= 0.0

let containsDX (point : V3d) (viewProj : Trafo3d) =
let fw = viewProj.Forward
let r0 = fw.R0
let r1 = fw.R1
let r2 = fw.R2
let r3 = fw.R3
let p = V4d(point, 1.0)

Vec.Dot((r3 + r0), p) >= 0.0 &&
Vec.Dot((r3 - r0), p) >= 0.0 &&
Vec.Dot((r3 + r1), p) >= 0.0 &&
Vec.Dot((r3 - r1), p) >= 0.0 &&
Vec.Dot(( r2), p) >= 0.0 &&
Vec.Dot((r3 - r2), p) >= 0.0

let toHull3dDX (viewProj : Trafo3d) =
let r0 = viewProj.Forward.R0
let r1 = viewProj.Forward.R1
let r2 = viewProj.Forward.R2
let r3 = viewProj.Forward.R3

Hull3d [|
r3 + r0 |> toPlane
r3 - r0 |> toPlane
r3 + r1 |> toPlane
r3 - r1 |> toPlane
r2 |> toPlane
r3 - r2 |> toPlane
|]

let inline toFastHull3dDX (viewProj : Trafo3d) =
FastHull3d(toHull3dDX viewProj)

let mergeStereo (lProj : Trafo3d) (rProj : Trafo3d) =
let p (v : V4d) = Plane3d(v.XYZ, -v.W)

let lPlane = rightPlane lProj |> p
let rPlane = leftPlane rProj |> p

let location = intersect lPlane rPlane Plane3d.YPlane
let view = Trafo3d.Translation(-location)

let points =
Array.concat [|
frustumCorners |> Array.map lProj.Backward.TransformPosProj
frustumCorners |> Array.map rProj.Backward.TransformPosProj
|]

let projected =
points |> Array.map (view.Forward.TransformPos >> proj)

let bounds = Box3d(projected)

let near = bounds.Min.Z
let far = bounds.Max.Z

let frustum =
{
left = bounds.Min.X * near
right = bounds.Max.X * near
top = bounds.Max.Y * near
bottom = bounds.Min.Y * near
near = near
far = far
isOrtho = false
}

let proj = Frustum.projTrafo frustum
view * proj
Loading

0 comments on commit 3e7fc9d

Please sign in to comment.