two_straightline.dart 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. import 'package:fis_measure/interfaces/process/items/item.dart';
  2. import 'package:fis_measure/interfaces/process/items/item_metas.dart';
  3. import 'package:fis_measure/interfaces/process/workspace/point_info.dart';
  4. import 'package:fis_measure/process/calcuators/a_b_ratio.dart';
  5. import 'package:fis_measure/process/calcuators/stenosis.dart';
  6. import 'package:fis_measure/process/calcuators/tei_index.dart';
  7. import 'package:fis_measure/process/calcuators/two_distance.dart';
  8. import 'package:fis_measure/process/items/top_item_feature.dart';
  9. import 'package:fis_measure/process/primitives/straightline.dart';
  10. import 'two_length.dart';
  11. class TwoStraightLine extends TwoLengthAbstract<TwoStraightLineFeature> {
  12. late final StraightLine x;
  13. late final StraightLine y;
  14. final bool ifVertical;
  15. final bool ifTimeSpan;
  16. TwoStraightLine(ItemMeta meta,
  17. {this.ifVertical = false, this.ifTimeSpan = false})
  18. : super(meta) {
  19. final metaX = meta.childItems[0];
  20. final metaY = meta.childItems[1];
  21. if (ifVertical) {
  22. x = StraightLine.createVerticalDistance(metaX, this);
  23. y = StraightLine.createVerticalDistance(metaY, this);
  24. } else if (ifTimeSpan) {
  25. x = StraightLine.createTimeSpan(metaX, this);
  26. y = StraightLine.createTimeSpan(metaY, this);
  27. } else {
  28. x = StraightLine.createDistance(metaX, this);
  29. y = StraightLine.createDistance(metaY, this);
  30. }
  31. childItems.add(x);
  32. childItems.add(y);
  33. }
  34. @override
  35. StraightLine get child1 => x;
  36. @override
  37. StraightLine get child2 => y;
  38. @override
  39. TwoStraightLineFeature buildFeature() => TwoStraightLineFeature(this);
  40. @override
  41. void onCancelingOnce() {}
  42. static TwoStraightLine createTwoDistanceBase(ItemMeta meta,
  43. [IMeasureItem? parent]) {
  44. var twoStraightline = TwoStraightLine(meta);
  45. twoStraightline.calculator = TwoDistanceCalBase(twoStraightline);
  46. return twoStraightline;
  47. }
  48. static TwoStraightLine createRUV(ItemMeta meta, [IMeasureItem? parent]) {
  49. var twoStraightline = TwoStraightLine(meta);
  50. twoStraightline.calculator = ResidualUrineCal(twoStraightline);
  51. return twoStraightline;
  52. }
  53. static TwoStraightLine createAbRatioDistance(ItemMeta meta,
  54. [IMeasureItem? parent]) {
  55. TwoStraightLine twoStraightline = TwoStraightLine(meta);
  56. twoStraightline.calculator = ABRatioCal(twoStraightline);
  57. return twoStraightline;
  58. }
  59. static TwoStraightLine createStenosisTwoDistance(ItemMeta meta,
  60. [IMeasureItem? parent]) {
  61. var twoStraightline = TwoStraightLine(meta);
  62. twoStraightline.calculator = StenosisCal(twoStraightline);
  63. return twoStraightline;
  64. }
  65. static TwoStraightLine createStenosisTwoVerticalDistance(ItemMeta meta,
  66. [IMeasureItem? parent]) {
  67. var twoStraightline = TwoStraightLine(meta, ifVertical: true);
  68. twoStraightline.calculator = StenosisCal(twoStraightline);
  69. return twoStraightline;
  70. }
  71. static TwoStraightLine createAbRatioTwoVerticalDistance(ItemMeta meta,
  72. [IMeasureItem? parent]) {
  73. var twoStraightline = TwoStraightLine(meta, ifVertical: true);
  74. twoStraightline.calculator = ABRatioCal(twoStraightline);
  75. return twoStraightline;
  76. }
  77. static TwoStraightLine createAbRatioTwoTimeSpan(ItemMeta meta,
  78. [IMeasureItem? parent]) {
  79. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: true);
  80. twoStraightline.calculator = ABRatioCal(twoStraightline);
  81. return twoStraightline;
  82. }
  83. static TwoStraightLine createAbRatioSlope(ItemMeta meta,
  84. [IMeasureItem? parent]) {
  85. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: false);
  86. twoStraightline.calculator = ABRatioCal(twoStraightline);
  87. return twoStraightline;
  88. }
  89. static TwoStraightLine createTeiIndex(ItemMeta meta, [IMeasureItem? parent]) {
  90. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: true);
  91. twoStraightline.calculator = TeiIndexCal(twoStraightline);
  92. return twoStraightline;
  93. }
  94. static TwoStraightLine createVolume(ItemMeta meta, [IMeasureItem? parent]) {
  95. var twoStraightline = TwoStraightLine(meta);
  96. twoStraightline.calculator = TwoDistanceVolumeCal(twoStraightline);
  97. return twoStraightline;
  98. }
  99. static TwoStraightLine createTwoDistanceAverage(ItemMeta meta,
  100. [IMeasureItem? parent]) {
  101. var twoStraightline = TwoStraightLine(meta);
  102. twoStraightline.calculator = TwoDistanceSumCal(twoStraightline);
  103. return twoStraightline;
  104. }
  105. static TwoStraightLine createAngle(ItemMeta meta, [IMeasureItem? parent]) {
  106. var twoStraightline = TwoStraightLine(meta);
  107. twoStraightline.calculator = TwoStraightLineAngleCal(twoStraightline);
  108. return twoStraightline;
  109. }
  110. static TwoStraightLine createEfTeich(ItemMeta meta, [IMeasureItem? parent]) {
  111. var twoStraightline = TwoStraightLine(meta);
  112. twoStraightline.calculator = EfTeichCal(twoStraightline);
  113. return twoStraightline;
  114. }
  115. static TwoStraightLine createIvsThck(ItemMeta meta, [IMeasureItem? parent]) {
  116. var twoStraightline = TwoStraightLine(meta);
  117. twoStraightline.calculator = IvsThckCal(twoStraightline);
  118. return twoStraightline;
  119. }
  120. }
  121. class TwoStraightLineFeature extends TopMeasureItemFeature {
  122. TwoStraightLineFeature(
  123. ITopMeasureItem refItem,
  124. ) : super(refItem);
  125. }