From aa512ff5fc428fbee046d6bc0761c3675023769e Mon Sep 17 00:00:00 2001 From: 罗明文 <125975490@qq.com> Date: 星期三, 21 五月 2025 15:49:32 +0800 Subject: [PATCH] save --- app/src/main/java/com/dollearn/student/ui/home/IncludeFragment.kt | 108 ++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 88 insertions(+), 20 deletions(-) diff --git a/app/src/main/java/com/dollearn/student/ui/home/IncludeFragment.kt b/app/src/main/java/com/dollearn/student/ui/home/IncludeFragment.kt index 54cee71..744ab92 100644 --- a/app/src/main/java/com/dollearn/student/ui/home/IncludeFragment.kt +++ b/app/src/main/java/com/dollearn/student/ui/home/IncludeFragment.kt @@ -16,8 +16,12 @@ import com.dollearn.student.R import com.dollearn.student.utils.AudioUtils import com.dollearn.student.utils.Const +import com.dollearn.student.utils.event.EmptyEvent import com.dollearn.student.utils.extention.clickDelay import kotlinx.android.synthetic.main.fragment_include.* +import org.greenrobot.eventbus.EventBus +import org.greenrobot.eventbus.Subscribe +import org.jetbrains.anko.support.v4.dip import org.jetbrains.anko.support.v4.startActivity class IncludeFragment : BaseFragment(), AudioUtils.OnAudioStatusUpdateListener { @@ -47,7 +51,7 @@ private val act by lazy { requireActivity() as IncludeActivity } private var voiceIndex = -1 //点击播放的声音序号 0-5取值 - private val voiceViews by lazy { arrayListOf(cl_voice1,cl_voice2,cl_voice3,cl_voice4,cl_voice5,cl_voice6) } + private val voiceViews by lazy { arrayListOf(cl_voice1_real,cl_voice2_real,cl_voice3_real,cl_voice4_real,cl_voice5_real,cl_voice6_real) } private var playing = false private val answerImg = arrayListOf<String>() //随机答案图片 @@ -55,14 +59,20 @@ private var nowVoiceView: View? = null + private var isAutoPlaying = false //true自动播放流程 + + var right = true //true进入下一题为全对,false 一旦答错过就置为false,此时进入下一题,本题算做错误 + override fun onFirstVisibleToUser() { player.setOnAudioStatusUpdateListener(this) player.stopPlayMusic() + EventBus.getDefault().register(this) handler = object : Handler(Looper.getMainLooper()){ override fun handleMessage(msg: Message) { super.handleMessage(msg) when(msg.what){ PLAY_VOICE->{ + playing = true player.startPlayMusic(requireContext(),data!!.subjectList[group][voiceIndex].correct) } TO_NEXT->{ @@ -71,10 +81,12 @@ } } PLAY_RIGHT->{ + playing = true rightPlaying = true player.startPlayMusic(requireContext(),rightVoice) } PLAY_ERROR->{ + playing = true errorPlaying = true player.startPlayMusic(requireContext(),errorVoice) } @@ -83,13 +95,23 @@ } data?.apply { val originList = subjectList[group] - iv_1.setImageURI(originList[0].img) - iv_2.setImageURI(originList[1].img) - iv_4.setImageURI(originList[3].img) answerImg.clear() answerImg.add(originList[2].img) answerImg.add(originList[4].img) answerImg.add(originList[5].img) + cl_voice1_real.postDelayed({ + iv_1.setImageURI(originList[0].img) + iv_2.setImageURI(originList[1].img) + iv_4.setImageURI(originList[3].img) +// if (cl_1.width > dip(203)){ +// voiceViews.forEach { +// it.layoutParams.width = dip(159) +// it.layoutParams.height = dip(52) +// it.requestLayout() +// } +// } + voiceViews.forEach { it.visible() } + },500) } voiceViews.forEachIndexed { index, constraintLayout -> if (index == 0) @@ -101,17 +123,17 @@ constraintLayout.isEnabled = data!!.subjectList[group][index].listend } } - showVoiceEnable() initClick() + showVoiceEnable() } private fun initClick() { voiceViews.forEachIndexed { index, constraintLayout -> - constraintLayout.clickDelay { + constraintLayout.setOnClickListener { if (!playing){ if (index!=0&&!data!!.subjectList[group][index-1].listend){ myToast("请按顺序听语音") - return@clickDelay + return@setOnClickListener } voiceIndex = index handler?.sendEmptyMessage(PLAY_VOICE) @@ -120,13 +142,14 @@ } cl_answer_1.clickDelay { - if (currentImage == 0) + if (currentImage == 0||!data!!.subjectList[group][currentImage].listend) return@clickDelay val subject = data!!.subjectList[group][currentImage] if (!subject.listend||subject.completed){ return@clickDelay } act.totalCount++ + data!!.subjectList[group][currentImage].listend = false if (answerImg[0] == subject.img){ nowVoiceView = voiceViews[currentImage] act.rightCount++ @@ -134,6 +157,7 @@ motion.transitionToEnd() showResultAnim() }else{ + right = false handler?.sendEmptyMessage(PLAY_ERROR) iv_error_1.visible() iv_error_1.postDelayed({ @@ -143,7 +167,7 @@ } cl_answer_2.clickDelay { - if (currentImage == 0) + if (currentImage == 0||!data!!.subjectList[group][currentImage].listend) return@clickDelay val subject = data!!.subjectList[group][currentImage] if (!subject.listend||subject.completed){ @@ -151,6 +175,7 @@ } act.totalCount++ + data!!.subjectList[group][currentImage].listend = false if (answerImg[1] == subject.img){ nowVoiceView = voiceViews[currentImage] act.rightCount++ @@ -158,6 +183,7 @@ motion.transitionToEnd() showResultAnim() }else{ + right = false handler?.sendEmptyMessage(PLAY_ERROR) iv_error_2.visible() iv_error_2.postDelayed({ @@ -167,7 +193,7 @@ } cl_answer_3.clickDelay { - if (currentImage == 0) + if (currentImage == 0||!data!!.subjectList[group][currentImage].listend) return@clickDelay val subject = data!!.subjectList[group][currentImage] if (!subject.listend||subject.completed){ @@ -175,6 +201,7 @@ } act.totalCount++ + data!!.subjectList[group][currentImage].listend = false if (answerImg[2] == subject.img){ nowVoiceView = voiceViews[currentImage] act.rightCount++ @@ -182,6 +209,7 @@ motion.transitionToEnd() showResultAnim() }else{ + right = false handler?.sendEmptyMessage(PLAY_ERROR) iv_error_3.visible() iv_error_3.postDelayed({ @@ -341,11 +369,23 @@ }) } + @Subscribe + fun onEvent(e: EmptyEvent){ + if (e.code == Const.EventCode.RECOVERD){ + if (act.fragments[act.vp.currentItem] == this){ //自动播放 + isAutoPlaying = true + voiceViews[0].callOnClick() + } + } + } + /** * 回到上一题,恢复状态 */ fun recover(){ Log.e(TAG,"回到上一题,恢复答题前的状态") + right = true + isAutoPlaying = false motion.progress = 0f clearAnswerImg() currentImage = 0 @@ -354,6 +394,10 @@ it.listend = false } showVoiceEnable() + if (act.fragments[act.vp.currentItem] == this&&act.recoverd) { //自动播放 + isAutoPlaying = true + voiceViews[0].callOnClick() + } } companion object{ @@ -417,7 +461,6 @@ override fun onFinishPlay() { playing = false val subject = data!!.subjectList[group][voiceIndex] - subject.listend = true when(voiceIndex){ 0->{ iv1_1.visible() @@ -466,23 +509,48 @@ }else{ hideAnswerImg() Log.e(TAG,"本题全部答对,3秒后进入下一图") - handler?.sendEmptyMessageDelayed(TO_NEXT,3000) + handler?.sendEmptyMessageDelayed(TO_NEXT,500) //万俊杰:缩短为0.5秒 + } + } + } + if (errorPlaying) + errorPlaying = false + else if (rightPlaying) { + rightPlaying = false + data!!.subjectList[group][currentImage].completed = true + nowVoiceView?.callOnClick() + }else{ + subject.listend = true + if (isAutoPlaying) + when(voiceIndex){ + 0-> voiceViews[1].callOnClick() + 1-> voiceViews[2].callOnClick() + 3-> voiceViews[4].callOnClick() + 2,4,5-> isAutoPlaying = false + } + else if (subject.completed){ + when(voiceIndex){ + 2->{ + isAutoPlaying = true + voiceViews[3].callOnClick() + } + 4->{ + voiceViews[5].callOnClick() + } } } } showVoiceEnable() - - if (errorPlaying) - errorPlaying = false - if (rightPlaying) { - rightPlaying = false - data!!.subjectList[group][currentImage].completed = true - nowVoiceView?.callOnClick() - } } override fun onPause() { super.onPause() player.stopPlayMusic() } + + override fun onDestroy() { + super.onDestroy() + handler?.removeCallbacksAndMessages(null) + EventBus.getDefault().unregister(this) + } } \ No newline at end of file -- Gitblit v1.7.1