4

のコンテキストでAndroidレイアウトに頭を悩ませようとしていますListViewが、リストビューで単純なものをレンダリングしたい場合は、かなり原始的なようです(ただし、Doing ItWrong™を使用している可能性は十分にあります)。名前とカウント、次のようなもの:

WP8 / WPF / Silverlightでこの種のXAMLを使用します:

<Grid>
    <Grid.ColumnDefinitions>
        <ColumnDefinition Height="*" />
        <ColumnDefinition Height="Auto" />
    </Grid.ColumnDefinitions>

    <TextBlock Grid.Column="0" x:Name="Thing" />
    <TextBlock Grid.Column="1" x:Name="Count" />
</Grid>

ただし、Androidレイアウトではそれが不可能なようです。使用してみRelativeLayoutましたが、どちらか一方が常にフルサイズで、もう一方が食べられてしまうようです。

4

3 に答える 3

4

このようなものが欲しいですか?

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:text="Thing" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:text="Count" />

</RelativeLayout>

LinearLayoutまたは、を使用して設定することもできますweights

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <TextView
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="4"
        android:text="Thing" />

    <TextView
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Count" />

</LinearLayout>

または、を使用することもできます。developer.android.comにすばらしい例GridViewがあります。

于 2013-01-29T02:07:50.330 に答える
1

これが問題です。グリッド内のレコードごとに1つの文字列を除くものには、特別なものが必要です。これは決して完璧なコードではありませんが、役に立ちます。

基本レイアウトから始めましょう。

これがmainlist.xmlと呼ばれるものにあるとしましょう

<RelativeLayout 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" >


    <ListView
        android:id="@+id/itemList"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        />
</RelativeLayout>

つまり、ここにListViewを持つRelativeがあります。かなり基本的ですね。

あなたの活動では、このようなコードが必要になります。

@Override
public void onCreate(Bundle savedInstanceState) {
     super.onCreate(savedInstanceState);   
     setContentView(R.layout.mainlist);
     GetAndAssociateData();
}

public void GetAndAssociateData() {
      ListView list = (ListView)findViewById(R.id.itemList);
      final ArrayList<CountedItem> items;
      list.setAdapter(new CountedItemAdapter(getApplicationContext(), R.id.countedItemRow, items, this));   
 }

その単一の文字列アイテム以外のものには、アダプターだけでなく、各アイテムのレイアウトも必要です。

この場合、CountedItemAdapterはアダプターです(ビューにデータを入力する方法を示します)。

countedItemRowは、各アイテムのレイアウトです。

/src/CountedItemAdapter.java

public CountedItemAdapter(Context context,int textViewResourceId, ArrayList<CountedItem> objects,CountedItemActivity parentActivity) {
        super(context,  textViewResourceId, objects);
        this.context = context;
        this.items = objects;
        this.parentActivity = parentActivity;
        // TODO Auto-generated constructor stub
    }

public View getView(int position, View convertView, ViewGroup parent) {
    View view = convertView;
    if (view == null) {
        LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        view = inflater.inflate(R.layout.countedItemRow, null);
    }
    if (items != null){
        CountedItem item = items.get(position);
        if (item != null) {
            TextView thing= (TextView) view.findViewById(R.id.thing);
            if (thing!= null)
            {
                thing.setText(item.GetThingText());
            }
            TextView thingCount = (TextView) view.findViewById(R.id.thingCount);
            if (thingCount != null)
            {
                thingCount .setText(item.GetThingCount());
            }

        }
    }

    return view;
}

/res/layout/countedItemRow.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/countedItemRow"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >
<TextView
    android:id="@+id/thing"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_x="0dp"
    android:layout_y="0dp"
     />

<TextView
    android:id="@+id/thingCount"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_x="0dp"
    android:layout_y="150dp"
    />
</RelativeLayout>
于 2013-01-29T02:26:16.820 に答える
1

パーティーに遅れた。私はGridViewたった2列の大ファンではありません。各リストアイテムのレイアウトに重み付きビューを含むListViewをお勧めします。TableLayoutも適合する場合がありますが、私の例では何らかの理由でスクロールできません。第一画面のボタンをクリックして、ListViewの例を表示します。

私はあなたの例に合うように私が置いていたいくつかのテストコードをすぐに変更しました-ここを見てください

于 2013-01-29T06:57:29.047 に答える