mirror of
				https://github.com/oxen-io/session-android.git
				synced 2025-10-20 18:48:40 +00:00 
			
		
		
		
	fix: avoid crash in voice message view for pending downloads, display the icon on player stop when player starting from another view. Use thread id in setAttachmentAudioExtras
This commit is contained in:
		| @@ -107,7 +107,7 @@ class DatabaseAttachmentProvider(context: Context, helper: SQLCipherOpenHelper) | ||||
|             attachmentId = attachmentId, | ||||
|             visualSamples = byteArrayOf(), | ||||
|             durationMs = durationMs | ||||
|         )) | ||||
|         ), threadId) | ||||
|     } | ||||
|  | ||||
|     override fun isOutgoingMessage(timestamp: Long): Boolean { | ||||
|   | ||||
| @@ -4,7 +4,8 @@ import android.content.Context | ||||
| import android.graphics.Canvas | ||||
| import android.util.AttributeSet | ||||
| import android.util.Log | ||||
| import android.view.* | ||||
| import android.view.LayoutInflater | ||||
| import android.view.View | ||||
| import android.widget.LinearLayout | ||||
| import android.widget.RelativeLayout | ||||
| import androidx.core.view.isVisible | ||||
| @@ -23,6 +24,10 @@ import kotlin.math.roundToLong | ||||
| class VoiceMessageView : LinearLayout, AudioSlidePlayer.Listener { | ||||
|     private val cornerMask by lazy { CornerMask(this) } | ||||
|     private var isPlaying = false | ||||
|     set(value) { | ||||
|         field = value | ||||
|         renderIcon() | ||||
|     } | ||||
|     private var progress = 0.0 | ||||
|     private var duration = 0L | ||||
|     private var player: AudioSlidePlayer? = null | ||||
| @@ -44,8 +49,6 @@ class VoiceMessageView : LinearLayout, AudioSlidePlayer.Listener { | ||||
|     // region Updating | ||||
|     fun bind(message: MmsMessageRecord, isStartOfMessageCluster: Boolean, isEndOfMessageCluster: Boolean) { | ||||
|         val audio = message.slideDeck.audioSlide!! | ||||
|         val player = AudioSlidePlayer.createFor(context, audio, this) | ||||
|         this.player = player | ||||
|         voiceMessageViewLoader.isVisible = audio.isPendingDownload | ||||
|         val cornerRadii = MessageBubbleUtilities.calculateRadii(context, isStartOfMessageCluster, isEndOfMessageCluster, message.isOutgoing) | ||||
|         cornerMask.setTopLeftRadius(cornerRadii[0]) | ||||
| @@ -54,7 +57,13 @@ class VoiceMessageView : LinearLayout, AudioSlidePlayer.Listener { | ||||
|         cornerMask.setBottomLeftRadius(cornerRadii[3]) | ||||
|  | ||||
|         // only process audio if downloaded | ||||
|         if (audio.isPendingDownload || audio.isInProgress) return | ||||
|         if (audio.isPendingDownload || audio.isInProgress) { | ||||
|             this.player = null | ||||
|             return | ||||
|         } | ||||
|  | ||||
|         val player = AudioSlidePlayer.createFor(context, audio, this) | ||||
|         this.player = player | ||||
|  | ||||
|         (audio.asAttachment() as? DatabaseAttachment)?.let { attachment -> | ||||
|             DatabaseFactory.getAttachmentDatabase(context).getAttachmentAudioExtras(attachment.attachmentId)?.let { audioExtras -> | ||||
| @@ -90,20 +99,27 @@ class VoiceMessageView : LinearLayout, AudioSlidePlayer.Listener { | ||||
|         progressView.layoutParams = layoutParams | ||||
|     } | ||||
|  | ||||
|     override fun onPlayerStop(player: AudioSlidePlayer) { } | ||||
|     override fun onPlayerStop(player: AudioSlidePlayer) { | ||||
|         Log.d("Loki", "Player stopped") | ||||
|         isPlaying = false | ||||
|     } | ||||
|  | ||||
|     override fun dispatchDraw(canvas: Canvas) { | ||||
|         super.dispatchDraw(canvas) | ||||
|         cornerMask.mask(canvas) | ||||
|     } | ||||
|  | ||||
|     private fun renderIcon() { | ||||
|         val iconID = if (isPlaying) R.drawable.exo_icon_pause else R.drawable.exo_icon_play | ||||
|         voiceMessagePlaybackImageView.setImageResource(iconID) | ||||
|     } | ||||
|  | ||||
|     // endregion | ||||
|  | ||||
|     // region Interaction | ||||
|     fun togglePlayback() { | ||||
|         val player = this.player ?: return | ||||
|         isPlaying = !isPlaying | ||||
|         val iconID = if (isPlaying) R.drawable.exo_icon_pause else R.drawable.exo_icon_play | ||||
|         voiceMessagePlaybackImageView.setImageResource(iconID) | ||||
|         if (isPlaying) { | ||||
|             player.play(progress) | ||||
|         } else { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Harris
					Harris