Blame view

lib/pages/practice/topic_picture_page.dart 22.3 KB
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
1
2
3
  import 'package:flutter/material.dart';
  import 'package:flutter_bloc/flutter_bloc.dart';
  import 'package:flutter_screenutil/flutter_screenutil.dart';
997ea0d6   liangchengyou   feat:绘本闪退问题修复
4
  import 'package:wow_english/common/core/app_consts.dart';
e3c2820c   liangchengyou   feat:先声SDK逻辑调整
5
  import 'package:wow_english/common/core/user_util.dart';
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
6
7
  import 'package:wow_english/common/extension/string_extension.dart';
  import 'package:wow_english/common/widgets/ow_image_widget.dart';
2eb67dd4   liangchengyou   feat:调整代码
8
  import 'package:wow_english/models/course_process_entity.dart';
22f36232   吴启风   feat:过渡页-练习环节
9
  import 'package:wow_english/pages/practice/topic_type.dart';
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
10
  import 'package:wow_english/pages/practice/widgets/shake_widget.dart';
934e2b47   liangchengyou   feat:权限调整+课程进度接口对接
11
  import 'package:wow_english/route/route.dart';
3c1d5c64   liangchengyou   feat:练习功能完成
12
  import 'package:wow_english/utils/toast_util.dart';
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
13
  
d4d91cb0   吴启风   feat:lottie动效组件封装...
14
  import '../../common/widgets/recorder_widget.dart';
56b412f5   吴启风   feat:扬声器播放动画组件封装
15
  import '../../common/widgets/speaker_widget.dart';
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
16
17
18
  import 'bloc/topic_picture_bloc.dart';
  import 'widgets/practice_header_widget.dart';
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
19
  class TopicPicturePage extends StatelessWidget {
07b173c9   吴启风   feat:练习页上方进度信息改成进...
20
    const TopicPicturePage({super.key, this.courseLessonId, this.moduleColor});
608c05b4   liangchengyou   feat:兑换课程
21
22
  
    final String? courseLessonId;
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
23
  
07b173c9   吴启风   feat:练习页上方进度信息改成进...
24
25
    final Color? moduleColor;
  
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
26
27
28
    @override
    Widget build(BuildContext context) {
      return BlocProvider(
2eb67dd4   liangchengyou   feat:调整代码
29
        create: (context) => TopicPictureBloc(
07b173c9   吴启风   feat:练习页上方进度信息改成进...
30
            context, PageController(), courseLessonId ?? '', moduleColor)
3c1d5c64   liangchengyou   feat:练习功能完成
31
          ..add(InitBlocEvent())
2eb67dd4   liangchengyou   feat:调整代码
32
          ..add(RequestDataEvent())
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
33
34
35
36
37
38
          ..add(XSVoiceInitEvent({
            'appKey': AppConsts.xsAppKey,
            'service': AppConsts.xsAppService,
            'secretKey': AppConsts.xsAppSecretKey,
            'userId': UserUtil.getUser()!.id.toString(),
          })),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
39
40
41
42
43
44
45
46
        child: _TopicPicturePage(),
      );
    }
  }
  
  class _TopicPicturePage extends StatelessWidget {
    @override
    Widget build(BuildContext context) {
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
47
48
      return BlocListener<TopicPictureBloc, TopicPictureState>(
        listener: (context, state) {
2eb67dd4   liangchengyou   feat:调整代码
49
          if (state is RequestDataState) {
608c05b4   liangchengyou   feat:兑换课程
50
            context.read<TopicPictureBloc>().add(CurrentPageIndexChangeEvent(0));
e3c2820c   liangchengyou   feat:先声SDK逻辑调整
51
          }
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
52
          if (state is XSVoiceTestState) {}
2eb67dd4   liangchengyou   feat:调整代码
53
        },
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
54
55
56
57
        child: _topicPictureView(),
      );
    }
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
58
59
60
    Widget _topicPictureView() =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
61
62
          final bloc = BlocProvider.of<TopicPictureBloc>(context);
          return Container(
82c8633c   biao   音频添加 页面优化
63
64
65
66
67
68
            decoration: BoxDecoration(
              image: DecorationImage(
                image: AssetImage('read_background'.assetPng), // 背景图片路径
                fit: BoxFit.cover, // 适应图片的方式
              ),
            ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
69
70
71
72
73
            child: Stack(
              children: [
                Column(
                  children: [
                    PracticeHeaderWidget(
07b173c9   吴启风   feat:练习页上方进度信息改成进...
74
75
76
                      color: bloc.moduleColor,
                      progress: bloc.currentPage,
                      total: bloc.entity?.topics?.length ?? 0,
b90a1518   liangchengyou   feat:练习接口逻辑完成
77
                      onTap: () {
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
78
79
80
81
82
                        popPage(data: {
                          'currentStep': bloc.currentPage,
                          'courseLessonId': bloc.courseLessonId,
                          'isCompleted': bloc.isLastPage(),
                        });
934e2b47   liangchengyou   feat:权限调整+课程进度接口对接
83
                        // Navigator.pop(context);
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
84
                      },
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
85
                    ),
82c8633c   biao   音频添加 页面优化
86
                    35.verticalSpace,
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
                    bloc.entity != null
                        ? Expanded(
                            child: PageView.builder(
                                itemCount: bloc.entity?.topics?.length,
                                scrollDirection: Axis.horizontal,
                                controller: bloc.pageController,
                                onPageChanged: (int index) {
                                  bloc.add(CurrentPageIndexChangeEvent(index));
                                },
                                itemBuilder: (BuildContext context, int index) {
                                  CourseProcessTopics? topics =
                                      bloc.entity?.topics![index];
                                  if (topics?.type ==
                                      TopicType.audioImageSelect.value) {
                                    //听音选图
                                    return _pageViewVoicePictureItemWidget(
                                        topics);
                                  } else if (topics?.type ==
                                      TopicType.audioCharSelect.value) {
                                    //听音选字
                                    return _pageViewVoiceWordItemWidget(topics);
                                  } else if (topics?.type ==
                                      TopicType.questionCharSelect.value) {
                                    //看题选字
                                    return _pageViewWordItemWidget(topics);
                                  } else if (topics?.type ==
                                      TopicType.questionImageSelect.value) {
                                    //看题选图
                                    return _pageViewItemWidget(topics);
                                  } else {
                                    //语音问答
                                    return _voiceAnswerItem(topics);
                                  }
                                }),
                          )
                        : Container(
                            color: Colors.transparent,
                            child: const CircularProgressIndicator(),
                          ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
126
                  ],
82c8633c   biao   音频添加 页面优化
127
                )
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
128
129
130
131
132
133
              ],
            ),
          );
        });
  
    ///看题选图
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
134
135
136
    Widget _pageViewItemWidget(CourseProcessTopics? topics) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
137
138
139
          return SafeArea(
            child: Column(
              children: [
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
140
                Text(topics?.word ?? '',
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
141
142
                    softWrap: true,
                    style: TextStyle(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
143
                        fontSize: 21.sp, color: const Color(0xFF333333))),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
144
                26.verticalSpace,
2eb67dd4   liangchengyou   feat:调整代码
145
146
                SizedBox(
                  height: 143.h,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
147
                  width: 143.w * (topics?.topicAnswerList?.length ?? 0),
2eb67dd4   liangchengyou   feat:调整代码
148
                  child: ListView.builder(
2eb67dd4   liangchengyou   feat:调整代码
149
                      scrollDirection: Axis.horizontal,
b90a1518   liangchengyou   feat:练习接口逻辑完成
150
                      physics: const NeverScrollableScrollPhysics(),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
151
152
153
154
                      itemCount: topics?.topicAnswerList?.length ?? 0,
                      itemBuilder: (context, index) {
                        return _decodeImageWidget(
                            index, topics?.topicAnswerList?[index]);
2eb67dd4   liangchengyou   feat:调整代码
155
156
                      }),
                ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
157
158
159
160
161
              ],
            ),
          );
        });
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
162
163
164
165
166
167
    Widget _decodeImageWidget(
            int index, CourseProcessTopicsTopicAnswerList? answerLis) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            buildWhen: (_, s) => s is SelectItemChangeState,
            builder: (context, state) {
              final bloc = BlocProvider.of<TopicPictureBloc>(context);
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
168
              final isAnswerOption = bloc.selectItem == index;
d4d91cb0   吴启风   feat:lottie动效组件封装...
169
170
171
172
              final answerCorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == true;
              final answerIncorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == false;
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
173
174
175
176
              return Container(
                padding: EdgeInsets.symmetric(horizontal: 10.w),
                child: GestureDetector(
                  onTap: () => bloc.add(SelectItemEvent(index)),
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
177
                  child: ShakeWidget(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
178
                    shouldShake: answerIncorrect,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
179
                    child: Container(
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
180
                      padding: const EdgeInsets.all(4.5),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
181
                      decoration: BoxDecoration(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
182
183
                        color: isAnswerOption
                            ? getResultColor(answerCorrect)
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
                            : Colors.white,
                        borderRadius: BorderRadius.circular(15),
                      ),
                      height: 143.h,
                      width: 143.w,
                      child: Container(
                        decoration: BoxDecoration(
                            color: Colors.white,
                            borderRadius: BorderRadius.circular(15),
                            border: Border.all(
                                width: 1.0, color: const Color(0xFF140C10)),
                            image: DecorationImage(
                                fit: BoxFit.fitWidth,
                                image: NetworkImage(answerLis?.picUrl ?? ''))),
                      ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
199
                    ),
2eb67dd4   liangchengyou   feat:调整代码
200
                  ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
201
                ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
202
203
              );
            });
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
204
205
  
    ///看题选字
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
206
207
208
    Widget _pageViewWordItemWidget(CourseProcessTopics? topics) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
209
210
211
          return SafeArea(
            child: Column(
              children: [
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
212
                Text(topics?.word ?? '',
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
213
214
                    softWrap: true,
                    style: TextStyle(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
215
                        fontSize: 21.sp, color: const Color(0xFF333333))),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
216
                26.verticalSpace,
2eb67dd4   liangchengyou   feat:调整代码
217
218
                SizedBox(
                  height: 143.h,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
219
                  width: 143.w * (topics?.topicAnswerList?.length ?? 0),
2eb67dd4   liangchengyou   feat:调整代码
220
                  child: ListView.builder(
2eb67dd4   liangchengyou   feat:调整代码
221
                      scrollDirection: Axis.horizontal,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
222
                      itemCount: topics?.topicAnswerList?.length ?? 0,
b90a1518   liangchengyou   feat:练习接口逻辑完成
223
                      physics: const NeverScrollableScrollPhysics(),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
224
225
226
                      itemBuilder: (context, index) {
                        return _decodeWordWidget(
                            index, topics?.topicAnswerList?[index]);
2eb67dd4   liangchengyou   feat:调整代码
227
228
                      }),
                ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
229
230
231
232
233
              ],
            ),
          );
        });
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
234
235
236
237
238
239
    Widget _decodeWordWidget(
            int index, CourseProcessTopicsTopicAnswerList? answerLis) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            buildWhen: (_, s) => s is SelectItemChangeState,
            builder: (context, state) {
              final bloc = BlocProvider.of<TopicPictureBloc>(context);
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
240
              final isAnswerOption = bloc.selectItem == index;
d4d91cb0   吴启风   feat:lottie动效组件封装...
241
242
243
244
              final answerCorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == true;
              final answerIncorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == false;
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
245
246
247
248
              return Container(
                padding: EdgeInsets.symmetric(horizontal: 10.w),
                child: GestureDetector(
                  onTap: () => bloc.add(SelectItemEvent(index)),
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
249
                  child: ShakeWidget(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
250
                    shouldShake: answerIncorrect,
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
                    child: Container(
                      width: 143.w,
                      height: 143.h,
                      padding: EdgeInsets.only(
                          left: 13.w, right: 13.w, top: 13.h, bottom: 13.h),
                      decoration: BoxDecoration(
                        color: Colors.white,
                        borderRadius: BorderRadius.circular(15),
                        border: Border.all(
                            width: 1.0, color: const Color(0xFF140C10)),
                      ),
                      child: Column(
                        mainAxisAlignment: MainAxisAlignment.end,
                        children: [
                          Expanded(
                            child: Container(
                              alignment: Alignment.center,
                              child: Text(answerLis?.word ?? '',
                                  style: TextStyle(
                                      fontSize: 20.sp,
                                      color: const Color(0xFF333333))),
                            ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
273
                          ),
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
274
275
276
277
                          Container(
                            height: 30.h,
                            width: double.infinity,
                            decoration: BoxDecoration(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
278
279
                              color: isAnswerOption
                                  ? getResultColor(answerCorrect)
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
280
281
282
283
284
285
286
287
288
289
                                  : Colors.white,
                              borderRadius: BorderRadius.circular(15.r),
                              border: Border.all(
                                  width: 1.5, color: const Color(0xFF140C10)),
                            ),
                            alignment: Alignment.center,
                            child: Image.asset('choose'.assetPng),
                          )
                        ],
                      ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
290
291
                    ),
                  ),
2eb67dd4   liangchengyou   feat:调整代码
292
                ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
293
294
              );
            });
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
295
296
  
    ///听音选图
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
297
298
299
    Widget _pageViewVoicePictureItemWidget(CourseProcessTopics? topics) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
3c1d5c64   liangchengyou   feat:练习功能完成
300
          final bloc = BlocProvider.of<TopicPictureBloc>(context);
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
301
302
303
304
305
306
          return SafeArea(
            child: Column(
              children: [
                Row(
                  mainAxisAlignment: MainAxisAlignment.center,
                  children: [
3c1d5c64   liangchengyou   feat:练习功能完成
307
308
309
310
311
                    GestureDetector(
                      onTap: () {
                        bloc.add(VoicePlayEvent());
                      },
                      child: Image.asset(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
312
313
314
                        bloc.voicePlayState == VoicePlayState.playing
                            ? 'reade_answer'.assetGif
                            : 'voice'.assetPng,
3c1d5c64   liangchengyou   feat:练习功能完成
315
316
317
318
                        height: 33.h,
                        width: 30.w,
                      ),
                    ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
319
                    10.horizontalSpace,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
320
                    Text(topics?.word ?? '',
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
321
                        style: TextStyle(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
322
                            fontSize: 20.sp, color: const Color(0xFF333333)))
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
323
324
325
                  ],
                ),
                26.verticalSpace,
2eb67dd4   liangchengyou   feat:调整代码
326
327
                SizedBox(
                  height: 143.h,
82c8633c   biao   音频添加 页面优化
328
                  width: 203.w * (topics?.topicAnswerList?.length ?? 0),
2eb67dd4   liangchengyou   feat:调整代码
329
330
                  child: ListView.builder(
                      scrollDirection: Axis.horizontal,
b90a1518   liangchengyou   feat:练习接口逻辑完成
331
                      physics: const NeverScrollableScrollPhysics(),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
332
333
334
335
336
                      itemCount: topics?.topicAnswerList?.length ?? 0,
                      itemBuilder: (BuildContext context, int index) {
                        return _decodeVoiceImageWidget(
                            index, topics?.topicAnswerList?[index]);
                      }),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
337
338
339
340
341
342
                )
              ],
            ),
          );
        });
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
343
344
345
346
347
348
    Widget _decodeVoiceImageWidget(
            int index, CourseProcessTopicsTopicAnswerList? answerList) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            buildWhen: (_, s) => s is SelectItemChangeState,
            builder: (context, state) {
              final bloc = BlocProvider.of<TopicPictureBloc>(context);
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
349
              final isAnswerOption = bloc.selectItem == index;
d4d91cb0   吴启风   feat:lottie动效组件封装...
350
351
352
353
              final answerCorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == true;
              final answerIncorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == false;
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
354
              return ShakeWidget(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
355
                shouldShake: answerIncorrect,
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
356
357
358
359
                child: Container(
                  padding: EdgeInsets.symmetric(horizontal: 20.w),
                  child: GestureDetector(
                    onTap: () => bloc.add(SelectItemEvent(index)),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
360
                    child: Container(
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
361
                      padding: const EdgeInsets.all(4.5),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
362
                      decoration: BoxDecoration(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
363
364
                        color: isAnswerOption
                            ? getResultColor(answerCorrect)
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
365
366
367
368
369
370
371
372
373
374
375
376
377
                            : Colors.white,
                        borderRadius: BorderRadius.circular(15),
                      ),
                      height: 143.h,
                      width: 163.w,
                      child: Container(
                        decoration: BoxDecoration(
                            color: Colors.white,
                            borderRadius: BorderRadius.circular(15),
                            image: DecorationImage(
                                fit: BoxFit.fill,
                                image: NetworkImage(answerList?.picUrl ?? ''))),
                      ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
378
                    ),
2eb67dd4   liangchengyou   feat:调整代码
379
                  ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
380
                ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
381
382
              );
            });
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
383
384
  
    ///听音选字
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
385
386
387
    Widget _pageViewVoiceWordItemWidget(CourseProcessTopics? topics) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
3c1d5c64   liangchengyou   feat:练习功能完成
388
          final bloc = BlocProvider.of<TopicPictureBloc>(context);
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
389
390
391
          return SafeArea(
            child: Column(
              children: [
3c1d5c64   liangchengyou   feat:练习功能完成
392
                GestureDetector(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
393
394
395
396
397
398
399
400
401
                    onTap: () {
                      bloc.add(VoicePlayEvent());
                    },
                    child: Image.asset(
                        bloc.voicePlayState == VoicePlayState.playing
                            ? 'reade_answer'.assetGif
                            : 'voice'.assetPng,
                        height: 33.h,
                        width: 30.w)),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
402
                26.verticalSpace,
2eb67dd4   liangchengyou   feat:调整代码
403
                SizedBox(
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
404
                  width: 163.w * (topics?.topicAnswerList?.length ?? 0),
2eb67dd4   liangchengyou   feat:调整代码
405
406
                  height: 143.h,
                  child: ListView.builder(
2eb67dd4   liangchengyou   feat:调整代码
407
                      scrollDirection: Axis.horizontal,
b90a1518   liangchengyou   feat:练习接口逻辑完成
408
409
                      itemCount: topics?.topicAnswerList?.length,
                      physics: const NeverScrollableScrollPhysics(),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
410
411
412
                      itemBuilder: (BuildContext context, int index) {
                        return _decodeVoiceWordImageWidget(
                            index, topics!.topicAnswerList![index]);
2eb67dd4   liangchengyou   feat:调整代码
413
414
                      }),
                ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
415
416
417
418
419
              ],
            ),
          );
        });
  
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
420
421
422
423
424
425
    Widget _decodeVoiceWordImageWidget(
            int index, CourseProcessTopicsTopicAnswerList answerList) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            buildWhen: (_, s) => s is SelectItemChangeState,
            builder: (context, state) {
              final bloc = BlocProvider.of<TopicPictureBloc>(context);
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
426
              final isAnswerOption = bloc.selectItem == index;
d4d91cb0   吴启风   feat:lottie动效组件封装...
427
428
429
430
              final answerCorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == true;
              final answerIncorrect =
                  isAnswerOption && bloc.checkAnswerRight(index) == false;
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
431
432
              return GestureDetector(
                onTap: () => bloc.add(SelectItemEvent(index)),
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
433
                child: ShakeWidget(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
434
                  shouldShake: answerIncorrect,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
435
                  child: Container(
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
436
                    width: 163.w,
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
437
                    height: 143.h,
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
                    padding: EdgeInsets.symmetric(horizontal: 10.w),
                    child: Container(
                      width: 143.w,
                      height: 143.h,
                      padding: EdgeInsets.only(
                          left: 13.w, right: 13.w, top: 13.h, bottom: 13.h),
                      decoration: BoxDecoration(
                        color: Colors.white,
                        borderRadius: BorderRadius.circular(15),
                        border: Border.all(
                            width: 1.0, color: const Color(0xFF140C10)),
                      ),
                      child: Column(
                        mainAxisAlignment: MainAxisAlignment.end,
                        children: [
                          Expanded(
                            child: Container(
                              alignment: Alignment.center,
                              child: Text(answerList.word ?? '',
                                  style: TextStyle(
                                      fontSize: 20.sp,
                                      color: const Color(0xFF333333))),
                            ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
461
                          ),
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
462
463
464
465
                          Container(
                            height: 30.h,
                            width: double.infinity,
                            decoration: BoxDecoration(
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
466
467
                              color: isAnswerOption
                                  ? getResultColor(answerCorrect)
45c862fd   吴启风   feat:闯关交互优化-答错晃动、...
468
469
470
471
472
473
474
475
476
477
                                  : Colors.white,
                              borderRadius: BorderRadius.circular(15.r),
                              border: Border.all(
                                  width: 1.5, color: const Color(0xFF140C10)),
                            ),
                            alignment: Alignment.center,
                            child: Image.asset('choose'.assetPng),
                          )
                        ],
                      ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
478
479
                    ),
                  ),
2eb67dd4   liangchengyou   feat:调整代码
480
                ),
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
481
482
              );
            });
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
483
484
  
    ///语音问答
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
485
486
487
    Widget _voiceAnswerItem(CourseProcessTopics? topics) =>
        BlocBuilder<TopicPictureBloc, TopicPictureState>(
            builder: (context, state) {
2eb67dd4   liangchengyou   feat:调整代码
488
          final bloc = BlocProvider.of<TopicPictureBloc>(context);
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
489
          return Row(
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
490
491
            mainAxisAlignment: MainAxisAlignment.center,
            children: [
82c8633c   biao   音频添加 页面优化
492
493
494
495
496
497
498
499
500
501
              ClipRRect(
                borderRadius: BorderRadius.circular(20),
                child: Container(
                  color: Colors.white,
                  child: OwImageWidget(
                    name: topics?.picUrl ?? '',
                    height: 186.h,
                    width: 186.w,
                  ),
                ),
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
502
              ),
82c8633c   biao   音频添加 页面优化
503
              120.horizontalSpace,
2eb67dd4   liangchengyou   feat:调整代码
504
505
506
              Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: [
d4d91cb0   吴启风   feat:lottie动效组件封装...
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
                  Row(
                    children: [
                      SpeakerWidget(
                        isPlaying: bloc.voicePlayState == VoicePlayState.playing,
                        // 控制动画播放
                        isClickable: !bloc.isRecording,
                        // 控制是否可点击
                        width: 45.w,
                        height: 45.w,
                        onTap: () {
                          bloc.add(VoicePlayEvent());
                        },
                      ),
                      10.horizontalSpace,
                      Text(topics?.word ?? '')
                    ],
2eb67dd4   liangchengyou   feat:调整代码
523
524
                  ),
                  70.verticalSpace,
d4d91cb0   吴启风   feat:lottie动效组件封装...
525
526
527
528
529
                  RecorderWidget(
                    isPlaying: bloc.isRecording,
                    isClickable: bloc.voicePlayState != VoicePlayState.playing,
                    width: 72.w,
                    height: 72.w,
2eb67dd4   liangchengyou   feat:调整代码
530
                    onTap: () {
d4d91cb0   吴启风   feat:lottie动效组件封装...
531
                      if (bloc.isRecording) {
ae77d87f   吴启风   feat:fix语音题无法手动停止...
532
                        bloc.add(XSVoiceStopEvent());
2eb67dd4   liangchengyou   feat:调整代码
533
534
                        return;
                      }
ae77d87f   吴启风   feat:fix语音题无法手动停止...
535
536
                      if (topics?.type == TopicType.voiceQuestion.value ||
                          topics?.type == TopicType.voiceWord.value) {
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
537
538
                        bloc.add(XSVoiceStartEvent(topics?.keyWord ?? '', '0',
                            UserUtil.getUser()!.id.toString()));
b90a1518   liangchengyou   feat:练习接口逻辑完成
539
                      } else {
f29687b2   biao   修复iOS偶现按钮消失问题,练习页...
540
541
                        bloc.add(XSVoiceStartEvent(topics?.word ?? '', '0',
                            UserUtil.getUser()!.id.toString()));
b90a1518   liangchengyou   feat:练习接口逻辑完成
542
                      }
2eb67dd4   liangchengyou   feat:调整代码
543
                    },
d4d91cb0   吴启风   feat:lottie动效组件封装...
544
                  ),
2eb67dd4   liangchengyou   feat:调整代码
545
                ],
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
546
547
              )
            ],
2eb67dd4   liangchengyou   feat:调整代码
548
549
          );
        });
32b3acf4   吴启风   feat:选择题作答完毕颜色参考hkc
550
551
552
553
554
555
556
557
  
    Color getResultColor(bool correct) {
      if (correct) {
        return const Color(0xFF19D717);
      } else {
        return const Color(0xFFFF463C);
      }
    }
da82bd70   Key   feat: user_inform...
558
  }