关于菜单使用gridView来实现的一些小经验

时间:2022-08-24 18:12:07

有时候写文章的时候 前面会稍微扯两句淡 讲一些使用场景 什么的来引入正文 或者干脆就是扯淡

也是纯粹想和大家有一些交流。不想让自己的帖子写的跟机器一样  直接上来就是代码。关于菜单使用gridView来实现的一些小经验

今天吧 直接上点干货

需求:完成主页面的菜单 如下图

关于菜单使用gridView来实现的一些小经验


有人会用LinearLayout实现 有人会用gridView实现

当然如果用LinearLayout 方便添加和删除 item

当然如果你习惯写style diman 还好 这样如果调整样式的话 还方便一些 如果你不注意这些 如果不注意这些 如果修改字号 颜色什么的 要逐一修改 非常麻烦


记得刚学习安卓的时候 总会“”手贱“”的用一下girdView 然后在主菜单有变动的时候 点击事件不对应 造成麻烦 然后又都改成线性布局 。。。。

现在把里面的一些经验拿出来分享一下

1.想法:想通过gridView的adapter  拿到position 来设置 当前item 的显示隐藏GONE  (结果就是 item内容可以被隐藏 但是所占空间并没有被隐藏)

2 想法:想设置adapter中View的宽高为零 (结果就是 View错乱或者干脆 gridView 都不显示了)

3.改变adapter 的数据源  一般是List 或者其他 的长度来改变 gridView所占布局 最为稳妥 也最为简单

4.如果要把菜单上的按钮和对应的点击事件绑定在一起   那onItemClick事件 不要用 position 来对应事件 可以采用如下方法比较好


mNBGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
switch ((int) mNBGridView.getItemIdAtPosition(position)) {
case R.drawable.club_main_btn_activity: {//活动专区
ClubEventFragment fragment = ClubEventFragment.newInstance(null, null);
mBaseUiActivity.switchFragment(fragment, ClubEventFragment.class.getSimpleName());
break;
}
case R.drawable.club_main_btn_notice: {//俱乐部公告
ClubNoticeFragment fragment = ClubNoticeFragment.newInstance(null, null);
mBaseUiActivity.switchFragment(fragment, ClubNoticeFragment.class.getSimpleName());
break;
}

当然要在adapter里设置一下 ItemID

@Override
public int getCount() {
if (null != mList) {
return mList.size();
} else {
return 0;
}
}

@Override
public Object getItem(int item) {
return item;
}

@Override
public long getItemId(int position) {
return mList.get(position).getMenuIcon();
}

getItemId(int position)

这个方法 就取出了集合对应位置 图片的ID  也就是R.drawable.XXX 那个文件   它在R文件里 一个整形的量 然后在判断这个 就能把事件绑定了

如果隐藏或者新增 某个菜单item 那么把数据源变一下 就能变成动态的菜单了

这样写的好处是  你动adapter中的View 所有的item都会进行调整