编程是一种美德,是促使一个人不断向上发展的一种原动力

—————–以下是正文———————
最近好多app的底部标签导航使用以下形式了,所以我们就来学习一下它是如何实现的。

先看效果:

中间的“+”我给了一个旋转动画,看起来还是不错的,有兴趣的同学可以下载Demo看一下。

最近准备开发一款新App, 产品也给出了这么一个底部标签导航。于是就开始研究这个样式怎么实现的。常规的做法是粘贴复制…,我就在想可以简单点不。于是就开始了网上海选工作,在gitHub上找到了MainNavigateTabBar,他是一个普通的底部标签导航。不太符合我的需求,于是就对其源码进行了一些修改,把消息提示加进去了。
,先看一下这个功能的实现吧,有了图之后,分分钟搞定
MainActivity 代码:

  1. public class MainActivity extends AppCompatActivity {
  2. private static final String TAG_PAGE_HOME = "首页";
  3. private static final String TAG_PAGE_CITY = "同城";
  4. private static final String TAG_PAGE_PUBLISH = "发布";
  5. private static final String TAG_PAGE_MESSAGE = "消息";
  6. private static final String TAG_PAGE_PERSON = "我的";
  7. private MainNavigateTabBar mNavigateTabBar;
  8. @Override
  9. protected void onCreate(Bundle savedInstanceState) {
  10. super.onCreate(savedInstanceState);
  11. setContentView(R.layout.activity_main);
  12. mNavigateTabBar = (MainNavigateTabBar) findViewById(R.id.mainTabBar);
  13. mNavigateTabBar.onRestoreInstanceState(savedInstanceState);
  14. mNavigateTabBar.setTabTextColor(getResources().getColor(R.color.blue_btn_disabled));
  15. //对应xml中的navigateTabSelectedTextColor
  16. mNavigateTabBar.setSelectedTabTextColor(getResources().getColor(R.color.blue_btn_normal));
  17. mNavigateTabBar.addTab(HomeFragment.class, new MainNavigateTabBar.TabParam(R.mipmap.tab_home_n, R.mipmap.tab_home_p, TAG_PAGE_HOME));
  18. mNavigateTabBar.addTab(CityFragment.class, new MainNavigateTabBar.TabParam(R.mipmap.tab_class_n, R.mipmap.tab_class_p, TAG_PAGE_CITY));
  19. mNavigateTabBar.addTab(null, new MainNavigateTabBar.TabParam(0, 0, TAG_PAGE_PUBLISH));
  20. mNavigateTabBar.addTab(MessageFragment.class, new MainNavigateTabBar.TabParam(R.mipmap.tab_user_n, R.mipmap.tab_user_p, TAG_PAGE_MESSAGE));
  21. mNavigateTabBar.addTab(PersonFragment.class, new MainNavigateTabBar.TabParam(R.mipmap.tab_more_n, R.mipmap.tab_more_p, TAG_PAGE_PERSON));
  22. //消息提醒 显示
  23. mNavigateTabBar.disPlayBadgeCount(0, 2);
  24. mNavigateTabBar.disPlayBadgeCount(1, 2);
  25. mNavigateTabBar.disPlayBadgeCount(2, 2);
  26. mNavigateTabBar.disPlayBadgeCount(3, 2);
  27. }
  28. @Override
  29. protected void onSaveInstanceState(Bundle outState) {
  30. super.onSaveInstanceState(outState);
  31. mNavigateTabBar.onSaveInstanceState(outState);
  32. }
  33. public void onClickPublish(View v) {
  34. //消息提醒 消失
  35. mNavigateTabBar.disMissBadgeCount(0, 0);
  36. mNavigateTabBar.disMissBadgeCount(1, 0);
  37. mNavigateTabBar.disMissBadgeCount(2, 0);
  38. mNavigateTabBar.disMissBadgeCount(3, 0);
  39. //中间图片动画
  40. RotateAnimation myAnimation_Rotate = new RotateAnimation(0.0f, 90.0f,
  41. Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF, 0.5f);
  42. v.startAnimation(myAnimation_Rotate);
  43. myAnimation_Rotate.setDuration(300);
  44. Toast.makeText(this, "发布", Toast.LENGTH_LONG).show();
  45. }
  46. }

activity_main.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. xmlns:app="http://schemas.android.com/apk/res-auto"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent">
  7. <FrameLayout
  8. android:id="@+id/main_container"
  9. android:layout_width="match_parent"
  10. android:layout_height="match_parent"
  11. android:layout_above="@+id/mainTabBar"/>
  12. <com.startsmake.mainnavigatetabbar.widget.MainNavigateTabBar
  13. android:id="@+id/mainTabBar"
  14. android:layout_width="match_parent"
  15. android:layout_height="50.0dip"
  16. android:layout_alignParentBottom="true"
  17. android:background="@android:color/white"
  18. app:containerId="@+id/main_container"
  19. app:navigateTabSelectedTextColor="@color/blue_btn_disabled"
  20. app:navigateTabTextColor="@color/blue_btn_normal"/>
  21. <ImageView
  22. android:layout_width="match_parent"
  23. android:layout_height="wrap_content"
  24. android:layout_above="@+id/mainTabBar"
  25. android:background="@mipmap/comui_bar_top_shadow"/>
  26. <LinearLayout
  27. android:layout_width="match_parent"
  28. android:layout_height="80.0dip"
  29. android:layout_alignParentBottom="true"
  30. android:background="@android:color/transparent"
  31. android:gravity="center|top"
  32. android:orientation="vertical">
  33. <ImageView
  34. android:id="@+id/tab_post_icon"
  35. android:layout_width="wrap_content"
  36. android:layout_height="wrap_content"
  37. android:onClick="onClickPublish"
  38. android:src="@mipmap/comui_tab_post"/>
  39. </LinearLayout>
  40. </RelativeLayout>

这就把主页搞定了,简单吧,当然还有几个Fragment。具体内容根据项目需求来开发了

来说说怎么修改的MainNavigateTabBar吧,其实也很简单,就是找了个BadgeView 把它加到MainNavigateTabBar里就OK了,

  1. /**
  2. * 隐藏消息数量提示
  3. * @param index 底部导航的位置
  4. * @param count 消息数量 count >0 显示
  5. */
  6. public void disPlayBadgeCount(int index,int count){
  7. if (index >= 0 && index < mViewHolderList.size()) {
  8. ViewHolder holder = mViewHolderList.get(index);
  9. holder.badgeView.setTargetView(holder.view);
  10. holder.badgeView.setBadgeMargin(0,0,10,0);
  11. holder.badgeView.setBadgeCount(count);
  12. }
  13. }
  14. /**
  15. * 隐藏消息数量提示
  16. * @param index 底部导航的位置
  17. * @param count 消息数量 count = 0 消失
  18. */
  19. public void disMissBadgeCount(int index,int count){
  20. if (index >= 0 && index < mViewHolderList.size()) {
  21. ViewHolder holder = mViewHolderList.get(index);
  22. holder.badgeView.setBadgeCount(count);
  23. }
  24. }

加一句话: 除了消息提示是我加上去的,其他的是其他人的劳动成果。遗憾的他的链接找不到了….

闲鱼demo的更多相关文章

  1. 23Flutter FloatingActionButton实现类似闲鱼App底部导航凸起按钮:

    /* 一.Flutter FloatingActionButton介绍 FloatingActionButton简称FAB,可以实现浮动按钮,也可以实现类型闲鱼app的底部凸起导航. child:子视 ...

  2. Dubbo Mesh 在闲鱼生产环境中的落地实践

    本文作者至简曾在 2018 QCon 上海站以<Service Mesh 的本质.价值和应用探索>为题做了一次分享,其中谈到了 Dubbo Mesh 的整体发展思路是“借力开源.反哺开源” ...

  3. 自己动手制作的淘宝闲鱼APP宝贝数据采集工具软件

    之前做过淘宝PC端宝贝和店铺数据的采集,后来需要做APP端的数据采集,因为没有学过Android,以前也都是做PC端的软件,有没有其他方法呢? 突然想到了用手机模拟器,可以在电脑端控制运行手机APP端 ...

  4. 如何用 Flutter 实现混合开发?闲鱼公开源代码实例

    Flutter: 必火,转两篇软文预热哈哈~ 中文网: https://flutterchina.club/get-started/test-drive/ 如何用 Flutter 实现混合开发?闲鱼公 ...

  5. 闲鱼hu超赞,有赞必回,24小时在线!咸鱼互赞超赞留言评

    有没有在闲鱼上卖东西没有浏览量的人! 我们来一起互赞互相提高彼此宝贝的浏览量,从而更快的促进交易! 我打算建个群,我们可以一起交流下哈! 需要的进入QQ群   : 530980712

  6. 闲鱼Flutter&FaaS云端一体化架构

    讲师介绍 国有,闲鱼架构团队负责人.在7月13号落幕的2019年Archsummit峰会上就近一年来闲鱼在Flutter&FaaS一体化项目上的探索和实践进行了分享. 传统Native+Web ...

  7. GIAC2019 演讲精选 | 面向未来的黑科技——UI2CODE闲鱼基于图片生成跨端代码

    一直以来, 如何从‘视觉稿’精确的还原出 对应的UI侧代码 一直是端侧开发同学工作里消耗比较大的部分,一方面这部分的工作 比较确定缺少技术深度,另一方面视觉设计师也需要投入大量的走查时间,有大量无谓的 ...

  8. GMTC2019|闲鱼-基于Flutter的架构演进与创新

    2012年应届毕业加入阿里巴巴,主导了闲鱼基于Flutter的新混合架构,同时推进了Flutter在闲鱼各业务线的落地.未来将持续关注终端技术的演变及趋势 Flutter的优势与挑战 Flutter是 ...

  9. 走近科学,探究阿里闲鱼团队通过数据提升Flutter体验的真相

    背景 闲鱼客户端的flutter页面已经服务上亿级用户,这个时候Flutter页面的用户体验尤其重要,完善Flutter性能稳定性监控体系,可以及早发现线上性能问题,也可以作为用户体验提升的衡量标准. ...

随机推荐

  1. npm link 安装本地模块,将本地模块cli化

    第三方学习地址 http://mp.weixin.qq.com/s?__biz=MzAxMTU0NTc4Nw==&mid=2661157390&idx=1&sn=6d96e54 ...

  2. iTop Webservice列表

    { u'operations':[ { u'verb':u'core/create', u'description':u'Create an object', u'extension':u'CoreS ...

  3. Server-Sent Events(HTML5 服务器发送事件)

    Server-Sent Events简介 Server-Sent Events(SSE)用于网页自动获取服务器上更新的数据,它是一个实时性的机制. 实时性获取数据的解决方案 对于某些需要实时更新的数据 ...

  4. Oracle 教程

    视频教程 Oracle DBA数据库高级工程师职业学习指南与职业规划视频课程

  5. 总结-javascript-ajax

    <html><head><meta charset="utf-8"><script type="text/javascript& ...

  6. MVC中的一些坑

    1.@字符在.cshtml文件中不能启用 经过2个小时求解,发现是配置文件web.config中引用的namespace少了System.Web.Optimization,所以不能启用,因为创建的空的 ...

  7. 《Linux及安全》实践3.1

    <Linux及安全>实践三 ELF格式文件分析 一.基础操作 1.查看大小端.32还是64 由此可以看出,本人实践所用到的是32位Ubuntu,数据存储采用小端法. 2.编写hello.c ...

  8. 安装Apache报80端口被占用 pid 4

    安装Apache,不能安装成服务,提示端口已经被占用. 使用 netstat -ano | findstr "80" ,发现占用80端口的竟然是System进程. 这个进程是系统进 ...

  9. SpringMVC原理解析-DispatcherServlet初始化以及请求处理过程

  10. C# ASP.NET MVC 图片盗链 加水印 的问题

    ImageClass using System; using System.Collections; using System.IO; using System.Drawing; using Syst ...