urm_vessel_measure.dart 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import 'package:fis_measure/interfaces/enums/items.dart';
  2. import 'package:fis_measure/interfaces/process/items/item.dart';
  3. import 'package:fis_measure/interfaces/process/items/item_metas.dart';
  4. import 'package:fis_measure/interfaces/process/workspace/point_info.dart';
  5. import 'package:fis_measure/process/calcuators/urm_calcuators/urm_vessel_measure.dart';
  6. import 'package:fis_measure/process/primitives/straightline.dart';
  7. import 'package:fis_measure/utils/prompt_box.dart';
  8. import 'package:fis_measure/view/gesture/cross_position_indicator.dart';
  9. class URMVesselMeasure extends StraightLine {
  10. URMVesselMeasure(super.meta, super.parent);
  11. static URMVesselMeasure createURMVesselMeasure(ItemMeta meta,
  12. [IMeasureItem? parent]) {
  13. URMVesselMeasure measureVessel = URMVesselMeasure(meta, parent);
  14. measureVessel.calculator = URMVesselMeasureCal(measureVessel);
  15. return measureVessel;
  16. }
  17. @override
  18. bool onExecuteMouse(PointInfo args) {
  19. if (state == ItemStates.finished) {
  20. if (args.pointType == PointInfoType.mouseDown) {
  21. state = ItemStates.waiting;
  22. } else {
  23. return false;
  24. }
  25. }
  26. if (state == ItemStates.waiting) {
  27. if (args.pointType == PointInfoType.mouseDown) {
  28. handleMouseDownWhileWaiting(args);
  29. }
  30. } else if (state == ItemStates.running) {
  31. if (args.pointType == PointInfoType.mouseUp) return false;
  32. feature?.endPoint = args;
  33. doCalculate();
  34. if (args.pointType == PointInfoType.mouseDown) {
  35. handleFinish();
  36. ///重置十字样式
  37. changeCrossIndicatorStyle(CrossIndicatorStyle.nomal);
  38. }
  39. }
  40. return true;
  41. }
  42. @override
  43. void handleMouseDownWhileWaiting(PointInfo args) {
  44. // TODO: 判断是否当前area
  45. // 转换为Area逻辑位置
  46. final point = args.toAreaLogicPoint();
  47. // feature = StraightLineFeature(this, point, point);
  48. if (args.hostVisualArea != null) {
  49. handleTissueTM(args.hostVisualArea!.mode.modeType, point);
  50. feature!.hostVisualArea = args.hostVisualArea;
  51. }
  52. state = ItemStates.running;
  53. }
  54. bool waitingResult = false;
  55. void handleFinish() async {
  56. feature!.isActive = false;
  57. waitingResult = true;
  58. await doCalculateAsync();
  59. doFeatureFinish();
  60. doFeatureUpdate(); // 若不执行,子测量将无法自动切换
  61. PromptBox.dismiss();
  62. waitingResult = false;
  63. }
  64. }