1

2 つではなく 1 つの項目のみを表示する ListView があります。それは私のMainActivityです:

public class MainActivity extends Activity {
ImageView Add;
ImageView Shadow;
ProgressBar PB;

ListView listView;
String[] valuesUp = { "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
        "Sed non justo eros. Praesent a nisl dui" };
String[] valuesDown = { "Quisque ut ante eu arcu sagittis porta eu a dolor...",
        "In orci augue facilisis eget fermentum consequat ac..." };
int[] imgValues = {R.drawable.mobileapp_16, R.drawable.mobileapp_19};

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

    ArrayAdapter<String> adapter = new MyAdapter(this, valuesUp, valuesDown, imgValues);
    listView = (ListView) findViewById(R.id.listView1);
    listView.setAdapter(adapter);
}

それは私のアダプターです:

public class MyAdapter extends ArrayAdapter<String> {
private final Context context;
private final String[] valuesUp;
private final String[] valuesDown;
private final int[] ImageValue;
private TextView textViewUp;
private TextView textViewDown;
private ImageView image;

public MyAdapter(Context context, String[] valuesUP, String[] valuesDown, int[] imageValue) {
    super(context, R.layout.rowlayout, valuesUP);
    this.context = context;
    this.valuesUp = valuesUP;
    this.valuesDown = valuesDown;
    this.ImageValue = imageValue;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    LayoutInflater inflater = (LayoutInflater) context
            .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    View rowView;

    rowView = inflater.inflate(R.layout.rowlayout, parent, false);
    textViewUp = (TextView) rowView.findViewById(R.id.row_text_view_up);
    textViewDown = (TextView) rowView.findViewById(R.id.row_text_view_down);
    image = (ImageView) rowView.findViewById(R.id.image);
    textViewUp.setText(valuesUp[position]);
    textViewDown.setText(valuesDown[position]);
    image.setImageDrawable(context.getResources().getDrawable(ImageValue[position]));

    return rowView;
}}

デバッグすると、getView が何度も呼び出され (約 12 回)、常に「位置」が 0 になっていることがわかります。ありがとう!

私は今私の問題を見つけました!それは奇妙だ。リストの高さがおかしい。「wrap_content または match_parent を実行すると、1 つのアイテムが返されますが、たとえば 400dp を入力すると問題ありません。なぜですか?! それが私の XML です:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/progress"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000000"
android:orientation="vertical" >

<ImageView
    android:id="@+id/imageView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_alignParentRight="true"
    android:layout_alignParentTop="true"
    android:background="@drawable/topbar_bg" />

<ImageView
    android:id="@+id/imageView2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/imageView1"
    android:layout_alignParentLeft="true"
    android:layout_alignParentTop="true"
    android:src="@drawable/topbar_leftcircle" />

<ImageView
    android:id="@+id/imageView3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/imageView1"
    android:layout_alignParentTop="true"
    android:layout_marginLeft="5dp"
    android:layout_toRightOf="@+id/imageView2"
    android:src="@drawable/topbar_logo" />

<ImageView
    android:id="@+id/imageView4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/imageView1"
    android:layout_alignParentRight="true"
    android:layout_alignParentTop="true"
    android:layout_marginRight="5dp"
    android:scaleType="fitStart"
    android:src="@drawable/topbar_menu" />

<ImageView
    android:id="@+id/imageView5"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/imageView1"
    android:layout_alignParentTop="true"
    android:layout_marginRight="5dp"
    android:layout_toLeftOf="@+id/imageView4"
    android:src="@drawable/topbar_key" />

<ScrollView
    android:id="@+id/scrollView2"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentBottom="true"
    android:layout_below="@+id/imageView1"
    android:layout_centerHorizontal="true" >

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent" >

        <ImageButton
            android:id="@+id/imageButton1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/imageView1"
            android:layout_centerHorizontal="true"
            android:background="#00000000"
            android:src="@drawable/mobileapp_14" />

        <ImageView
            android:id="@+id/imageView6"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@+id/imageButton1"
            android:layout_centerHorizontal="true"
            android:scaleType="fitXY"
            android:src="@drawable/transparent_bg" />

        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_alignParentRight="true"
            android:layout_alignTop="@+id/imageView6"
            android:layout_marginBottom="5dp"
            android:layout_marginLeft="10dp"
            android:layout_marginRight="10dp"
            android:layout_marginTop="10dp"
            android:maxLines="2"
            android:text="Sed at vestibulum elit. Nunc quam erat, gravida ac consequat"
            android:textColor="@color/RedText"
            android:textSize="15dp" />

        <TextView
            android:id="@+id/textView2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@+id/imageButton1"
            android:layout_alignParentLeft="true"
            android:layout_alignParentRight="true"
            android:layout_below="@+id/textView1"
            android:layout_marginLeft="10dp"
            android:layout_marginRight="10dp"
            android:maxLines="2"
            android:text="Nullam sed erat erat, ut faucibus nunc. Etiam et mi di ante lacinia suscipit. Mauris gravida turpis eget lectus ullam..."
            android:textColor="@color/WhiteText"
            android:textSize="12dp" />

        <ImageView
            android:id="@+id/imageView7"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/imageButton1"
            android:layout_centerHorizontal="true"
            android:background="#00000000"
            android:scaleType="centerCrop"
            android:src="@drawable/mobileapp_15" />

        <ListView
            android:id="@+id/listView1"
            android:layout_width="match_parent"
            android:layout_height="600dp"
            android:layout_below="@id/imageView7" >

        </ListView>

    </RelativeLayout>
</ScrollView>
4

6 に答える 6

2

問題が見つかりました。

問題は XML にあります。

xml からScrollViewを削除します。問題は解決します。

于 2012-11-21T13:39:48.750 に答える
2

@roiberg私のエミュレーターであなたのコードは正常に動作しています。XML コードを確認してください

于 2012-11-21T13:22:46.180 に答える
1

これは非常に高価であるため、listViewの高さをwrap_contentとして保持しないでください。fill_parent / match_parentとして指定し、試してみてください。

wrap_contentを指定すると、システムはlistViewの高さを計算するために多くの操作を実行します。これにより、位置0のアイテムが複数回呼び出されます。

scrollView内にListViewを指定しないでください。これは決して機能しません!

于 2012-11-21T13:13:56.120 に答える
0

このようにアクティビティを変更します

public class MainActivity extends Activity { ImageView Add; ImageView シャドウ; プログレスバー PB;

ListView listView;
String[] valuesUp = { "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
"Sed non justo eros. Praesent a nisl dui" };
String[] valuesDown = { "Quisque ut ante eu arcu sagittis porta eu a dolor...",
"In orci augue facilisis eget fermentum consequat ac..." };
int[] imgValues = {R.drawable.mobileapp_16, R.drawable.mobileapp_19};

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


    listView = (ListView) findViewById(R.id.listView1);
    listView.setAdapter(new MyAdapter(this,valuesUp,valuesDown,imgValues));
}

このようにアダプターを変更します

public class MyAdapter extends BaseAdapter {
private final Context context;
private final String[] valuesUp;
private final String[] valuesDown;
private final int[] ImageValue;
private TextView textViewUp;
private TextView textViewDown;
private ImageView image;

public MyAdapter(Context context, String[] valuesUP, String[] valuesDown, int[] imageValue) {
    super(context, R.layout.rowlayout, valuesUP);
    this.context = context;
    this.valuesUp = valuesUP;
    this.valuesDown = valuesDown;
    this.ImageValue = imageValue;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    LayoutInflater inflater = (LayoutInflater) context
            .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    View rowView;

    rowView = inflater.inflate(R.layout.rowlayout, parent, false);
    textViewUp = (TextView) rowView.findViewById(R.id.row_text_view_up);
    textViewDown = (TextView) rowView.findViewById(R.id.row_text_view_down);
    image = (ImageView) rowView.findViewById(R.id.image);
    textViewUp.setText(valuesUp[position]);
    textViewDown.setText(valuesDown[position]);
    image.setImageDrawable(context.getResources().getDrawable(ImageValue[position]));

    return rowView;
}

@Override
public int getCount() {
    // TODO Auto-generated method stub
    return valuesUp.length;
}

@Override
public Object getItem(int arg0) {
    // TODO Auto-generated method stub
    return valuesUp[arg0];
}

@Override
public long getItemId(int position) {
    // TODO Auto-generated method stub
    return position;
}}
于 2012-11-21T12:59:13.760 に答える
0

回避策を見つけました。最初の画像をスタンドアロン レイアウトに配置し、このレイアウトをリストの最初のセルにしました。そのため、画像とリスト自体が 1 つの大きなスクロール可能なリストになっています。誰かがこれに大きな問題を見つけたら、私はそれについて聞きたいです.

于 2012-11-21T14:26:58.780 に答える