-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathPicoGK_Lattice.cs
84 lines (78 loc) · 2.72 KB
/
PicoGK_Lattice.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
//
// SPDX-License-Identifier: Apache-2.0
//
// PicoGK ("peacock") is a compact software kernel for computational geometry,
// specifically for use in Computational Engineering Models (CEM).
//
// For more information, please visit https://picogk.org
//
// PicoGK is developed and maintained by LEAP 71 - © 2023-2025 by LEAP 71
// https://leap71.com
//
// Computational Engineering will profoundly change our physical world in the
// years ahead. Thank you for being part of the journey.
//
// We have developed this library to be used widely, for both commercial and
// non-commercial projects alike. Therefore, we have released it under a
// permissive open-source license.
//
// The foundation of PicoGK is a thin layer on top of the powerful open-source
// OpenVDB project, which in turn uses many other Free and Open Source Software
// libraries. We are grateful to be able to stand on the shoulders of giants.
//
// LEAP 71 licenses this file to you under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with the
// License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, THE SOFTWARE IS
// PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED.
//
// See the License for the specific language governing permissions and
// limitations under the License.
//
using System.Diagnostics;
using System.Numerics;
namespace PicoGK
{
public partial class Lattice
{
public Lattice()
{
m_hThis = _hCreate();
Debug.Assert(m_hThis != IntPtr.Zero);
}
public void AddSphere( in Vector3 vecCenter,
float fRadius)
{
_AddSphere(m_hThis, vecCenter, fRadius);
}
public void AddBeam( in Vector3 vecA,
float fRadA,
in Vector3 vecB,
float fRadB,
bool bRoundCap = true)
{
_AddBeam( m_hThis,
in vecA,
in vecB,
fRadA,
fRadB,
bRoundCap);
}
public void AddBeam( in Vector3 vecA,
in Vector3 vecB,
float fRadA,
float fRadB,
bool bRoundCap = true)
{
_AddBeam( m_hThis,
in vecA,
in vecB,
fRadA,
fRadB,
bRoundCap);
}
}
}