FineKernelToolKit 4.2.13
読み取り中…
検索中…
一致する文字列を見つけられません
Gregory.h
[詳解]
1#if !defined(__FK_GREGORY_HEADER__)
2#define __FK_GREGORY_HEADER__
3
4#include <FK/Surface.h>
5
6namespace FK {
8
41 class fk_Gregory : public fk_Surface {
42
43#if !defined(FK_DOXYGEN_USER_PROCESS)
44 class Member {
45 public:
46 fk_Vector boundary[4][4];
47 fk_Vector deriv[4][4];
48 fk_Vector bezier[4][4];
49
50 Member(void);
51 };
52
53#endif
54
55 public:
58
60 virtual ~fk_Gregory();
61
63
66 void init(void);
67
69
78 bool setBoundary(fk_UV uv, int vID, const fk_Vector &pos);
79
81
90 bool setDerivative(fk_UV uv, int vID, const fk_Vector &pos);
91
93
102
104
113
115
122
124
133
135
162 bool connect(fk_Gregory *surf, fk_UV thisUV, fk_UV otherUV,
163 bool d, bool mode = false);
164
166
174 fk_Vector pos(double u, double v);
175
177
185 fk_Vector uDeriv(double u, double v);
186
188
196 fk_Vector vDeriv(double u, double v);
197
198 private:
199 std::unique_ptr<Member> _m;
200
201 void C1Connect(fk_UV, fk_Vector *);
202 void G1Connect(fk_UV, fk_Vector *);
203 void MakeBezier(double, double);
204 void MakeTable(void);
205 };
206}
207
208#endif // __FK_BEZSURFACE_HEADER__
209
210/****************************************************************************
211 *
212 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
213 *
214 * Redistribution and use in source and binary forms,
215 * with or without modification, are permitted provided that the
216 * following conditions are met:
217 *
218 * - Redistributions of source code must retain the above
219 * copyright notice, this list of conditions and the
220 * following disclaimer.
221 *
222 * - Redistributions in binary form must reproduce the above
223 * copyright notice, this list of conditions and the
224 * following disclaimer in the documentation and/or
225 * other materials provided with the distribution.
226 *
227 * - Neither the name of the copyright holders nor the names
228 * of its contributors may be used to endorse or promote
229 * products derived from this software without specific
230 * prior written permission.
231 *
232 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
233 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
234 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
235 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
236 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
237 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
238 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
239 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
240 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
241 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
242 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
243 * POSSIBILITY OF SUCH DAMAGE.
244 *
245 ****************************************************************************/
246/****************************************************************************
247 *
248 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
249 *
250 * 本ソフトウェアおよびソースコードのライセンスは、基本的に
251 * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
252 *
253 * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
254 * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
255 *
256 * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
257 * および下記免責条項を含めること。
258 *
259 * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
260 * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
261 * 含めること。
262 *
263 * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
264 * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
265 * コントリビューターの名前を使用してはならない。
266 *
267 * 本ソフトウェアは、著作権者およびコントリビューターによって「現
268 * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
269 * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
270 * に限定されない、いかなる保証もないものとします。著作権者もコン
271 * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
272 * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
273 * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
274 * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
275 * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
276 * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
277 * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
278 * ついて、一切責任を負わないものとします。
279 *
280 ****************************************************************************/
Gregory 曲面を生成、管理するクラス
Definition Gregory.h:41
void adjustDerivative(void)
流れベクトル制御点自動設定関数
fk_Vector getBoundary(fk_UV uv, int vID)
境界制御点参照関数
virtual ~fk_Gregory()
デストラクタ
fk_Vector vDeriv(double u, double v)
曲面 v 方向偏微分ベクトル算出関数
fk_Gregory(void)
コンストラクタ
fk_Vector uDeriv(double u, double v)
曲面 u 方向偏微分ベクトル算出関数
fk_Vector getDerivative(fk_UV uv, int vID)
流れベクトル制御点参照関数
void adjustDerivative(fk_UV uv)
境界別流れベクトル制御点自動設定関数
bool connect(fk_Gregory *surf, fk_UV thisUV, fk_UV otherUV, bool d, bool mode=false)
隣接曲面G1連続接続関数
fk_Vector pos(double u, double v)
曲面点算出関数
bool setDerivative(fk_UV uv, int vID, const fk_Vector &pos)
流れベクトル制御点設定関数
void init(void)
初期化用関数
bool setBoundary(fk_UV uv, int vID, const fk_Vector &pos)
境界制御点設定関数
曲面用純粋仮想クラス
Definition Surface.h:36
3次元ベクトルを管理するクラス
Definition Vector.h:45
Fine Kernel Toolkit 名前空間
Definition Angle.h:6
fk_UV
曲面の uv 方向を表す列挙型
Definition Surface.h:12