two_straightline.dart 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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/application.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 'package:get/get.dart';
  11. import 'two_length.dart';
  12. class TwoStraightLine extends TwoLengthAbstract<TwoStraightLineFeature> {
  13. late final StraightLine x;
  14. late final StraightLine y;
  15. final bool ifVertical;
  16. final bool ifTimeSpan;
  17. TwoStraightLine(ItemMeta meta,
  18. {this.ifVertical = false, this.ifTimeSpan = false})
  19. : super(meta) {
  20. final metaX = meta.childItems[0];
  21. final metaY = meta.childItems[1];
  22. if (ifVertical) {
  23. x = StraightLine.createVerticalDistance(metaX, this);
  24. y = StraightLine.createVerticalDistance(metaY, this);
  25. } else if (ifTimeSpan) {
  26. x = StraightLine.createTimeSpan(metaX, this);
  27. y = StraightLine.createTimeSpan(metaY, this);
  28. } else {
  29. x = StraightLine.createDistance(metaX, this);
  30. y = StraightLine.createDistance(metaY, this);
  31. }
  32. childItems.add(x);
  33. childItems.add(y);
  34. }
  35. @override
  36. StraightLine get child1 => x;
  37. @override
  38. StraightLine get child2 => y;
  39. @override
  40. TwoStraightLineFeature buildFeature() => TwoStraightLineFeature(this);
  41. @override
  42. void onCancelingOnce() {}
  43. static TwoStraightLine createTwoDistanceBase(ItemMeta meta,
  44. [IMeasureItem? parent]) {
  45. var twoStraightline = TwoStraightLine(meta);
  46. twoStraightline.calculator = TwoDistanceCalBase(twoStraightline);
  47. return twoStraightline;
  48. }
  49. static TwoStraightLine createRUV(ItemMeta meta, [IMeasureItem? parent]) {
  50. var twoStraightline = TwoStraightLine(meta);
  51. twoStraightline.calculator = ResidualUrineCal(twoStraightline);
  52. return twoStraightline;
  53. }
  54. static TwoStraightLine createAbRatioDistance(ItemMeta meta,
  55. [IMeasureItem? parent]) {
  56. TwoStraightLine twoStraightline = TwoStraightLine(meta);
  57. twoStraightline.calculator = ABRatioCal(twoStraightline);
  58. return twoStraightline;
  59. }
  60. static TwoStraightLine createStenosisTwoDistance(ItemMeta meta,
  61. [IMeasureItem? parent]) {
  62. var twoStraightline = TwoStraightLine(meta);
  63. twoStraightline.calculator = StenosisCal(twoStraightline);
  64. return twoStraightline;
  65. }
  66. static TwoStraightLine createStenosisTwoVerticalDistance(ItemMeta meta,
  67. [IMeasureItem? parent]) {
  68. var twoStraightline = TwoStraightLine(meta, ifVertical: true);
  69. twoStraightline.calculator = StenosisCal(twoStraightline);
  70. return twoStraightline;
  71. }
  72. static TwoStraightLine createAbRatioTwoVerticalDistance(ItemMeta meta,
  73. [IMeasureItem? parent]) {
  74. var twoStraightline = TwoStraightLine(meta, ifVertical: true);
  75. twoStraightline.calculator = ABRatioCal(twoStraightline);
  76. return twoStraightline;
  77. }
  78. static TwoStraightLine createAbRatioTwoTimeSpan(ItemMeta meta,
  79. [IMeasureItem? parent]) {
  80. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: true);
  81. twoStraightline.calculator = ABRatioCal(twoStraightline);
  82. return twoStraightline;
  83. }
  84. static TwoStraightLine createAbRatioSlope(ItemMeta meta,
  85. [IMeasureItem? parent]) {
  86. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: false);
  87. twoStraightline.calculator = ABRatioCal(twoStraightline);
  88. return twoStraightline;
  89. }
  90. static TwoStraightLine createTeiIndex(ItemMeta meta, [IMeasureItem? parent]) {
  91. var twoStraightline = TwoStraightLine(meta, ifTimeSpan: true);
  92. twoStraightline.calculator = TeiIndexCal(twoStraightline);
  93. return twoStraightline;
  94. }
  95. static TwoStraightLine createVolume(ItemMeta meta, [IMeasureItem? parent]) {
  96. var twoStraightline = TwoStraightLine(meta);
  97. twoStraightline.calculator = TwoDistanceVolumeCal(twoStraightline);
  98. return twoStraightline;
  99. }
  100. static TwoStraightLine createTwoDistanceAverage(ItemMeta meta,
  101. [IMeasureItem? parent]) {
  102. var twoStraightline = TwoStraightLine(meta);
  103. twoStraightline.calculator = TwoDistanceSumCal(twoStraightline);
  104. return twoStraightline;
  105. }
  106. static TwoStraightLine createAngle(ItemMeta meta, [IMeasureItem? parent]) {
  107. var twoStraightline = TwoStraightLine(meta);
  108. twoStraightline.calculator = TwoStraightLineAngleCal(twoStraightline);
  109. return twoStraightline;
  110. }
  111. static TwoStraightLine createEfTeich(ItemMeta meta, [IMeasureItem? parent]) {
  112. final isModeBelow = _checkIsModeBelow();
  113. var twoStraightline = TwoStraightLine(meta, ifVertical: isModeBelow);
  114. twoStraightline.calculator = EfTeichCal(twoStraightline);
  115. return twoStraightline;
  116. }
  117. static TwoStraightLine createIvsThck(ItemMeta meta, [IMeasureItem? parent]) {
  118. var twoStraightline = TwoStraightLine(meta);
  119. twoStraightline.calculator = IvsThckCal(twoStraightline);
  120. return twoStraightline;
  121. }
  122. static TwoStraightLine createTwoVerticalDistance(ItemMeta meta,
  123. [IMeasureItem? parent]) {
  124. var twoStraightline = TwoStraightLine(meta, ifVertical: true);
  125. twoStraightline.calculator = RvStudyCal(twoStraightline);
  126. return twoStraightline;
  127. }
  128. static TwoStraightLine createAreaPerimeter(ItemMeta meta,
  129. [IMeasureItem? parent]) {
  130. var twoStraightline = TwoStraightLine(meta);
  131. twoStraightline.calculator = AreaPerimeterByLAndWCal(twoStraightline);
  132. return twoStraightline;
  133. }
  134. static bool _checkIsModeBelow() {
  135. if (Get.isRegistered<IApplication>()) {
  136. final app = Get.find<IApplication>();
  137. final mode = app.currentMode.name.toLowerCase();
  138. return ["m", "pw"].contains(mode);
  139. }
  140. return false;
  141. }
  142. }
  143. class TwoStraightLineFeature extends TopMeasureItemFeature {
  144. TwoStraightLineFeature(
  145. ITopMeasureItem refItem,
  146. ) : super(refItem);
  147. }