- ScrollView и HorizontalScrollView
- Методы scrollBy() и scrollTo()
- NestedScrollView внутри фрагмента без программной прокрутки
- 2 ответа
- РЕДАКТИРОВАТЬ
- Tutorialwing
- Output
- Getting Started
- Attributes of Android NestedScrollView Widget
- Example of Android NestedScrollView Widget
- 1. Creating New Project
- 2. Modify Values folder
- 3. Download Drawable Resources Needed
- 4. Use NestedScrollView Widget in xml file
- 5. Access NestedScrollView Widget in java file
- AndroidManifest.xml
- Constraintlayout внутри scrollview
- Могу ли я прокручивать ScrollView программно в Android?
- 16 ответов
ScrollView и HorizontalScrollView
При большом количестве информации, которую нужно поместить на экране приходится использовать полосы прокрутки. В Android существуют специальные компоненты ScrollView и HorizontalScrollView, которые являются контейнерными элементами и наследуются от ViewGroup. Обратите внимание, что класс TextView использует свою собственную прокрутку и не нуждается в добавлении отдельных полос прокрутки. Но использование отдельных полос даже с TextView может улучшить вид вашего приложения и повышает удобство работы для пользователя.
На панели инструментов компоненты можно найти в разделе Containers.
В контейнеры ScrollView и HorizontalScrollView можно размещать только один дочерний элемент (обычно LinearLayout), который в свою очередь может быть контейнером для других элементов. Виджет ScrollView, несмотря на свое название, поддерживает только вертикальную прокрутку, поэтому для создания вертикальной и горизонтальной прокрутки необходимо использовать ScrollView в сочетании с HorizontalScrollView. Обычно ScrollView используют в качестве корневого элемента, а HorizontalScrollView в качестве дочернего. Можно и наоборот, пробуйте.
В в теле метода onCreate() создайте ссылку на элемент TextView, объявленный в XML-разметке, и запишите в него через метод setText() какой-нибуль длинный текст, который не поместится в видимые размеры экрана устройства:
Запустив проект, вы должны увидеть вертикальную и горизонтальную полосы прокрутки при попытке скролирования.
Если полосы прокрутки вас раздражают, то используйте атрибут android:scrollbars=»none», который скроет их.
По такому же принципу можете вложить ImageView, чтобы просматривать большие картинки:
Методы scrollBy() и scrollTo()
Вы можете программно прокручивать контент с помощью методов scrollBy() и scrollTo(). Например, можно организовать автоматическую прокрутку во время чтения. В нашем примере мы будем прокручивать контент с помощью трёх кнопок.
Сам код для методов:
Дополнительное чтение
Библиотека ParallaxScrollView с использованием эффекта параллакса. Вы прокручиваете длинный текст, а задний фон прокручивается чуть медленнее. Возможно, кому-то пригодится. Там же можно скачать готовое демо и просмотреть в действии.
Источник
NestedScrollView внутри фрагмента без программной прокрутки
У меня есть вкладка с viewpager2 и FragmentStateAdapter. У меня есть 3 вкладки, каждая с NestedScrollView, который оборачивает линейный макет:
Когда я переключаюсь между вкладками на вкладке, вид прокрутки не начинается сверху. В методе onViewCreated () каждого фрагмента для viewPager я добавил следующие строки, однако представление прокрутки по-прежнему не прокручивается вверх, оно начинается там, где оно было остановлено.
2 ответа
onViewCreated вызывается только при первом создании Fragment . ViewPager не меняет состояние Fragment . Вы можете подумать о том, что скрытый Fragments хранится видимым по сторонам видимого в настоящее время Fragment .
Я выполнил настройку обратного вызова при изменении TabLayout . TabLayout где слушатель для этого. Затем вы можете вызвать его в вашем FragmentPagerAdapter методе обратного вызова. В каждом Fragment вы должны реализовать метод, который возвращает обратный вызов. В FragmentPagerAdapter используйте getItem(int position) для сохранения обратного вызова из Fragment в Map . Метод обратного вызова в адаптере занимает позицию из TabLayout
Во-первых, в ваших фрагментах дайте им метод, который возвращает какой-то обратный вызов (я использовал Runnable ), который будет вызываться из адаптера.
Затем в своем FragmentPagerAdapter (я назвал мой SectionsPagerAdapter ) сохраните обратные вызовы на карте в методе getItem() , а затем добавьте пользовательский обратный вызов.
В вашей деятельности, содержащей TabLayout, вы захотите вызвать addOnTabSelectedListener() для TabLayout в методе onCreate() .
РЕДАКТИРОВАТЬ
Принцип тот же, но чтобы это работало с использованием ViewPager2 и FragmentStateAdapter , вам потребуются следующие изменения:
Fragment остается прежним.
Адаптер функционально аналогичен некоторым обновленным методам:
Активность меняется больше всего:
Обратите внимание, что единственное реальное изменение заключается в том, что ViewPager2 не требуется TabLayout для обработки изменения страницы. Вы все еще можете использовать TabLayout.addOnTabSelectedListener() , если хотите, но вам придется реализовать свой собственный TabLayout.OnTabSelecterListener , поскольку TabLayout.ViewPagerOnTabSelectedListener не работает с ViewPager2 .
Решение от @ star4z должно работать, но есть более простой вариант. Вместо этого вы можете использовать FragmentPagerAdapter и установить его поведение равным BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT .
Источник
Tutorialwing
Hello Readers! In this post, we are going to learn about how to use android nestedScrollView widget in any android application. We will also go through different attributes of nestedScrollView widget that can be used to customise it.
Output
Tutorialwing Android NestedScrollView Output
Tutorialwing Android NestedScrollView Output
Getting Started
NestedScrollView widget can be defined as below –
As the Name suggests, NestedScrollView is a widget that are used when we want to implement scrollable view inside another scrollable view.
Normally, it is difficult to implement scrollable view inside another scrollable view because system would be unable to decide which view to scroll. This is where NestedScrollView comes in.
Attributes of Android NestedScrollView Widget
Attributes of nestedScrollView is same as scrollView. It is a support v4 widget that runs on old version of android as well. It is added in api 22.
Example of Android NestedScrollView Widget
At first, we will create android application. Then, we will use nestedScrollView widget in this application.
1. Creating New Project
Follow steps below to create new project. Please ignore the steps if you have already created a new application.
Step | Description |
---|---|
1. | Open Android Studio. |
2. | Go to File => New => New Project. Write application name as NestedScrollView. Then, click next button. |
3. | Select minimum SDK you need. However, we have selected 17 as minimum SDK. Then, click next button |
4. | Then, select Empty Activity => click next => click finish. |
5. | If you have followed above process correctly, you will get a newly created project successfully. However, you can also visit post to create a new project to know steps in detail. |
Now, we will modify xml and java file to use nestedScrollView widget in the application.
2. Modify Values folder
Open res/values/strings.xml file. Then, add below code into it.
3. Download Drawable Resources Needed
You will need some images, stored in res/drawable folder, to be used in the application. These drawable images will be used by views inside nestedScrollView widget in the application.
4. Use NestedScrollView Widget in xml file
Open res/layout/activity_main.xml file. Then, add below code into it.
In activity_main.xml file, we have defined nestedScrollView inside scrollView. Using nestedScrollView, we have defined scrollable view inside another scrollable view. It is used same as scrollView i.e. It can contain only one direct child. Note that we have defined linearLayout inside nestedScrollView as a direct child. Then, we have defined view to be scrolled inside it. All the imageViews have been defined inside scrollView.
5. Access NestedScrollView Widget in java file
Open src/main/java/com.tutorialwing.nestedscrollview/MainActivity.java file. Then, add below code into it.
We have changed nothing in MainActivity. So, it is as it was after creating project.
Since AndroidManifest.xml file is very important in any android application, we are also going to see the content inside this file.
AndroidManifest.xml
Code inside src/main/AndroidManifest.xml file is as below –
When we run the program, we will get output as shown above.
That’s end of tutorial on Android NestedScrollView widget.
Источник
Constraintlayout внутри scrollview
Проблема в том что полос прокрутки нет. А вроде должны быть.
ScrollView вылезает за свои границы в ConstraintLayout
Вверху экрана находятся несколько TextView. К ним привязан ScrollView, в который динамически.
Кнопка с форматированием внутри ConstraintLayout
Всем привет! Хочу создать кнопку, и в надписи хочу сделать 2 строчки с разным форматированием, и у.
ConstraintLayout программно
Из справочника бд вытаскиваю инфу по блюдам и в цикле создаю view ArrayList Foods =.
В чем удобство ConstraintLayout?
Уже не первый раз пытаюсь понять удобства и преимущества ConstraintLayout , но увы получается.
Паблито, ну я тяну вниз а ничего не прокручивается. дело даж не в видимости скроллбаров.
вот так выглядит на 10 дюймах
Паблито, скриншот в заголовке вопроса сделан с эмулятора. на физическом девайсе всё так же.
скриншот с 10 дюймовым экраном скинул чтобы показать что там под листвью есть еще текст.
Добавлено через 17 минут
сделал у листвью android:layout_height=»match_parent». полоса прокрутки появилась, но не полностью прокручивает
ConstraintLayout. Изменение ID элементов
При изменении ID контролов в ConstraintLayout, Андроид-студия спрашивает: «Update usages as well?».
Ошибка после работы с ConstraintLayout
Всем привет. Стал использовать ConstraintLayout ну импортнул его автоматом. Потом вылезла ошибка.
Android Studio. ConstraintLayout адаптация интерфейса к разным экранам
Здравствуйте. Решил сделать простейшее приложение для Android с целью познакомиться с Android.
ScrollView
Добрый день! Работаю с обычным ScrollView. Получаю что-то типа: Подскажите пожалуйста, можно ли.
ScrollView
Привет) Работаю со ScrollView у меня есть например 5 изображений, грубо говоря каждое отвечает за.
Наложение на ScrollView
Добрый день. Вот такая проблема, у меня сверху ScrollView лежит еще один блок LinearLayout. .
Источник
Могу ли я прокручивать ScrollView программно в Android?
есть ли способ прокрутить ScrollView программно на определенную позицию?
Я создал динамический TableLayout который находится в ScrollView . Поэтому я хочу, чтобы это было конкретное действие (например, нажатие кнопки и т. д.) конкретная строка должна автоматически прокручиваться в верхнюю позицию.
16 ответов
ответ от Pragna не всегда работает, попробуйте следующее:
я хотел, чтобы scrollView прокручивался непосредственно после onCreateView () (не после, например, нажатия кнопки). Чтобы заставить его работать, мне нужно было использовать ViewTreeObserver:
но будьте осторожны, что это будет называться каждый раз, когда что-то получает layouted (e.g Если вы установили вид невидимый или аналогичный), поэтому не забудьте удалить этот прослушиватель, если он вам больше не нужен:
public void removeGlobalOnLayoutListener (ViewTreeObserver.OnGlobalLayoutListener victim) на SDK Lvl
public void removeOnGlobalLayoutListener (ViewTreeObserver.OnGlobalLayoutListener victim) в SDK Lvl >= 16
использовать что-то вроде этого:
здесь много хороших ответов, но я хочу добавить только одну вещь. Иногда случается, что вы хотите прокрутить ScrollView до определенного вида макета, а не полный прокрутки вверх или вниз.
простой пример: в регистрационной форме, если пользователь нажимает кнопку «Регистрация», когда текст редактирования формы не заполнен, вы хотите прокрутить до этого конкретного текста редактирования, чтобы сообщить пользователю, что он должен заполнить это поле.
В этом случае, вы можете сделайте что-нибудь вроде этого:
или, если вы хотите гладкую прокрутку вместо мгновенной прокрутки:
очевидно, вы можете использовать любой тип представления вместо редактирования текста. Обратите внимание, что getBottom() возвращает координаты представления на основе его родительского макета, поэтому все виды, используемые внутри ScrollView, должны иметь только родительский (например, линейный макет).
Если у вас есть несколько родителей внутри ребенка ScrollView, единственное решение, которое я нашел вызвать requestChildFocus на родительский вид:
но в этом случае вы не можете иметь гладкий свиток.
Я надеюсь, что этот ответ может помочь кому-то с такой же проблемой.
Источник