在 Android Studio 中设计可滚动内容时要遵循的方法是啥?
Posted
技术标签:
【中文标题】在 Android Studio 中设计可滚动内容时要遵循的方法是啥?【英文标题】:What is the method to follow while designing scrollable content in Android Studio?在 Android Studio 中设计可滚动内容时要遵循的方法是什么? 【发布时间】:2020-05-18 00:01:09 【问题描述】:我正在使用约束布局设计我的应用程序,并将其放置在滚动视图下。我想放置更多卡片视图,但在 xml 文件的预览中没有地方这样做。当布局已满时,我在哪里拖放按钮、TextViews 等?我已经处理了文本的滚动视图,但这是另一回事。
我知道我可以只输入代码,但是当我无法看到我正在设计的具体内容时,我将很难这样做,因为内容超出了定义的屏幕尺寸。
(如果您希望我发布屏幕截图以更好地理解问题,请在 cmets 中告诉我)
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:background="@drawable/images"
android:fillViewport="true"
>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
android:background="@drawable/images"
tools:context=".MainActivity">
<LinearLayout
android:layout_
android:layout_
android:layout_alignParentBottom="true"
android:orientation="vertical"
app:layout_constraintBottom_toBottomOf="parent"
tools:layout_editor_absoluteX="10dp">
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_donation"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp"
android:src="@drawable/ic_donate" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="DONATE"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_receive"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp"
android:src="@drawable/ic_receive" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="RECEIVE"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_chat"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp"
android:src="@drawable/ic_chat" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="CHAT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_logout"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp"
android:src="@drawable/ic_logout" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="LOGOUT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</ScrollView>
【问题讨论】:
请发截图,我看不懂问题:/ i.stack.imgur.com/YPulN.jpg 在这里,我想添加更多的卡片视图,而不是可以向上滚动用户的 4 个卡片视图,但正如您所见,没有地方可以拖放它们。 (我希望整个活动都是可滚动的,而不仅仅是卡片视图,这就是 XML 文件的根布局是 Scroll View 的原因) 【参考方案1】:好吧,我猜你还没有尝试添加更多 CardView
s(或任何其他 View
s)...我已经复制了你的代码,增加了 CardViews
的数量,它就像魔术...这对我有用:
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:fillViewport="true">
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context=".MainActivity">
<LinearLayout
android:layout_
android:layout_
android:layout_alignParentBottom="true"
android:orientation="vertical"
app:layout_constraintBottom_toBottomOf="parent"
tools:layout_editor_absoluteX="10dp">
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_donation"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="DONATE"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_receive"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="RECEIVE"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_chat"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="CHAT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_logout"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="LOGOUT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_chat_other"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="CHAT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_other"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="LOGOUT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
<LinearLayout
android:layout_
android:layout_
android:clipToPadding="false"
android:gravity="center"
android:orientation="horizontal">
<androidx.cardview.widget.CardView
android:id="@+id/test_chat_other_"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="CHAT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/test_other_"
android:layout_
android:layout_
android:layout_margin="10dp"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
android:padding="0dp">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center"
android:orientation="vertical">
<LinearLayout
android:layout_
android:layout_
android:background="#660000"
android:gravity="center">
<ImageView
android:layout_
android:layout_
android:padding="10dp" />
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="LOGOUT"
android:textColor="#FFEb3b"
android:textSize="24sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</ScrollView>
这和你做的一样,只是没有图像,因为我没有它们的 src,并且还有四张卡片,它们从屏幕上消失并强制启用 ScrollView
s 滚动。 .. 如果您尝试在特定空间执行此操作,您只需将特定高度设置为ScrollView
,而不是 match_parent。无论如何,ScrollView
只有在它有要滚动的内容时才会滚动(当然你不必只使用卡片......你可以将任何东西添加到 ScrollView
中,当某些东西超出其边界时,它的滚动是激活)
希望对你有帮助!
【讨论】:
【参考方案2】:你可以试试这个android.support.v4.widget.NestedScrollView
<android.support.v4.widget.NestedScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
android:layout_marginStart="8dp"
android:layout_marginTop="60dp"
android:layout_marginEnd="8dp"
android:layout_marginBottom="60dp"
android:animateLayoutChanges="true"
android:orientation="vertical"
android:padding="8dp"
>
</android.support.v4.widget.NestedScrollView>
【讨论】:
【参考方案3】:你可以用NestedScrollView
代替scrollview
,像这样:
<androidx.core.widget.NestedScrollView
android:layout_
android:layout_
android:fillViewport="true">
<android.support.constraint.ConstraintLayout
android:layout_
android:layout_>
</android.support.constraint.ConstraintLayout>
</androidx.core.widget.NestedScrollView>
【讨论】:
以上是关于在 Android Studio 中设计可滚动内容时要遵循的方法是啥?的主要内容,如果未能解决你的问题,请参考以下文章
无法在 android studio 中设置 firebase
在 Android Studio 中设置 Spotify API