2

カスタム アダプターを使用してリストから入力する gridView で奇妙な問題が発生しています。

gridView の最初のページがいっぱいになるまで、すべてが正常に見えます。その後、後続の項目の一部が欠落しているか、同期されていません。

最初は 1 つの列で、2 つ目は 2 つの列で、2 つのスクリーン キャプチャを行いました。ご覧のとおり、最初のページは次の図のように両方で正しくレンダリングされます。

1 列: http://screencast.com/t/mSoEsDf1cY

2 列: http://screencast.com/t/i6zfPLYf

問題を示すためにコードを単純化しました。

public class Activity1 : Activity
{
    List<Item> _items = null;

    protected override void OnCreate (Bundle bundle)
    {
        base.OnCreate (bundle);

        // Set our view from the "main" layout resource
        SetContentView (Resource.Layout.Main);

        _items = new List<Item>();

        for ( int i =0; i < 30; i++)
        {
            Item newItem = new Item();
            newItem.Text = "Item " + i;
            newItem.Bitmap = Android.Graphics.BitmapFactory.DecodeResource( this.Resources, Resource.Drawable.Icon );

            _items.Add( newItem );
        }

        GridView grid = FindViewById<GridView> (Resource.Id.gridView1);
        grid.SetNumColumns(2);

        ItemGridViewAdapter adapter = new ItemGridViewAdapter( this, _items);
        grid.Adapter = adapter;
    }

}

public class Item
{
    public Android.Graphics.Bitmap Bitmap { get; set; }
    public string Text { get; set; }
}

public class ItemGridViewAdapter : BaseAdapter<Item>
{
    private List<Item> _items = null;
    private Context _context = null;

    public override int Count {
        get {
            return _items.Count;
        }
    }

    public override long GetItemId (int position)
    {
        return position;
    }

    public override Item this[int position] {
        get {
            return _items[position];
        }
    }

    public ItemGridViewAdapter (Context context, List<Item> items)
    {
        _items = items;
        _context = context;
    }

    public override View GetView (int position, View convertView, ViewGroup parent)
    {
        //based on http://developer.android.com/guide/topics/ui/layout/gridview.html

        RelativeLayout layout = null;

        if (convertView == null) {
            layout = new RelativeLayout( _context );

            RelativeLayout.LayoutParams rlp = new RelativeLayout.LayoutParams (RelativeLayout.LayoutParams.WrapContent, RelativeLayout.LayoutParams.WrapContent);

            ImageView image = new ImageView (_context);
            image.LayoutParameters = new Gallery.LayoutParams (150, 150);
            image.SetImageBitmap ( this[position].Bitmap );
            image.Id = 1;
            layout.AddView (image);

            RelativeLayout.LayoutParams title_lp = new RelativeLayout.LayoutParams (RelativeLayout.LayoutParams.WrapContent, RelativeLayout.LayoutParams.WrapContent);
            TextView title = new TextView (_context);
            title.Text = this[position].Text; 
            title.Id = 2;
            title.SetTextColor (Android.Graphics.Color.White);
            title_lp.AddRule (LayoutRules.RightOf, 1);
            title_lp.AddRule (LayoutRules.CenterVertical);
            layout.AddView (title, title_lp);

        } else {

            layout = (RelativeLayout)convertView;
        }

        return layout;
    }

}

どんなアイデアでも大歓迎です。

4

1 に答える 1

1

あなたのコードは、ここでは何も変更せずに、いくつかのランダムな古いアイテム ビューを再利用します。

    layout = (RelativeLayout)convertView;

getView() を変更して、リサイクルまたは作成されたばかりのビューに関係なく、位置の関数である新しい値を提供する必要があります。

http://developer.android.com/guide/topics/ui/layout/gridview.htmlの例を考えてみましょう。

それらは、「else」部分で行うのとほぼ同じことを行います。しかしその後、ビューに新しい値を提供します。彼らの場合は、新しい画像です。

} else {
    imageView = (ImageView) convertView;
}

// Analogous update is missing from your code.
// Set your view's image, text, etc. here:
imageView.setImageResource(mThumbIds[position]);

return imageView;
于 2012-10-15T21:59:23.263 に答える