无法在gridview(C#),System.Collections.Generic.List中查看sqlite表数据

时间:2017-09-13 09:59:39

标签: c# xamarin xamarin.android

我是C#的初学者,我有一个xamarin.android项目,我想在gridview中查看我的表的数据。

将此代码用于我的活动:

public class MenuFoodActivity : Activity
{
    string dpPath = Path.Combine(System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal), "HotelDb.db3");

    GridView gv;
    ArrayAdapter adapter;
    JavaList<String> tvShows = new JavaList<string>();


    protected override void OnCreate(Bundle savedInstanceState)
    {
        base.OnCreate(savedInstanceState);
        SetContentView(Resource.Layout.MenuFood);
        gv = FindViewById<GridView>(Resource.Id.gridViewMenu);
        adapter = new ArrayAdapter(this, Android.Resource.Layout.SimpleListItem1, tvShows);            
        Retrieve();

    }
   private void Retrieve()
    {
        var db = new SQLiteConnection(dpPath);
        var data = db.Table<FoodTable>();
        var data1 = (from values in data
                     select new FoodTable
                     {
                         Shenase = values.Shenase,
                         Types = values.Types,
                         Names = values.Names,
                         Costs = values.Costs

                     }).ToList<FoodTable>();

        tvShows.Add(data1);
        if (tvShows.Size() > 0)
        {
            gv.Adapter = adapter;
        }
        else
        {

            Toast.MakeText(this, "not found.", ToastLength.Short).Show();
        }
    }
}

这个是针对axml文件的

 <GridView
    android:minWidth="25px"
    android:minHeight="25px"
    android:layout_width="wrap_content"
    android:layout_height="200dip"
    android:id="@+id/gridViewMenu"
    android:background="#aaa"
    android:layout_marginTop="10dip" />

问题是,当我调试项目时,字段'data1'有数据,if语句的结果为true,但行

gv.Adapter = adapter;

不起作用所以我收到这一行而不是获取我的数据。

System.Collections.Generic.List[MainAppHotelXamarin.FoodTable]

1 个答案:

答案 0 :(得分:0)

  

System.Collections.Generic.List [MainAppHotelXamarin.FoodTable]

您将<% if (prevDisabledClass) { %> <a>prev</a> <% } else { %> <a href="?page=<%= page - 1 %>">prev</a> <% } %> 的类型定义为tvShows,因此当您使用JavaList<string>方法时,tvShows.Add(data1)的类型应为data1类型。但是您的string类型为data1,它们不兼容。

修改您的代码:

List<FoodTable>

当您将//Change the type form string to FoodTable List<FoodTable> tvShows = new List<FoodTable>(); 数据1添加到List tvShows时,您可以使用List.AddRange方法,这样使用:

List

如果您想在tvShows.AddRange(data1); 中显示FoodTable的数据,可以为您的班级实施custom adapter,此处为example

编辑:

HereGridView适配器的示例,它与ListView适配器类似,您可以使用它来实现您的功能。

编辑2:

您可以创建自定义布局项以显示要显示的任何视图类型。

例如,创建一个布局以显示四个GridView

item.axml

TextView

创建<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="40dp" android:orientation="horizontal" android:padding="8dp" > <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:id="@+id/Shenase" android:layout_weight="1"/> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:id="@+id/Types" android:layout_weight="1" /> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:id="@+id/Names" android:layout_weight="1" /> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:id="@+id/Costs" android:layout_weight="1" /> </LinearLayout>

GridViewAdapter

在您的代码中使用它:

public class GridViewAdapter : BaseAdapter<FoodTable>
{
    private MainActivity mContext;
    private List<FoodTable> tvShows;

    public GridViewAdapter(MainActivity context, List<FoodTable> tvShows)
    {
        this.mContext = context;
        this.tvShows = tvShows;
    }

    public override FoodTable this[int position]
    {
        get { return tvShows[position]; }
    }

    public override int Count => tvShows.Count;

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

    public override View GetView(int position, View convertView, ViewGroup parent)
    {
        FoodTable item = tvShows[position];

        View view = convertView; // re-use an existing view, if one is available
        if (view == null) 
            view = mContext.LayoutInflater.Inflate(Resource.Layout.item, null);

        view.FindViewById<TextView>(Resource.Id.Shenase).Text = item.Types;
        view.FindViewById<TextView>(Resource.Id.Types).Text = item.Types;
        view.FindViewById<TextView>(Resource.Id.Names).Text = item.Names;
        view.FindViewById<TextView>(Resource.Id.Costs).Text = item.Costs;

        return view;
    }
}  

效果如this