2011-12-21 16 views
6

Mam poziomy przewijany stron jak na rynku Android (ViewPager).Przewijanie w poziomie Przeglądanie wewnątrz ViewPager

Mój problem polega na tym, że chcę mieć w nich widok przewijania w poziomie z niektórymi obrazkami? Czy to możliwe?

W tej chwili dostaję mały przewijak w moim widoku, a następnie przewija się cała strona.

Dziękujemy za poświęcony czas!

+0

Obejrzyj odpowiedź [this] (http://stackoverflow.com/questions/7774642/scroll-webview-horizontally-inside-a-viewpager). Ale zamiast niestandardowego WebView w tej odpowiedzi, może być konieczne rozszerzenie HorizontalScrollingView. – grine4ka

Odpowiedz

0
<Linearlayout> 
    <linearlayout> 
     <scrollView> 
      <ImageView1></ImageView> 
      <ImageView2></....> 
     </scrollView> 
    </Linearlayout> 
    <EditText> 
</Linearlayout> 

W powyższym przypadku scrollVIew dotyczy tylko dwóch obrazów, które nie są edytowalne.

W innym przypadku:

<Linearlayout> 
    <linearlayout> 
     <scrollView> 
      here listVIew with Images using listView adapter 
     </scrollView> 
    </Linearlayout> 
    <EditText> 
</Linearlayout> 

Tutaj Scrollview ma zastosowanie wyłącznie do ListView.

18

Musisz przedłużyć HorizontalScrollView i przechwycić zdarzenia dotykowe. Co pracował dla mnie było następujące próbki:

public class MyScrollView extends HorizontalScrollView { 

    public MyScrollView(Context p_context, AttributeSet p_attrs) 
    { 
     super(p_context, p_attrs); 
    } 

    @Override 
    public boolean onInterceptTouchEvent(MotionEvent p_event) 
    { 
     return true; 
    } 

    @Override 
    public boolean onTouchEvent(MotionEvent p_event) 
    { 
     if (p_event.getAction() == MotionEvent.ACTION_MOVE && getParent() != null) 
     { 
      getParent().requestDisallowInterceptTouchEvent(true); 
     } 

     return super.onTouchEvent(p_event); 
    } 
} 

Następnie, zamiast używania HorizontalScrollView w XML układu, trzeba użyć tego widoku niestandardowego.

Co pomogło mi dostać się do tego rozwiązania jest this post

+0

To działa dla mnie, inne rozwiązania nie! Wydaje się jednak, że wyłącza obsługę klikania przycisków wewnątrz niestandardowego przewijania. Dowolny pomysł? – user1365836

+0

@ user1365836 Tak ... to może być trochę niechlujne ... To, co zrobiłem, to użycie getHitRect i znajdowanie dokładnego przycisku wciśniętego, a następnie wywoływanie jego funkcji onClick – Muzikant

+6

Jeśli jedyną rzeczą, którą chcesz zrobić, jest zezwolenie na przewijanie, ale nadal zezwalaj na użytkownik, aby kliknąć elementy wewnątrz, po prostu trzeba kontrolować wszystko od wewnątrz onInterceptTouchEvent(). https://gist.github.com/brandondenney/b8ddd655664eb295129d – Brandon

1

mam przerobione rozwiązanie iw końcu znalazłem bardzo prosty sposób, aby wdrożyć go w ten sam sposób to zostało zrobione na GMail: im HorizontalScrollView będą przewijać aż osiągnie jedną jego krawędzi. Następnie przy następnym przewijaniu przewija się cała strona.

Wymagało tylko przesłonięcia HorizontalScrollView w celu sprawdzenia kierunku przewijania względem krawędzi, a także upewnienia się, że zawartość może faktycznie przewijać.

@Override 
public boolean onTouchEvent(MotionEvent ev) 
{ 
    if (no_scrolling) 
     return false; 

    // Standard behavior 
    // 
    return super.onTouchEvent(ev); 
} 

boolean no_scrolling = false; 
float old_x, old_y; 
@Override 
public boolean onInterceptTouchEvent(MotionEvent ev) 
{ 
    int action = ev.getActionMasked(); 
    Log.d(at_data.TAG, "HSV scroll intercept: " + String.format("0x%08x", action)); 

    if (action == MotionEvent.ACTION_DOWN) 
    { 
     old_x = ev.getX(); 
     old_y = ev.getY(); 
     no_scrolling = false; 

    } 
    else if (action == MotionEvent.ACTION_MOVE) 
    { 
     float dx = ev.getX() - old_x; 
     float dy = ev.getY() - old_y; 

     if (Math.abs(dx) > Math.abs(dy) && dx != 0) 
     { 
      View hsvChild = getChildAt(0); 
      int childW = hsvChild.getWidth(); 
      int W = getWidth(); 

      Log.d(at_data.TAG, "HSV " + childW + " > " + W + " ? dx = " + dx + " dy = " + dy); 
      if (childW > W) 
      { 
       int scrollx = getScrollX(); 
       if ((dx < 0 && scrollx + W >= childW) || (dx > 0 && scrollx <= 0)) 
       { 
        Log.d(at_data.TAG, "HSV Wider: on edge already"); 
        no_scrolling = true; 
        return false; 
       } 
       else 
       { 
        Log.d(at_data.TAG, "HSV Wider: can scroll"); 
        no_scrolling = false; 
       } 
      } 
      else 
      { 
       Log.d(at_data.TAG, "HSV cannot scroll in desired direction"); 
       no_scrolling = true; 
      } 
     } 
    } 

    // Standard behavior 
    // 
    return super.onInterceptTouchEvent(ev); 
} 
Powiązane problemy