Recyclerview 显示多种布局 demo

效果图

 

第一种布局文件

item_title

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">

    <data>

        <variable
            name="handler"
            type="com.example.startkotlin.EventHandler" />
    </data>

    <Button
        android:id="@+id/userbtn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="@{handler::onClickFriend}"
        android:text="xnxnxnx" />

</layout>

第二种布局

item_user_layout

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">

    <data>

        <variable
            name="useritem"
            type="com.example.startkotlin.User" />

        <variable
            name="handler"
            type="com.example.startkotlin.EventHandler" />

    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="@{() -> handler.onItemClick(useritem)}"
        android:orientation="horizontal"
        android:padding="5dp">

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="@{useritem.getName}" />

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text='@{"" +useritem.getAge}' />
    </LinearLayout>
</layout>

Java bean

User

public class User {
    private String name = "";
    private int age = 0;

    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

事件处理器

EventHandler 

public class EventHandler {
    private Context mContext;

    public EventHandler(Context context) {
        mContext = context;
    }

    public void onClickFriend(View view) {
        Toast.makeText(mContext, "onClickFriend", Toast.LENGTH_LONG).show();
    }

    public void onItemClick(User user) {
        Toast.makeText(mContext, "Click " + user.getName() + user.getAge(), Toast.LENGTH_SHORT).show();
    }
}

主界面布局

activity_main

<layout xmlns:android="http://schemas.android.com/apk/res/android">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/listAll"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

        </androidx.recyclerview.widget.RecyclerView>
    </LinearLayout>
</layout>

适配器

UserAdapter 

public class UserAdapter extends RecyclerView.Adapter<UserAdapter.MyViewHolder> {
    private List<User> userList;
    private Context context;

    public UserAdapter(Context context, List<User> userList) {
        this.userList = userList;
        this.context = context;
    }

    @Override
    public int getItemCount() {
        //need add the count of title
        return userList.size() + 1;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {

        ItemUserLayoutBinding itemUserLayoutBinding;
        ItemTitleBinding itemTitleBinding;
        switch (viewType) {
            case 0:
                itemTitleBinding = DataBindingUtil.inflate(LayoutInflater.from(context), R.layout.item_title, parent, false);
                return new MyViewHolder(itemTitleBinding);
            case 1:
                itemUserLayoutBinding = DataBindingUtil.inflate(LayoutInflater.from(context), R.layout.item_user_layout, parent, false);
                return new MyViewHolder(itemUserLayoutBinding);
            default:
                // invalid case
                return null;
        }
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        switch (holder.getItemViewType()) {
            case 0:
                ItemTitleBinding itemTitleBinding = holder.itemTitleBinding;
                itemTitleBinding.setHandler(new EventHandler(context));
                break;
            case 1:
                User user = userList.get(position - 1);
                ItemUserLayoutBinding itemUserLayoutBinding = holder.itemUserLayoutBinding;
                itemUserLayoutBinding.setHandler(new EventHandler(context));
                itemUserLayoutBinding.setUseritem(user);
                break;

            default:

        }
    }

    @Override
    public int getItemViewType(int position) {
        if (position == 0) {
            //if position is 0,it is type for title
            return 0;
        } else {
            //if not,it is type for user
            return 1;
        }
    }

    public class MyViewHolder extends RecyclerView.ViewHolder {
        ItemUserLayoutBinding itemUserLayoutBinding = null;
        ItemTitleBinding itemTitleBinding = null;

        public MyViewHolder(ItemUserLayoutBinding itemUserLayoutBinding) {
            super(itemUserLayoutBinding.getRoot());
            this.itemUserLayoutBinding = itemUserLayoutBinding;
            itemUserLayoutBinding.setHandler(new EventHandler(context));
        }

        public MyViewHolder(ItemTitleBinding itemTitleBinding) {
            super(itemTitleBinding.getRoot());
            this.itemTitleBinding = itemTitleBinding;
            itemTitleBinding.setHandler(new EventHandler(context));
        }

    }
}

主界面

MainActivity 

public class MainActivity extends AppCompatActivity {

    private List<User> mUserList;
    private UserAdapter mUserAdapter;
    ActivityMainBinding mainBinding;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main);
        initData();
    }

    private void initData() {
        mUserList = new ArrayList<User>();
        for (int i = 0; i < 20; i++) {
            User u = new User("Caihuijian", i);
            mUserList.add(u);
        }
        mUserAdapter = new UserAdapter(this, mUserList);
        mainBinding.listAll.setLayoutManager(new LinearLayoutManager(this));
        mainBinding.listAll.setAdapter(mUserAdapter);
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个使用TabLayout+ViewPager+Fragmet+RecyclerView结合的小demo的示例代码。 1. 首先,在xml文件中添加TabLayout和ViewPager组件。 ```xml <android.support.design.widget.TabLayout android:id="@+id/tab_layout" android:layout_width="match_parent" android:layout_height="wrap_content" /> <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 创建Fragment类,用于展示RecyclerView数据。 ```java public class SimpleFragment extends Fragment { private RecyclerView recyclerView; private SimpleAdapter adapter; @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_simple, container, false); recyclerView = view.findViewById(R.id.recycler_view); recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); adapter = new SimpleAdapter(); recyclerView.setAdapter(adapter); return view; } } ``` 3. 创建FragmentPagerAdapter类,用于管理Fragment。 ```java public class SimplePagerAdapter extends FragmentPagerAdapter { private String[] titles; public SimplePagerAdapter(FragmentManager fm, String[] titles) { super(fm); this.titles = titles; } @Override public Fragment getItem(int position) { return new SimpleFragment(); } @Override public int getCount() { return titles.length; } @Nullable @Override public CharSequence getPageTitle(int position) { return titles[position]; } } ``` 4. 创建RecyclerView Adapter类,用于展示数据。 ```java public class SimpleAdapter extends RecyclerView.Adapter<SimpleViewHolder> { private List<String> data; public SimpleAdapter() { data = new ArrayList<>(); for (int i = 0; i < 20; i++) { data.add("Item " + i); } } @NonNull @Override public SimpleViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_simple, parent, false); return new SimpleViewHolder(view); } @Override public void onBindViewHolder(@NonNull SimpleViewHolder holder, int position) { holder.textView.setText(data.get(position)); } @Override public int getItemCount() { return data.size(); } } ``` 5. 创建RecyclerView ViewHolder类,用于展示每个item。 ```java public class SimpleViewHolder extends RecyclerView.ViewHolder { public TextView textView; public SimpleViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(R.id.text_view); } } ``` 6. 最后,在Activity中进行初始化和设置。 ```java public class MainActivity extends AppCompatActivity { private TabLayout tabLayout; private ViewPager viewPager; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tabLayout = findViewById(R.id.tab_layout); viewPager = findViewById(R.id.view_pager); String[] titles = {"Tab 1", "Tab 2", "Tab 3"}; SimplePagerAdapter adapter = new SimplePagerAdapter(getSupportFragmentManager(), titles); viewPager.setAdapter(adapter); tabLayout.setupWithViewPager(viewPager); } } ``` 这样就完成了TabLayout+ViewPager+Fragmet+RecyclerView结合的小demo

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值