ho rielaborato una soluzione e finalmente trovato un modo molto semplice da implementare allo stesso modo in cui è stato fatto su GMail: il HorizontalScrollView scorrerà fino a raggiungere una dei suoi bordi. Quindi al prossimo scorrimento, l'intera pagina scorrerà.
Tutto ciò che serviva era sovrascrivere HorizontalScrollView per controllare la direzione di scorrimento verso i bordi e assicurarsi che il contenuto potesse effettivamente scorrere.
@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);
}
orologio [questo] risposta (http://stackoverflow.com/questions/7774642/scroll-webview-horizontally-inside-a-viewpager). Ma invece di WebView personalizzato in quella risposta, potresti dover estendere il tuo HorizontalScrollingView. – grine4ka