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