内容简介:因为之前第一遍写项目的时候,技术什么的都是第一次学习就使用,所以期间没有对整个MD设计有一个全面的认识,结果就是四不像。关于MD能做什么,不能做什么,提倡什么,不提倡什么,通过第一次编写,已经有了把握。所以这一次是重新对MD的第二次实践。过程中肯定有以前没用过的技术,和新遇到的困难,都记录在这里,打上同样的标签,写成一个系列,作为未来的参考。页面使用Fragment的理由:样式官网建议:
因为之前第一遍写项目的时候,技术什么的都是第一次学习就使用,所以期间没有对整个MD设计有一个全面的认识,结果就是四不像。关于MD能做什么,不能做什么,提倡什么,不提倡什么,通过第一次编写,已经有了把握。所以这一次是重新对MD的第二次实践。过程中肯定有以前没用过的技术,和新遇到的困难,都记录在这里,打上同样的标签,写成一个系列,作为未来的参考。
底部导航的使用情况和原因
-
使用情况: 用于切换不同的页面。
-
使用顾虑 之前我担心的问题在于:会不会因为一个导航一直悬停在底部,显得界面不好看。 实际上底部导航是能够跟随页面滑动隐藏的。 而且事实底部导航设计好了,也不会显得有突兀的问题。
如何实践
- 之前项目的不同模块是用Activity写的,现在用Fragment写
页面使用Fragment的理由: stackoverflow.com/questions/4… It will prevent from destroying and creation of the activities and screen blinking. 避免屏幕闪烁 It is easier to hold only one BottomNavigationView. 不同的activity要保持底部导航的一致是比较困难的 Single Responsibility for handling navigation, saving and restoring states. 处理导航的状态更方便
- MD风格底部菜单栏的样式
样式官网建议: www.mdui.org/design/comp… 用法:3 - 5 个顶级视图 且 对应的视图要可以直接访问 颜色:激活状态的导航项的图标和文字使用主色。如果底部导航栏有背景色,则使用白色或黑色的图标和文字。 规格:宽度80-168 高度56 图标24*24 底部导航主要用于移动设备。如果要在桌面设备上实现类似效果,请使用侧边栏导航。
- 如何实现
CoordinatorLayout + BottomNavigationView + Fragment☆参考文章1, 参考文章2
BottomNavigationView开始实践
问题一:如何在XML中放置:
参考:在CoordinatorLayout中使用BottomNavigation 我们都知道CoordinatorLayout是一个高级FragmentLayout,直接放置BottomNavigationView的时候,它会在界面的最上方,而不是直觉上认为的:名字都叫Bottom了,位置应该自动置于最下。 我们需要在不同的布局中为它进行设置:对CoordinatorLayout用android:layout_gravity="bottom"
问题二:怎么设置各个导航项:
参考:MD系列文章之底部导航栏 BottomNavigationView的Tab是通过menu的方式添加的,与TabLayout的Tab不同。 (TabLayout:addTab添加Tab | 与ViewPager adapter联动设置切换Fragments) 所以先来写menu,然后在BottomNavigationView中通过app:menu使用
<!--BottomNavigationView代码--> <android.support.design.widget.BottomNavigationView android:layout_width="match_parent" android:layout_height="56dp" android:layout_gravity="bottom" app:menu="@menu/navigation_bottom" ></android.support.design.widget.BottomNavigationView> <!--menu代码--> <menu xmlns:android="http://schemas.android.com/apk/res/android"> <item android:id="@+id/navigation_bottom_folder_list" android:icon="@drawable/ic_unselected_cards" android:title="收藏"/> ...省略 复制代码
效果:
问题三:导航栏如何与fragment对应以切换视图?
参考文章1 参考2 事实上,这个问题是错误的。底部菜单栏和TabLayout不一样,它是不能滑动切换的,所以没有设置对应fragment的这种说法。
那怎么做呢?setOnNavigationItemSelectedListener 设置item的点击事件。
第一步:创建fragment - 使用newInstance函数设置Fragment的个性 第二步:在XML中设置FrameLayout用于放置fragment 第三步:设置setOnNavigationItemSelectedListener,获取当前的点击位置,并设置对应的fragment到FrameLayout中
<FrameLayout android:id="@+id/fragment_placeholder" android:layout_gravity="top" android:layout_width="match_parent" android:layout_height="wrap_content" /> 复制代码
bottomNavigationView = findViewById(R.id.BottomNavigation); bottomNavigationView.setOnNavigationItemSelectedListener(item -> onTabItemSelected(item.getItemId())); 复制代码
实践反馈-新的问题
这种实践反馈而来的问题,更多是使用原理的问题。也就是和这个系统的原理有关, 比如 不会默认设置选中状态, setOnNavigationItemSelectedListener一定要返回true(这个应该和事件分发有关,或许不返回true就认为没有成功设置,所以没有改变底部)
可以看到的问题是:第一个视图没有加载;下方导航被选择没有改变状态; 实际上原因已经在开头说过了,就是一定要。所以代码如下:
protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_folder_list); initFragments(); initView(); } private void initView() { bottomNavigationView = findViewById(R.id.BottomNavigation); //一定要获得true的返回 bottomNavigationView.setOnNavigationItemSelectedListener(item -> onTabItemSelected(item.getItemId())); //这个地方来设置默认选中的状态 onTabItemSelected(R.id.navigation_bottom_folder_list); } private boolean onTabItemSelected(int id) { Fragment fragment = null; switch (id) { case://省略 fragment = fragments.get(0); break; //省略 } if (fragment != null) { getSupportFragmentManager().beginTransaction().replace(R.id.fragment_placeholder,fragment).commit(); return true; } return false; } 复制代码
效果如下
项目地址
github.com/Wubingyu/An… branch:project_practice clone命令:
git clone -b project_practice git@github.com:Wubingyu/Android-Practice.git 复制代码
以上所述就是小编给大家介绍的《项目实践-MD设计-底部菜单栏(一)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 紧贴底部的页脚
- Android实现底部状态栏切换
- 定制化你的ReactNative底部导航栏
- 深耕业务——商品列表底部分销商品资源广告位
- iphone – 顶部和底部透明渐变的UITableView
- 移动端H5 input输入完成后页面底部留白问题
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
模式识别
(希)Sergios Theodoridis、(希)Konstantinos Koutroumbas / 电子工业出版社 / 2010-2 / 75.00元
本书全面阐述了模式识别的基础理论、最新方法以及各种应用。模式识别是信息科学和人工智能的重要组成部分,主要应用领域有图像分析、光学字符识别、信道均衡、语言识别和音频分类等。本书在完美地结合当前的理论与实践的基础上,讨论了贝叶斯分类、贝叶斯网络、线性和非线性分类器设计、上下文相关分类、特征生成、特征选取技术、学习理论的基本概念以及聚类概念与算法。与前一版相比,增加了大数据集和高维数据相关的最新算法,这......一起来看看 《模式识别》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
RGB转16进制工具
RGB HEX 互转工具