123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- import 'package:fis_i18n/i18n.dart';
- import 'package:fis_measure/index.dart';
- import 'package:fis_measure/interfaces/process/player/play_controller.dart';
- import 'package:fis_measure/process/workspace/measure_data_controller.dart';
- import 'package:fis_measure/process/workspace/measure_handler.dart';
- import 'package:fis_measure/view/ai_result_modifier/view.dart';
- import 'package:fis_measure/view/paint/ai_patint_controller.dart';
- import 'package:fis_measure/view/paint/date_structure.dart';
- import 'package:fis_measure/view/paint/parts/ai_resul_info.dart';
- import 'package:fis_measure/view/paint/parts/feature_analysis.dart';
- import 'package:flutter/material.dart';
- import 'package:get/get.dart';
- import 'package:vid/us/vid_us_image.dart';
- class AIResultPanel extends StatefulWidget {
- final List<AIDetectedObject> aiDetectedObject;
- /// ai部位
- final DiagnosisOrganEnum diagnosisOrgan;
- const AIResultPanel(
- this.aiDetectedObject,
- this.diagnosisOrgan, {
- Key? key,
- }) : super(key: key);
- @override
- State<AIResultPanel> createState() => _AIResultPanelState();
- }
- class _AIResultPanelState extends State<AIResultPanel> {
- late AIDetectedObject aiDetectedObjectItem;
- final aiPatintController = Get.find<AiPatintController>();
- MeasureDataController get measureData => Get.find<MeasureDataController>();
- VidPlayerController get playerController =>
- Get.find<IPlayerController>() as VidPlayerController;
- String get remedicalCode => measureData.measureImageData.remedicalCode ?? "";
- int get currFrameIndex => playerController.currentFrameIndex;
- VidUsImage get currFrame => playerController.currentFrame!;
- @override
- Widget build(BuildContext context) {
- return Row(
- mainAxisAlignment: MainAxisAlignment.spaceBetween,
- children: [
- Expanded(child: Container()),
- SizedBox(
- /// TODO:[Gavin] 多语言-UI-整合
- width: i18nBook.isCurrentChinese ? 210 : 270,
- child: Column(
- crossAxisAlignment: CrossAxisAlignment.start,
- children: [
- if (widget.aiDetectedObject.length > 1)
- Container(
- child: Wrap(
- spacing: 2.0, // 主轴(水平)方向间距
- runSpacing: 2.0, // 纵轴(垂直)方向间距
- direction: Axis.horizontal,
- alignment: WrapAlignment.start,
- children: List<Widget>.generate(
- widget.aiDetectedObject.length,
- (index) {
- return GestureDetector(
- onTap: () {
- aiPatintController.state.aiResultIndex = index;
- },
- child: Obx(
- () => Container(
- decoration: BoxDecoration(
- color: aiPatintController.state.aiResultIndex ==
- index
- ? const Color.fromRGBO(54, 169, 206, 1)
- : Colors.grey,
- ),
- width: 38,
- height: 35,
- child: Center(
- child: Text(
- '${index + 1}',
- style: const TextStyle(
- color: Colors.white,
- ),
- ),
- ),
- ),
- ),
- );
- },
- ),
- ),
- color: Colors.transparent,
- ),
- const SizedBox(
- height: 10,
- ),
- Obx(() {
- try {
- aiDetectedObjectItem = widget
- .aiDetectedObject[aiPatintController.state.aiResultIndex];
- if (aiDetectedObjectItem.label != 0) {
- return Column(
- children: [
- ResultInfo(
- widget.aiDetectedObject,
- ),
- const SizedBox(
- height: 10,
- ),
- aiDetectedObjectItem.descriptions?.isNotEmpty ?? false
- ? FeatureAnalysis(
- aiDetectedObjectItem.descriptions,
- )
- : const SizedBox(),
- const SizedBox(
- height: 10,
- ),
- if (aiDetectedObjectItem.descriptions?.isNotEmpty ??
- false)
- InkWell(
- onTap: () {
- Get.dialog(
- AiResultModifierDialog(
- remedicalCode: remedicalCode,
- currFrameIndex: currFrameIndex,
- currFrame: currFrame,
- ),
- );
- },
- child: const Text(
- "编辑AI结果",
- style: TextStyle(
- color: Colors.white,
- decoration: TextDecoration.underline,
- ),
- ),
- ),
- ],
- );
- } else {
- return const SizedBox();
- }
- } catch (e) {
- return const SizedBox();
- }
- })
- ],
- ),
- ),
- ],
- );
- }
- }
|