Android seekbar решение
возможно ли перемещение панели поиска только при перемещении большого пальца. Прямо сейчас seekbar двигает даже на касание перста в progressdrawable. Как отключить перемещение панели поиска на палец касание progressdrawable?
спасибо.
4 ответов
переопределить OnTouchListener
для seekbar и только обрабатывать движение на большом пальце, когда MotionEvent
ход событий.
event.getAction() == MotionEvent.ACTION_MOVE
обновление : 1
что-то вроде этого будет работать, но загвоздка в том, что даже если пользователь перемещает палец 2 шт компонент seekbar движения. И вы действительно не должны останавливать это поведение, так как это испортит панель поиска.
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;
}
});
Я обнаружил, что проблема с Рави это трогательно и перемещение за пределы текущего положения большого пальца все равно приведет к скачку.
класс ниже решает эту проблему и заменяет jump-on-touch с небольшим шагом, таким же, как и с клавишами со стрелками.
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's 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 появляется только при касании
удачи
решение Рави отлично, я сделал некоторые рефакторинг ниже:
две цели:
- разрешить
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);
}
}