Возможно ли, чтобы стрелка была перемещена только при перемещении большого пальца. Прямо сейчас стрелка перемещается даже при касании пальца в progressdrawable. Как отключить перемещение касание пальцем от progressdrawable?
Спасибо.
Возможно ли, чтобы стрелка была перемещена только при перемещении большого пальца. Прямо сейчас стрелка перемещается даже при касании пальца в progressdrawable. Как отключить перемещение касание пальцем от progressdrawable?
Спасибо.
Отмените OnTouchListener
для поиска и обрабатывайте движение только на большом пальце, когда MotionEvent
является событием перемещения.
event.getAction() == MotionEvent.ACTION_MOVE
Обновление: 1
Что-то вроде этого будет работать, но улов в том, что даже если пользователь перемещает большой палец на 2 единицы, стрелка перемещается. И вы действительно не должны останавливать это поведение, так как это может испортить поисковую панель.
seekBar.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
if(event.getAction() == MotionEvent.ACTION_MOVE){
Log.d(TAG, "Moved , process data, Moved to :" + seekBar.getProgress());
seekBar.setProgress(seekBar.getProgress());
return false;
}
Log.d(TAG, "Touched , Progress :" + seekBar.getProgress());
return true;
}
});
Я обнаружил, что проблема с Ravi solution заключается в том, что касание и перемещение за пределы текущего положения большого пальца все равно приведет к скачку.
В приведенном ниже классе решается эта проблема и заменяется на переход на касание с небольшим шагом, так же как и с клавишами со стрелками.
import android.content.Context;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.widget.SeekBar;
/**
* A NoSkipSeekBar is an extension of {@link SeekBar} that prevents jumps in position
* by touching outside the current thumb position. Such touches are replaced by
* an increment or decrement the same as would be achieved using a DPAD Left or
* Right arrow keys.
*/
public class NoSkipSeekBar extends SeekBar {
public NoSkipSeekBar(Context context) {
super(context);
}
public NoSkipSeekBar(Context context, AttributeSet attrs) {
super(context, attrs);
}
public NoSkipSeekBar(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
private boolean isDragging;
private boolean isWithinThumb(MotionEvent event) {
return getThumb().getBounds().contains((int)event.getX(), (int)event.getY());
}
private void increment(int direction) {
if (direction != 0) {
final KeyEvent key = new KeyEvent(KeyEvent.ACTION_DOWN,
direction < 0 ? KeyEvent.KEYCODE_DPAD_LEFT : KeyEvent.KEYCODE_DPAD_RIGHT);
onKeyDown(key.getKeyCode(), key);
}
}
@Override
public boolean onTouchEvent(MotionEvent event) {
if (!isEnabled() || getThumb() == null) return super.onTouchEvent(event);
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
if (isWithinThumb(event)) {
isDragging = true;
return super.onTouchEvent(event);
} else {
return true;
}
case MotionEvent.ACTION_UP:
isDragging = false;
if (isWithinThumb(event)) {
return super.onTouchEvent(event);
} else {
final Rect r = getThumb().getBounds();
increment((int)event.getX() - (r.left + r.right) / 2);
return true;
}
case MotionEvent.ACTION_MOVE:
if (!isDragging) return true;
break;
case MotionEvent.ACTION_CANCEL:
isDragging = false;
break;
}
return super.onTouchEvent(event);
}
}
Вы посмотрели на это:
Действительно подобная тема, которая поможет вам решить ваш вопрос:
Большой палец SeekBar появляется только при касании
Желаем удачи
Решение Ravi отлично, я сделал несколько рефакторингов ниже:
Две цели:
getThumb()
, которая может использоваться только над проблемами API 16.onStopTrackingTouch()
, а только перетащит большой палецЭто мой код:
public class NoSkipSeekBar extends SeekBar {
Drawable mThumb;
@Override
public void setThumb(Drawable thumb) {
super.setThumb(thumb);
mThumb = thumb;
}
public Drawable getSeekBarThumb() {
return mThumb;
}
public NoSkipSeekBar(Context context) {
super(context);
}
public NoSkipSeekBar(Context context, AttributeSet attrs) {
super(context, attrs);
}
public NoSkipSeekBar(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
private boolean isDragging;
private boolean isStart = false;
private boolean isWithinThumb(MotionEvent event) {
Rect rect = getSeekBarThumb().getBounds();//increate the thumb invoke area
Rect rect1 = new Rect();
rect1.left = rect.left - 50;
rect1.right = rect.right + 50;
rect1.bottom = rect.bottom + 50;
return rect1.contains((int)event.getX(), (int)event.getY());
}
private void increment(int direction) {
if (direction != 0) {
final KeyEvent key = new KeyEvent(KeyEvent.ACTION_DOWN,
direction < 0 ? KeyEvent.KEYCODE_DPAD_LEFT : KeyEvent.KEYCODE_DPAD_RIGHT);
onKeyDown(key.getKeyCode(), key);
}
}
@Override
public boolean onTouchEvent(MotionEvent event) {
if (!isEnabled() || getSeekBarThumb() == null) return super.onTouchEvent(event);
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
if (isWithinThumb(event)) {
isDragging = true;
isStart = true;
return super.onTouchEvent(event);
} else {
return true;
}
case MotionEvent.ACTION_UP:
isDragging = false;
if(isStart){
isStart = false;
return super.onTouchEvent(event);
}
if (isWithinThumb(event)) {
return super.onTouchEvent(event);
} else {
//final Rect r = getThumb().getBounds();
//increment((int)event.getX() - (r.left + r.right) / 2);
return true;
}
case MotionEvent.ACTION_MOVE:
if (!isDragging) return true;
break;
case MotionEvent.ACTION_CANCEL:
isDragging = false;
break;
}
return super.onTouchEvent(event);
}
}