mirror of
https://github.com/SimpleMobileTools/Simple-Dialer.git
synced 2025-06-05 21:49:23 +02:00
Merge pull request #274 from Aga-C/add-swipe-to-answer
Added swipe to answer an incoming call (#127)
This commit is contained in:
@ -11,7 +11,9 @@ import android.os.Handler
|
||||
import android.os.PowerManager
|
||||
import android.telecom.Call
|
||||
import android.telecom.CallAudioState
|
||||
import android.view.MotionEvent
|
||||
import android.view.WindowManager
|
||||
import android.widget.ImageView
|
||||
import com.simplemobiletools.commons.extensions.*
|
||||
import com.simplemobiletools.commons.helpers.MINUTE_SECONDS
|
||||
import com.simplemobiletools.commons.helpers.isOreoMr1Plus
|
||||
@ -45,6 +47,8 @@ class CallActivity : SimpleActivity() {
|
||||
private var callDuration = 0
|
||||
private val callContactAvatarHelper by lazy { CallContactAvatarHelper(this) }
|
||||
private val callDurationHelper by lazy { (application as App).callDurationHelper }
|
||||
private var dragDownX = 0f
|
||||
private var stopAnimation = false
|
||||
|
||||
override fun onCreate(savedInstanceState: Bundle?) {
|
||||
supportActionBar?.hide()
|
||||
@ -94,13 +98,7 @@ class CallActivity : SimpleActivity() {
|
||||
}
|
||||
|
||||
private fun initButtons() {
|
||||
call_decline.setOnClickListener {
|
||||
endCall()
|
||||
}
|
||||
|
||||
call_accept.setOnClickListener {
|
||||
acceptCall()
|
||||
}
|
||||
handleSwipe()
|
||||
|
||||
call_toggle_microphone.setOnClickListener {
|
||||
toggleMicrophone()
|
||||
@ -145,6 +143,115 @@ class CallActivity : SimpleActivity() {
|
||||
call_sim_id.setTextColor(config.textColor.getContrastColor())
|
||||
}
|
||||
|
||||
@SuppressLint("ClickableViewAccessibility")
|
||||
private fun handleSwipe() {
|
||||
var minDragX = 0f
|
||||
var maxDragX = 0f
|
||||
var initialDraggableX = 0f
|
||||
var initialLeftArrowX = 0f
|
||||
var initialRightArrowX = 0f
|
||||
var initialLeftArrowScaleX = 0f
|
||||
var initialLeftArrowScaleY = 0f
|
||||
var initialRightArrowScaleX = 0f
|
||||
var initialRightArrowScaleY = 0f
|
||||
var leftArrowTranslation = 0f
|
||||
var rightArrowTranslation = 0f
|
||||
|
||||
call_accept.onGlobalLayout {
|
||||
minDragX = call_decline.left.toFloat()
|
||||
maxDragX = call_accept.left.toFloat()
|
||||
initialDraggableX = call_draggable.left.toFloat()
|
||||
initialLeftArrowX = call_left_arrow.x
|
||||
initialRightArrowX = call_right_arrow.x
|
||||
initialLeftArrowScaleX = call_left_arrow.scaleX
|
||||
initialLeftArrowScaleY = call_left_arrow.scaleY
|
||||
initialRightArrowScaleX = call_right_arrow.scaleX
|
||||
initialRightArrowScaleY = call_right_arrow.scaleY
|
||||
leftArrowTranslation = -call_decline.x
|
||||
rightArrowTranslation = call_decline.x
|
||||
|
||||
call_left_arrow.applyColorFilter(getColor(R.color.md_red_400))
|
||||
call_right_arrow.applyColorFilter(getColor(R.color.md_green_400))
|
||||
|
||||
startArrowAnimation(call_left_arrow, initialLeftArrowX, initialLeftArrowScaleX, initialLeftArrowScaleY, leftArrowTranslation)
|
||||
startArrowAnimation(call_right_arrow, initialRightArrowX, initialRightArrowScaleX, initialRightArrowScaleY, rightArrowTranslation)
|
||||
}
|
||||
|
||||
var lock = false
|
||||
call_draggable.setOnTouchListener { v, event ->
|
||||
when (event.action) {
|
||||
MotionEvent.ACTION_DOWN -> {
|
||||
dragDownX = event.x
|
||||
call_draggable_background.animate().alpha(0f)
|
||||
stopAnimation = true
|
||||
call_left_arrow.animate().alpha(0f)
|
||||
call_right_arrow.animate().alpha(0f)
|
||||
lock = false
|
||||
}
|
||||
MotionEvent.ACTION_UP, MotionEvent.ACTION_CANCEL -> {
|
||||
dragDownX = 0f
|
||||
call_draggable.animate().x(initialDraggableX).withEndAction {
|
||||
call_draggable_background.animate().alpha(0.2f)
|
||||
}
|
||||
call_draggable.setImageDrawable(getDrawable(R.drawable.ic_phone_down_vector))
|
||||
call_left_arrow.animate().alpha(1f)
|
||||
call_right_arrow.animate().alpha(1f)
|
||||
stopAnimation = false
|
||||
startArrowAnimation(call_left_arrow, initialLeftArrowX, initialLeftArrowScaleX, initialLeftArrowScaleY, leftArrowTranslation)
|
||||
startArrowAnimation(call_right_arrow, initialRightArrowX, initialRightArrowScaleX, initialRightArrowScaleY, rightArrowTranslation)
|
||||
}
|
||||
MotionEvent.ACTION_MOVE -> {
|
||||
call_draggable.x = Math.min(maxDragX, Math.max(minDragX, event.rawX - dragDownX))
|
||||
when {
|
||||
call_draggable.x >= maxDragX - 50f -> {
|
||||
if (!lock) {
|
||||
lock = true
|
||||
call_draggable.performHapticFeedback()
|
||||
acceptCall()
|
||||
}
|
||||
}
|
||||
call_draggable.x <= minDragX + 50f -> {
|
||||
if (!lock) {
|
||||
lock = true
|
||||
call_draggable.performHapticFeedback()
|
||||
endCall()
|
||||
}
|
||||
}
|
||||
call_draggable.x > initialDraggableX -> {
|
||||
lock = false
|
||||
call_draggable.setImageDrawable(getDrawable(R.drawable.ic_phone_green_vector))
|
||||
}
|
||||
call_draggable.x <= initialDraggableX -> {
|
||||
lock = false
|
||||
call_draggable.setImageDrawable(getDrawable(R.drawable.ic_phone_down_red_vector))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
true
|
||||
}
|
||||
}
|
||||
|
||||
private fun startArrowAnimation(arrow: ImageView, initialX: Float, initialScaleX: Float, initialScaleY: Float, translation: Float) {
|
||||
arrow.apply {
|
||||
alpha = 1f
|
||||
x = initialX
|
||||
scaleX = initialScaleX
|
||||
scaleY = initialScaleY
|
||||
animate()
|
||||
.alpha(0f)
|
||||
.translationX(translation)
|
||||
.scaleXBy(-0.5f)
|
||||
.scaleYBy(-0.5f)
|
||||
.setDuration(1000)
|
||||
.withEndAction {
|
||||
if (!stopAnimation) {
|
||||
startArrowAnimation(this, initialX, initialScaleX, initialScaleY, translation)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private fun dialpadPressed(char: Char) {
|
||||
CallManager.keypad(char)
|
||||
dialpad_input.addCharacter(char)
|
||||
|
Reference in New Issue
Block a user