今天舰讹,我們用RecyclerView來實(shí)現(xiàn)以下效果
實(shí)現(xiàn)過程:
1.你需要用到的文件
(1)MainActivity與activity_main.xml
(2)item_menu.xml:菜單項(xiàng)布局文件
(3)DataUtil.java:工具類搜立,添加獲取菜單數(shù)據(jù)的靜態(tài)方法
(4)Menu.java:菜單實(shí)體類,存放菜單的信息
(5)MenuAdapter.java:
繼承RecyclerView.Adapter蟆盐,用作RecyclerView的適配器
(6)MenuViewHolder.java:
與MenuAdapter.java處于同一個(gè).java文件,繼承RecyclerView.ViewHolder遭殉,用于關(guān)聯(lián)layout文件
2.activity_main.xml要實(shí)現(xiàn)的效果:添加一個(gè)RecyclerView即可
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerview_main_menu"
android:layout_width="match_parent"
android:layout_height="62dp">
</androidx.recyclerview.widget.RecyclerView>
提示:記得要導(dǎo)入依賴:
implementation 'androidx.recyclerview:recyclerview:1.1.0'
3.MainActivity:添加成員變量菜單視圖RecyclerView mRecyclerViewMenu石挂,菜單圖標(biāo)int[] menuIcons,菜單字符串String [] menus险污。(這里我把menus的值寫在了strings.xml里了痹愚,推薦此編碼習(xí)慣)
4.item_menu.xml要實(shí)現(xiàn)的效果:實(shí)現(xiàn)一個(gè)菜單的效果其中即可,如圖
5.Menu.java:添加兩個(gè)成員變量int icon和String menuName蛔糯,添加帶參構(gòu)造方法
public Menu(int icon, String menuName) {
this.icon = icon;
this.menuName = menuName;
}
6.DataUtil.java:添加獲取菜單數(shù)據(jù)的靜態(tài)方法
public static List<Menu> getMainMenus(int icons[],String names[]){
List<Menu> menus=new ArrayList<>();
for (int index = 0; index < icons.length; index++) {
Menu menu=new Menu(icons[index],names[index]);
menus.add(menu);
}
return menus;
}
注意:這里的Menu不是android.view.Menu,不要引入錯(cuò)了
7.MenuViewHolder.java:
與MenuAdapter.java處于同一個(gè).java文件拯腮,繼承RecyclerView.ViewHolder類。
添加成員變量ImageView mImgMenuIcon和TextView mTxtMenuName蚁飒,添加構(gòu)造方法动壤,如下:
public MenuViewHolder(View itemView) {
super(itemView);
mImgMenuIcon=itemView.findViewById(R.id.img_menu_icon);
mTxtMenuName =itemView.findViewById(R.id.txt_menu_name);
}
8.MenuAdapter.java:
繼承RecyclerView.Adapter,添加成員變量Context context和List<Menu> menus淮逻,添加帶參構(gòu)造方法琼懊。
(1)重寫onCreateViewHolder方法,返回一個(gè)由item_menu.xml反向生成的視圖弦蹂。
return new MenuViewHolder(LayoutInflater.from(context).inflate(R.layout.item_menu, null));
(2)重寫getItemCount方法肩碟,返回菜單項(xiàng)的數(shù)量(注意判空)
return null != menus ? menus.size() : 0;
(3)重寫onBindViewHolder方法,
對(duì)MenuViewHolder的成員變量mImgMenuIcon和mTxtMenuName進(jìn)行設(shè)置凸椿。
Menu menu=menus.get(position);
holder.mImgMenuIcon.setImageResource(menu.icon);
holder.mTxtMenuName.setText(menu.menuName);
9. MainActivity:
在onCreate方法中初始化menus字符串,綁定mRecyclerViewMenu削祈。
給mRecyclerViewMenu設(shè)置布局管理器,創(chuàng)建適配器脑漫,給mRecyclerViewMenu設(shè)置適配器髓抑。
menus=getResources().getStringArray(R.array.main_menu);
mRecyclerViewMenu = findViewById(R.id.recyclerview_main_menu);
mRecyclerViewMenu.setLayoutManager (new GridLayoutManager(this,4));
MenuAdapter menuAdapter= new MenuAdapter(this,DataUtil.getMainMenus(menuIcons,menus));
mRecyclerViewMenu.setAdapter(menuAdapter);
The end !