¿Hay alguna manera de desplazarse programáticamente a la parte superior de un NestedScrollView
activando también los eventos de desplazamiento para el padre? smoothScrollTo(x, y)
no delega los eventos de desplazamiento al NestedScrollingParent
.
¿Hay alguna manera de desplazarse programáticamente a la parte superior de un NestedScrollView
activando también los eventos de desplazamiento para el padre? smoothScrollTo(x, y)
no delega los eventos de desplazamiento al NestedScrollingParent
.
Respuestas:
NestedScrollView.scrollTo(0, 0);
NestedScrollView.scrollTo(0, 0);
para desplazarse hasta la parte superior del archivo NestedScrollView
. De nada.
Logré hacerlo (desplazamiento animado):
CoordinatorLayout.LayoutParams params = (CoordinatorLayout.LayoutParams) appBarLayout.getLayoutParams();
AppBarLayout.Behavior behavior = (AppBarLayout.Behavior) params.getBehavior();
if (behavior != null) {
behavior.onNestedFling(coordinatorLayout, appBarLayout, null, 0, 10000, true);
}
donde 10000
es la velocidad en la dirección y.
behavior.onNestedFling(coordinator, appbar, null, 0, -params.height, true);
para revertirlobehavior.onNestedFling(coordinator, appbar, null, 0, params.height, true);
Otra forma de suavizar el desplazamiento NestedScrollView
hacia arriba o hacia abajo es usando la fullScroll(direct)
función
nestedScrollView.fullScroll(View.FOCUS_DOWN);
nestedScrollView.fullScroll(View.FOCUS_UP);
NestedScrollView
debajo de la barra de aplicaciones?
Nada funcionó para mí, y realmente no sé por qué funcionó, pero aquí está mi solución y problema.
Al agregar la vista de reciclador a una vista de desplazamiento anidada, mostraba la vista de reciclador en la pantalla al llegar a esa actividad. Para desplazarme hacia arriba, tuve que usar esto:
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.details_recycler_view);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
recyclerView.setItemAnimator(new DefaultItemAnimator());
ProductDescriptionAdapter adapter = new ProductDescriptionAdapter(this);
adapter.setData(mProduct.getDetails());
recyclerView.setAdapter(adapter);
NestedScrollView scrollView = (NestedScrollView) findViewById(R.id.scroll);
scrollView.getParent().requestChildFocus(scrollView, scrollView);
scrollView.getParent().requestChildFocus(scrollView, scrollView);
También me enfrenté a un escenario similar. En mi caso, cuando me desplazo hacia abajo para terminar, debería aparecer el botón FAB y cuando el usuario toque ese botón FAB debería ir a la parte superior de la página. Para eso, agregué la respuesta de @SilentKnight NestedScrollView.scrollTo(0, 0);
Para ir a la parte superior, pero que no es suficiente para una animación suave para desplazarse hacia arriba.
Para una animación fluida, he usado la respuesta de @Sharj, que es NestedScrollView.fullScroll(View.FOCUS_UP);
Pero luego mi AppBar no es visible, por lo tanto, tengo que expandir la AppBar de la siguiente manera appBarLayout1.setExpanded(true)
. Entonces, usando estos tres puedo ir sin problemas a la parte superior de la página.
nestedScrollView.fullScroll(View.FOCUS_UP);
nestedScrollView.scrollTo(0,0);
appBarLayout1.setExpanded(true);
Fácilmente podría simular el desplazamiento en el nivel NestedScrollView. Básicamente, le dice al coordinatorLayout que acaba de desplazarse por la altura de la barra de herramientas.
NestedScrollView nestedScrollView = (NestedScrollView) getActivity().findViewById(R.id.your_nested_scroll_view);
int toolbarHeight = getActivity().findViewById(R.id.toolbar).getHeight();
nestedScrollView.startNestedScroll(ViewCompat.SCROLL_AXIS_VERTICAL);
nestedScrollView.dispatchNestedPreScroll(0, toolbarHeight, null, null);
nestedScrollView.dispatchNestedScroll(0, 0, 0, 0, new int[]{0, -toolbarHeight});
nestedScrollView.scrollTo(0, nestedScrollView.getBottom());
Puede usar esto para un desplazamiento suave.
nestedScrollView.fullScroll(View.FOCUS_UP);
nestedScrollView.smoothScrollTo(0,0);
O para desplazamiento normal
nestedScrollView.fullScroll(View.FOCUS_UP);
nestedScrollView.scrollTo(0,0);
Probé todas las respuestas anteriores, nada parecía funcionar, pero solo necesitaba un postDelayed.
scrollview.postDelayed(new Runnable() {
@Override
public void run() {
listener.setAppBarExpanded(false, true); //appbar.setExpanded(expanded, animated);
scrollview.fullScroll(View.FOCUS_DOWN);
}
}, 400);
Agregue la línea dos veces. Funcionó para mí
nestedScrollView.fullScroll(View.FOCUS_UP);
nestedScrollView.fullScroll(View.FOCUS_UP);
Use View.scollTo (int x, int y) en su lugar para desplazarse hasta la parte superior.
findViewById({your NestedScrollView resource id}).scrollTo(0, 0);
Tuve un problema con NestedScrollView cuando lo usé que con RecyclerView. Este código funcionó para mí: nestedScrollView !!. GetParent (). RequestChildFocus (nestedScrollView, nestedScrollView);
val recyclerViewSearch = activity?.findViewById<RecyclerView>(R.id.recycler)
recyclerViewSearch.setAdapter(setAdapterSearch())
val nestedScrollView = activity?.findViewById<NestedScrollView>(R.id.bottom_sheet_Search)
nestedScrollView!!.getParent().requestChildFocus(nestedScrollView, nestedScrollView);
Así es como me desplazo a un elemento de RecyclerView cuando RecyclerView está dentro de NestedScrollView
Primero, obtenga y item height
luego desplácese hasta el position
que desee.
val itemHeight =
binding.calendarRecyclerView.findViewHolderForAdapterPosition(0)!!.itemView.height
binding.nestedScrollView2.smoothScrollTo(0, position * itemHeight)