Android,XAMARIN:将单个LinearLayout标头添加到RecyclerView的顶部(可点击)

问题描述 投票:0回答:1

我一直在寻找,无法找到任何东西。我设法把我的recyclerview恰到好处,唯一缺少的就是标题。在我之前的listview中,我只设计了第一个元素作为我的标题。这是一个线性布局,其中包含一些文本视图和一些图像作为可点击按钮。至于RecyclerView,我还没能做到这一点。这里的任何人都可以帮我吗?

这些是我的Recycler视图的3个(工作)类:

class RecyclerViewAdapter : RecyclerView.Adapter
{
    private List<DataForProfile> lstData = new List<DataForProfile>();
    private Context ctx;

    public RecyclerViewAdapter(List<DataForProfile> lstData, Context ctx)
    {
        this.lstData = lstData;
        this.ctx = ctx;
    } 


    public override void OnBindViewHolder(RecyclerView.ViewHolder holder, int position)
    {

        RecyclerViewHolder viewHolder = holder as RecyclerViewHolder;

        viewHolder.txtTitle.Text = (lstData[position].description);
        viewHolder.imageView.SetImageBitmap((lstData[position].img));


    }

    public override RecyclerView.ViewHolder OnCreateViewHolder(ViewGroup parent, int viewType)
    {
        LayoutInflater inflater = LayoutInflater.From(parent.Context);
        View itemView = inflater.Inflate(Resource.Layout.RecView_Profile, parent, false);
        return new RecyclerViewHolder(itemView, ctx);
    }

    //Get Number Of Items
    public override int ItemCount
    {
        get
        {
            return lstData.Count;
        }
    }

}




public class DataForProfile
{
    public int imageId { get; set; }
    public Bitmap img { get; set; }
    public string description { get; set; }

}

class RecyclerViewHolder : RecyclerView.ViewHolder
{
    public ImageView imageView { get; set; }
    public TextView txtTitle { get; set; }
    public TextView txtDescription { get; set; }
    public TextView txtDate { get; set; }
    public TextView txtLikeCountBlue { get; set; }
    public TextView txtLikeCountGreen { get; set; }
    public TextView txtComments { get; set; }
    private Typeface font;
    private Context ctx;


    public RecyclerViewHolder(View itemView, Context ctx) : base(itemView)
    {
        this.ctx = ctx;
        txtTitle = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_TaskName);
        imageView = itemView.FindViewById<ImageView>(Resource.Id.imageView1);
        txtDescription = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_Description);
        txtDate = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_Date);
        txtLikeCountBlue = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_blue);
        txtLikeCountGreen = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_green);
        txtComments = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_comments);

        font = Typeface.CreateFromAsset(ctx.Assets, "CourierNew.ttf");

        txtTitle.SetTypeface(font, TypefaceStyle.Bold);
        txtDescription.SetTypeface(font, TypefaceStyle.Normal);
        txtDate.SetTypeface(font, TypefaceStyle.Normal);
        txtLikeCountBlue.SetTypeface(font, TypefaceStyle.Normal);
        txtLikeCountGreen.SetTypeface(font, TypefaceStyle.Normal);
        txtComments.SetTypeface(font, TypefaceStyle.Normal);

    }
}

任何帮助都会很棒!

android xamarin android-recyclerview android-linearlayout recycler-adapter
1个回答
1
投票

好的,在做了一些覆盖之后 - 这是为了做到这一点的工作代码:

class RecyclerViewAdapter : RecyclerView.Adapter
{
    private List<DataForProfile> lstData = new List<DataForProfile>();
    private Context ctx;
    private static int TYPE_HEADER = 0;
    private static int TYPE_ITEM = 2;

    public RecyclerViewAdapter(List<DataForProfile> lstData, Context ctx)
    {
        this.lstData = lstData;
        this.ctx = ctx;
    } 

    public override void OnBindViewHolder(RecyclerView.ViewHolder holder, int position)
    {

        //Check oif Header orData
        if (holder.GetType() == typeof(HeaderViewHolder)) 
        {
            HeaderViewHolder headerHolder = holder as HeaderViewHolder;
            headerHolder.headerTitle.Text = "hall0";

            headerHolder.headerTitle.Click += delegate
            {
                Toast.MakeText(ctx, "Header!", ToastLength.Long).Show();
            };

            headerHolder.headerImageView.Click += delegate
            {
                Toast.MakeText(ctx, "image!", ToastLength.Long).Show();
            };
        }             
        else if (holder.GetType() == typeof(RecyclerViewHolder)) 
        {
             RecyclerViewHolder viewHolder = holder as RecyclerViewHolder;
             viewHolder.txtTitle.Text = (lstData[position-1].description); // - 1 because of the header
             viewHolder.imageView.SetImageBitmap((lstData[position-1].img));

        }

    }

    // What layout to be inflated?
    public override RecyclerView.ViewHolder OnCreateViewHolder(ViewGroup parent, int viewType)
    {

        if (viewType == TYPE_ITEM)
        {
            // Data
             LayoutInflater inflater = LayoutInflater.From(parent.Context);
             View itemView = inflater.Inflate(Resource.Layout.RecView_Profile, parent, false);
             return new RecyclerViewHolder(itemView, ctx);
        }
        else if (viewType == TYPE_HEADER)
        {
            //Inflating header view
            LayoutInflater inflater = LayoutInflater.From(parent.Context);
            View itemView = inflater.Inflate(Resource.Layout.testheader, parent, false);
            return new HeaderViewHolder(itemView, ctx);
        }
        else return null;
    }

    // Get Number Of Items
    public override int ItemCount
    {
        get
        {
            return lstData.Count + 1; // +1 due to the header
        }
    }

    // Custom Override to decided whether its the header or the data
    public override int GetItemViewType(int position)
    {
        if (position == 0)
        {
            return TYPE_HEADER;
        }
        else if (position == lstData.Count() + 1) //+1 wegen des Headers
        {
            return TYPE_ITEM;;
        }
        return TYPE_ITEM;
    }

}

// class for header
public class HeaderViewHolder : RecyclerView.ViewHolder
{
    public TextView headerTitle;
    public ImageView headerImageView;

    public HeaderViewHolder(View itemView, Context ctx) : base(itemView)
    {
        headerTitle = itemView.FindViewById<TextView>(Resource.Id.testheadertitle);
        headerImageView = itemView.FindViewById<ImageView>(Resource.Id.testheaderbutton);
    }
}

// xml
class RecyclerViewHolder : RecyclerView.ViewHolder
{
    public ImageView imageView { get; set; }
    public TextView txtTitle { get; set; }
    public TextView txtDescription { get; set; }
    public TextView txtDate { get; set; }
    public TextView txtLikeCountBlue { get; set; }
    public TextView txtLikeCountGreen { get; set; }
    public TextView txtComments { get; set; }
    private Typeface font;
    private Context ctx;


    public RecyclerViewHolder(View itemView, Context ctx) : base(itemView)
    {
        this.ctx = ctx;
        txtTitle = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_TaskName);
        imageView = itemView.FindViewById<ImageView>(Resource.Id.imageView1);
        txtDescription = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_Description);
        txtDate = itemView.FindViewById<TextView>(Resource.Id.RecView_Profile_Date);
        txtLikeCountBlue = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_blue);
        txtLikeCountGreen = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_green);
        txtComments = itemView.FindViewById<TextView>(Resource.Id.txt_recview_profile_comments);

        font = Typeface.CreateFromAsset(ctx.Assets, "CourierNew.ttf");

        txtTitle.SetTypeface(font, TypefaceStyle.Bold);
        txtDescription.SetTypeface(font, TypefaceStyle.Normal);
        txtDate.SetTypeface(font, TypefaceStyle.Normal);
        txtLikeCountBlue.SetTypeface(font, TypefaceStyle.Normal);
        txtLikeCountGreen.SetTypeface(font, TypefaceStyle.Normal);
        txtComments.SetTypeface(font, TypefaceStyle.Normal);

    }
}


public class DataForProfile
{
    public int imageId { get; set; }
    public Bitmap img { get; set; }
    public string description { get; set; }

}

}

© www.soinside.com 2019 - 2024. All rights reserved.