什么';在Android中创建二维滚动视图的正确方法是什么?
我需要创建一个支持垂直滚动和水平滚动的二维视图,非常类似于谷歌的图库设计或Netflix的设计。我看过一些关于使用嵌套滚动视图的最佳实践和保留意见的帖子,但大多数都是非常老的帖子 鉴于Android的当前版本,实现这种行为的正确方法是什么 参考资料: 这是我目前使用的代码:什么';在Android中创建二维滚动视图的正确方法是什么?,android,layout,scrollview,Android,Layout,Scrollview,我需要创建一个支持垂直滚动和水平滚动的二维视图,非常类似于谷歌的图库设计或Netflix的设计。我看过一些关于使用嵌套滚动视图的最佳实践和保留意见的帖子,但大多数都是非常老的帖子 鉴于Android的当前版本,实现这种行为的正确方法是什么 参考资料: 这是我目前使用的代码: <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.andr
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
tools:context="com.example.culami.RecipeDashboardActivity"
android:orientation="vertical"
android:background="#2E2E2E"
>
<!-- Parent Linear Layout -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center|left"
android:orientation="vertical">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="@string/recipeDashLabel1"
android:gravity="left"
android:textSize="24sp"
android:padding="5dp"
android:textColor="#ffffff" />
<!-- Recently viewed Recipes -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:orientation="horizontal"
android:baselineAligned="false" >
<ImageButton
android:id="@+id/recipe_1_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/recipe_1"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_2_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_2"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_3_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_4"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
</LinearLayout>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="@string/recipeDashLabel2"
android:gravity="left"
android:textSize="24sp"
android:padding="5dp"
android:textColor="#ffffff" />
<!-- Frequently viewed Recipes -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:orientation="horizontal"
android:baselineAligned="false" >
<ImageButton
android:id="@+id/recipe_4_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/recipe_1"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_5_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_2"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_6_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_4"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
</LinearLayout>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="@string/recipeDashLabel3"
android:gravity="left"
android:textSize="24sp"
android:padding="5dp"
android:textColor="#ffffff" />
<!-- Frequently viewed Recipes -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:orientation="horizontal"
android:baselineAligned="false" >
<ImageButton
android:id="@+id/recipe_7_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/recipe_1"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_8_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_2"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_9_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_4"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
</LinearLayout>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="@string/recipeDashLabel4"
android:gravity="left"
android:textSize="24sp"
android:padding="5dp"
android:textColor="#ffffff" />
<!-- Frequently viewed Recipes -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:orientation="horizontal"
android:baselineAligned="false" >
<ImageButton
android:id="@+id/recipe_10_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/recipe_1"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_11_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_2"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_12_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_4"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
</LinearLayout>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="@string/recipeDashLabel5"
android:gravity="left"
android:textSize="24sp"
android:padding="5dp"
android:textColor="#ffffff" />
<!-- Frequently viewed Recipes -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:orientation="horizontal"
android:baselineAligned="false" >
<ImageButton
android:id="@+id/recipe_13_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/recipe_1"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_14_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_2"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
<ImageButton
android:id="@+id/recipe_15_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:src="@drawable/recipe_4"
android:contentDescription="@string/descMSG"
android:background="@drawable/arrow_imagebutton_selector"
android:layout_gravity="center"
android:onClick="" />
</LinearLayout>
</LinearLayout> <!-- End Parent Linear Layout -->
</ScrollView>
我需要能够将每行LinearLayout中的三个虚拟图像替换为适用于多个图像的水平滚动视图。
我怎样才能做到这一点?卢卡斯·罗查结帐。您可以选择在2个维度中滚动,或将其固定为1个维度(水平/垂直)
如果出现否决票,请说明问题被否决的原因,以便我进行必要的更正或将其记录下来。简单的否决票对任何人都没有帮助!谢谢您是否可以编写一些示例代码来演示如何使用自定义布局?这真的很有帮助!我编辑我的答案以包含我们正在使用的内容的简化版本
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<org.lucasr.twowayview.TwoWayView
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<!-- some more horizontal TwoWayView here -->
</LinearLayout>
</ScrollView>