CMind.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #ifndef CMIND_H
  2. #define CMIND_H
  3. #include "CNode.h"
  4. #include <QObject>
  5. struct SeqNode
  6. {
  7. QString name;
  8. QStringList childs;
  9. };
  10. class CMind : public QObject
  11. {
  12. Q_OBJECT
  13. public:
  14. explicit CMind(QObject *parent = nullptr);
  15. // 节点数据
  16. QList<CNodeData> nodeList() const;
  17. void setNodeList(QList<CNodeData> list);
  18. bool isNodeValid(CNodeData n) const;
  19. CNodeData node(int number) const;
  20. bool containsNode(int number) const;
  21. bool canAddNode(CNodeData n);
  22. void addNode(CNodeData n);
  23. void removeNode(int number);
  24. void updateNode(CNodeData n);
  25. CNodeData root() const;
  26. bool hasAncestor(int childNumber, int ancestorNumber) const;
  27. // 最大的节点编号, 创建节点时, 编号递增
  28. int maxNumber() const;
  29. // 最小的节点编号, 由于创建节点时编号递增, 所以此为根节点
  30. int minNumber() const;
  31. void clear();
  32. // 节点所在层级
  33. int levelOfNode(CNodeData n) const;
  34. // 节点图层级数
  35. int levels() const;
  36. // 某一层节点列表, 第1层为根节点
  37. QList<CNodeData> nodesInLevel(int i) const;
  38. // 子节点列表
  39. QList<CNodeData> subNodes(CNodeData n) const;
  40. // 某节点的叶子节点个数或包含的分支数
  41. int leavesCountOfNode(CNodeData n) const;
  42. // 脑图的叶子节点个数或包含的分支数
  43. int leavesCount() const;
  44. // 某节点的叶子节点列表, 即最外层节点
  45. QList<CNodeData> leavesOfNode(CNodeData n) const;
  46. // 脑图的叶子节点列表
  47. QList<CNodeData> leaves() const;
  48. void getSeqNodes(QList<QList<SeqNode>> &seqNodes) const; // 序列所有节点
  49. signals:
  50. void sigRemoveNode(int id);
  51. private:
  52. QList<int> numberList() const; // 节点编号列表
  53. private:
  54. QList<CNodeData> m_nodeList; // 节点列表
  55. };
  56. #endif // CMIND_H