如何在Android中创建类似于视图的架子?

时间:2012-04-15 10:29:34

标签: android listview horizontal-scrolling vertical-scrolling

如何在android中创建一个类似于视图的架子,可以在任何行显示几本书?此外,它应该具有水平和垂直功能,如月亮+阅读器应用程序。

我可以写一个水平移动的架子视图,但它不能完全发挥作用。我使用xml文件来查看包含图像,文本和按钮的项目。我写了一个扩展AdapterView的类来创建一个我称为ListView的自定义"shelf view"。不幸的是,我的程序显示了一行,我不能在几行中使用它。

enter image description here

1 个答案:

答案 0 :(得分:20)

上次更新:现在,我可以比以前的解决方案更好地检测创建货架视图的新方法。我在CodeProject

中对此进行了描述

顺便说一句,在这个应用程序中,我使用了两个类:

  • Horizo​​ntalListView扩展AdapterView的类。它是从GitHub

  • 下载的
  • Quaere库的使用与.Net中的Linq2Object几乎相同。您可以下载here


2012年4月22日:

有一些实现货架视图的方法,它有两个功能(水平和垂直滚动)。我尝试编写一个可以动态运行的程序。此示例应用程序具有XML文件和 showShelfView java 类。

所以你可以看到我的App:

主XML文件:首先,在 main.XML中添加以下代码

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:id="@+id/sclView">
    <TableLayout
            android:id="@+id/tblLayout"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent" 
           android:padding="0dp">
    </TableLayout>
</ScrollView>

showShelfView类: Inner TableLayout添加几个Horizo​​ntalScroll等于行数。在内部任何TableRow添加图像。

不要忘记为Row的背景设置一个架子图像:

enter image description here

public class showShelfView extends Activity {

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);


        int numRow = 4;
        int numCol = 8;

        TableLayout tblLayout = (TableLayout) findViewById(R.id.tblLayout);

        for(int i = 0; i < numRow; i++) {
            HorizontalScrollView HSV = new HorizontalScrollView(this);
            HSV.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));

            TableRow tblRow = new TableRow(this);
            tblRow.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT));
            tblRow.setBackgroundResource(R.drawable.bookshelf);

            for(int j = 0; j < numCol; j++) {
            ImageView imageView = new ImageView(this);
                imageView.setImageResource(R.drawable.book1);

                TextView textView = new TextView(this);
                textView.setText("Java Tester");
                textView.setLayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));

                tblRow.addView(imageView,j);
            }

            HSV.addView(tblRow);
            tblLayout.addView(HSV, i);
        }
    }

}