FineKernelToolKit 4.2.13
読み取り中…
検索中…
一致する文字列を見つけられません
Graph_CLI.h
[詳解]
1#pragma once
2
3#include <FK/Graph.h>
4#include "Shape_CLI.h"
5#include "GraphNode_CLI.h"
6#include "GraphEdge_CLI.h"
7#using <System.dll>
8
9namespace FK_CLI
10{
11 using namespace System::Collections::Generic;
12
13 public enum class fk_CostStatus {
14 CONTINUE,
15 FINISH,
16 ERROR
17 };
18
20
46 public ref class fk_Graph : fk_Shape {
47 internal:
48 ::FK::fk_Graph * GetP(void);
49 static fk_CostStatus getCS(::FK::fk_CostStatus);
50 cli::array<fk_GraphNode^>^ _nodeArray;
51 Dictionary<unsigned int, fk_GraphEdge^>^ _edgeMap;
52
53 public:
55
62 fk_Graph(unsigned int num);
63
66
69
71
74 property unsigned int NodeSize {
75 unsigned int get();
76 }
77
79
84 property unsigned int MaxEdgeID {
85 unsigned int get();
86 }
87
89
96 fk_GraphNode^ GetNode(unsigned int ID);
97
99
104 List<fk_GraphNode ^> ^GetAllNode(void);
105
107
114 fk_GraphEdge^ GetEdge(unsigned int ID);
115
117
122 List<fk_GraphEdge ^> ^GetAllEdge(void);
123
125
135
138
140
154
156
164
166
169
171
188 bool MakeCostTable(unsigned int tableID, fk_CostType type);
189
191
203 bool SetCostDirection(unsigned int tableID, fk_CostDirection direction);
204
206
216 bool SetEdgeCostID(unsigned int tableID, unsigned int edgeCostID);
217
219
226 unsigned int GetNodeCostID(unsigned int tableID);
227
229
236 void SetStart(unsigned int tableID, fk_GraphNode^ node);
237
239
246 void AddGoal(unsigned int tableID, fk_GraphNode^ node);
247
249
255 void RemoveGoal(unsigned int tableID, fk_GraphNode^ node);
256
258
263 void ClearGoal(unsigned int tableID);
264
266
275 bool InitCostTable(unsigned int tableID);
276
278
293 fk_CostStatus UpdateCostTable(unsigned int tableID);
294
296
311 fk_CostStatus GetCostStatus(unsigned int tableID);
312
314
328 List<fk_GraphNode^>^ GetOnePath(unsigned int tableID);
330 };
331}
332
333/****************************************************************************
334 *
335 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
336 *
337 * Redistribution and use in source and binary forms,
338 * with or without modification, are permitted provided that the
339 * following conditions are met:
340 *
341 * - Redistributions of source code must retain the above
342 * copyright notice, this list of conditions and the
343 * following disclaimer.
344 *
345 * - Redistributions in binary form must reproduce the above
346 * copyright notice, this list of conditions and the
347 * following disclaimer in the documentation and/or
348 * other materials provided with the distribution.
349 *
350 * - Neither the name of the copyright holders nor the names
351 * of its contributors may be used to endorse or promote
352 * products derived from this software without specific
353 * prior written permission.
354 *
355 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
356 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
357 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
358 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
359 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
360 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
361 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
362 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
363 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
364 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
365 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
366 * POSSIBILITY OF SUCH DAMAGE.
367 *
368 ****************************************************************************/
369/****************************************************************************
370 *
371 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
372 *
373 * 本ソフトウェアおよびソースコードのライセンスは、基本的に
374 * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
375 *
376 * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
377 * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
378 *
379 * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
380 * および下記免責条項を含めること。
381 *
382 * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
383 * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
384 * 含めること。
385 *
386 * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
387 * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
388 * コントリビューターの名前を使用してはならない。
389 *
390 * 本ソフトウェアは、著作権者およびコントリビューターによって「現
391 * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
392 * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
393 * に限定されない、いかなる保証もないものとします。著作権者もコン
394 * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
395 * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
396 * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
397 * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
398 * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
399 * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
400 * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
401 * ついて、一切責任を負わないものとします。
402 *
403 ****************************************************************************/
グラフ構造の辺を制御するクラス
Definition GraphEdge_CLI.h:39
グラフ構造のノードを制御するクラス
Definition GraphNode_CLI.h:30
グラフ構造を制御するクラス
Definition Graph_CLI.h:46
fk_CostStatus GetCostStatus(unsigned int tableID)
コストテーブル状態取得メソッド
unsigned int NodeSize
ノード数取得プロパティ
Definition Graph_CLI.h:74
fk_Graph(unsigned int num)
コンストラクタ
bool SetCostDirection(unsigned int tableID, fk_CostDirection direction)
コスト算出方向指定関数
unsigned int MaxEdgeID
辺ID最大値取得プロパティ
Definition Graph_CLI.h:84
bool SetEdgeCostID(unsigned int tableID, unsigned int edgeCostID)
辺コストID対応指定メソッド
bool DeleteEdge(fk_GraphEdge^ e)
辺削除メソッド
bool InitCostTable(unsigned int tableID)
コストテーブル初期化メソッド
fk_CostStatus UpdateCostTable(unsigned int tableID)
コストテーブル更新メソッド
void ClearGoal(unsigned int tableID)
目標ノード初期化メソッド
void AddGoal(unsigned int tableID, fk_GraphNode^ node)
目標ノード追加メソッド
unsigned int GetNodeCostID(unsigned int tableID)
ノード内コストID参照メソッド
List< fk_GraphNode^> ^ GetOnePath(unsigned int tableID)
最短経路取得メソッド
fk_GraphEdge ^ MakeEdge(bool mode, fk_GraphNode^ v1, fk_GraphNode^ v2)
辺生成メソッド
void RemoveGoal(unsigned int tableID, fk_GraphNode^ node)
目標ノード除外メソッド
List< fk_GraphEdge ^> ^ GetAllEdge(void)
全辺取得メソッド
~fk_Graph()
デストラクタ
fk_GraphNode ^ GetNode(unsigned int ID)
ノード取得メソッド
List< fk_GraphNode ^> ^ GetAllNode(void)
全ノード取得メソッド
void SetStart(unsigned int tableID, fk_GraphNode^ node)
出発ノード設定メソッド
fk_GraphEdge ^ GetEdge(unsigned int ID)
辺情報取得メソッド
bool IsConnect(fk_GraphNode^ v1, fk_GraphNode^ v2)
辺存在確認メソッド
bool MakeCostTable(unsigned int tableID, fk_CostType type)
コストテーブル生成メソッド
形状用基底クラス
Definition Shape_CLI.h:29
Definition AppWindow_CLI.h:11
fk_CostType
グラフ内コスト値の型を表す列挙型
Definition GraphEdge_CLI.h:13
fk_CostStatus
Definition Graph_CLI.h:13
@ CONTINUE
途中段階状態
@ FINISH
完了状態
fk_CostDirection
グラフ内コスト算出方向を表す列挙型
Definition GraphEdge_CLI.h:20