热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android仿网易客户端顶部导航栏效果

这篇文章主要为大家详细介绍了Android仿网易客户端顶部导航栏效果,帮助大家制作网易客户端导航栏特效,感兴趣的小伙伴们可以参考一下

最近刚写了一个网易客户端首页导航条的动画效果,现在分享出来给大家学习学习。我说一下这个效果的核心原理。下面是效果图:

 首先是布局,这个布局是我从网易客户端反编译后弄来的。大家看后应该明白,布局文件如下:

 
   
 
   
 
   
  

这里用了HorizontalScrollView横向滚动视图主要是为了实现当导航栏个数超出屏幕以后可以实现左右移动的效果,这2个ImageButton则是用来实现左右滚动的操作。HorizontalScrollView里面用的一个框架布局,大家都知道框架布局是一个叠加式的 布局,所以里面的ImageView会在LinearLayout布局下面一层,这个ImageView就是实现动态背景效果的。而LinearLayout里面放的是TextView,这里是在后台程序里面动态添加。

那要怎样实现当我点击一个TextView 后实现后面的ImageView动态移动到我选中的TextView位置呢?这里我们需要为每一个TextView添加onTouchEvent()时间,并且监听ACTION_DOWN时间,也就是手指按下的时候,这时我们就启动一个TranslateAnimation平移动画,在动画结束时,再将ImageView移动到textview的位置。移动textview的位置我这里是动态调整textview的布局来实现的。

下面是实现的代码:

private void translateImage(MotionEvent event) { 
  float x = event.getX(); 
  float rx = event.getRawX(); 
  final float nx = rx - x - 12; 
  TranslateAnimation trans = null; 
  if (nx > lastX) { 
   trans = new TranslateAnimation(0, nx - lastX, 0, 0); 
  } else if (nx 

这个方法的开头我是取到手指按下的textview的坐标位置,而lastX是上一次手指按下的位置,我这里做了判断来确定移动的方向,然后给动画添加了一个动画监听事件,在动画结束时我就动态的把imageview移动到新的坐标位置。setFillEnabled(true);这里的作用主要是避免动画乱跳,这里具体是什么原因我也还不太清楚,但是设置以后动画一切都正常。

下面是textview的onTouchEvent事件的代码:

@Override 
 public boolean onTouch(View v, MotionEvent event) { 
  if (event.getAction() == MotionEvent.ACTION_DOWN) { 
   if (up_text != null) { 
    up_text.setTextColor(Color.BLACK); 
   } else { 
    TextView text = (TextView) context 
      .findViewById(R.id.head_lines); 
    text.setTextColor(Color.BLACK); 
   } 
   translateImage(event); 
   TextView tv = (TextView) v; 
   tv.setTextColor(Color.WHITE); 
   up_text = tv; 
  } 
  return true; 
 } 

 在这段代码中我主要是实现了textview的字体颜色的变还,大家应该看得懂,没什么好说的吧。

最后就是实现HorizontalScrollView控件通过单机左右的imageButton来实现左右移动,这个就是在ImageButton的OnClick事件中来调用HorizontalScrollView的smoothScrollTo(x,y)方法这里面是传入新的坐标。下面是实现代码:

private void addListener() { 
 column_to_left.setOnClickListener(new OnClickListener() { 
 
  @Override 
  public void onClick(View v) { 
   column_scrollview.smoothScrollTo( 
     column_scrollview.getScrollX() - 40, 0); 
  } 
 }); 
 column_to_right.setOnClickListener(new View.OnClickListener() { 
 
  @Override 
  public void onClick(View v) { 
   column_scrollview.smoothScrollTo( 
     column_scrollview.getScrollX() + 40, 0); 
  } 
 }); 
} 

下面是动态添加textview的代码:

private void initView() { 
 column_title_layout = (LinearLayout) findViewById(R.id.column_title_layout); 
 column_scrollview = (HorizontalScrollView) findViewById(R.id.column_scrollview); 
 column_slide_bar = (ImageView) findViewById(R.id.column_slide_bar); 
 column_to_left = (ImageButton) findViewById(R.id.column_to_left); 
 column_to_right = (ImageButton) findViewById(R.id.column_to_right); 
 
 LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(65, 
   LayoutParams.WRAP_CONTENT); 
 params.gravity = Gravity.CENTER_HORIZONTAL | Gravity.CENTER_VERTICAL; 
 params.leftMargin = 9; 
 
 TextViewOnTouchListener listener = new TextViewOnTouchListener( 
   column_slide_bar, this); 
 TextView text = null; 
 for (int i = 0; i <6; i++) { 
  text = new TextView(this); 
  text.setTextSize(16); 
  switch (i) { 
  case 0: 
   text.setId(R.id.head_lines); 
   text.setTextColor(Color.WHITE); 
   text.setText("头条"); 
   break; 
  case 1: 
   text.setId(R.id.sport); 
   text.setTextColor(Color.BLACK); 
   text.setText("体育"); 
   break; 
  case 2: 
   text.setId(R.id.entertainment); 
   text.setTextColor(Color.BLACK); 
   text.setText("娱乐"); 
   break; 
  case 3: 
   text.setId(R.id.finance); 
   text.setTextColor(Color.BLACK); 
   text.setText("财经"); 
   break; 
  case 4: 
   text.setId(R.id.technology); 
   text.setTextColor(Color.BLACK); 
   text.setText("科技"); 
   break; 
  case 5: 
   text.setId(R.id.more); 
   text.setTextColor(Color.BLACK); 
   text.setText("更多"); 
   break; 
  } 
  text.setOnTouchListener(listener); 
  column_title_layout.addView(text, params); 
 } 
} 

下面是ids.xml文件中定义的动态生成控件的id:

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
 
 

源码下载:Android仿网易客户端顶部导航栏

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文详细介绍了如何在Android应用中使用GridView组件以网格形式展示数据(如文本和图像)。通过行列布局,实现类似矩阵的数据展示效果。 ... [详细]
  • 在使用Maven进行项目构建时,由于依赖库的下载速度慢常常让人感到沮丧,这直接影响了开发效率和学习热情。幸运的是,阿里云提供了一个快速的国内镜像服务,能够显著提升Maven项目的构建速度。 ... [详细]
  • 本文介绍了在Android项目中实现时间轴效果的方法,通过自定义ListView的Item布局和适配器逻辑,实现了动态显示和隐藏时间标签的功能。文中详细描述了布局文件、适配器代码以及时间格式化工具类的具体实现。 ... [详细]
  • 在本问题中,游戏的每一步状态均可以视为原始序列的一个子序列。通过定义一个动态规划函数 d(i, j),表示在最优策略下,先手玩家从原序列的第 i 个元素到第 j 个元素之间所能获得的最大分数。 ... [详细]
  • Spring Cloud Config 使用 Vault 作为配置存储
    本文探讨了如何在Spring Cloud Config中集成HashiCorp Vault作为配置存储解决方案,基于Spring Cloud Hoxton.RELEASE及Spring Boot 2.2.1.RELEASE版本。文章还提供了详细的配置示例和实践建议。 ... [详细]
  • 本文探讨如何利用Java反射技术来模拟Webwork框架中的URL解析过程。通过这一实践,读者可以更好地理解Webwork及其后续版本Struts2的工作原理,尤其是它们在MVC架构下的角色。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 最近同事提了一个需求过来,他觉得项目对于第三方日志记录的太多了,只想记录一些业务相关的日志减少对于框架日志的显示。具体要求就是对于框架日志只显示warn等级以上的,而业务日志显示info等级以上 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 详细指南:使用IntelliJ IDEA构建多模块Maven项目
    本文在前两篇文章的基础上,进一步指导读者如何在IntelliJ IDEA中创建和配置多模块Maven项目。通过详细的步骤说明,帮助读者掌握项目模块化管理的方法。 ... [详细]
  • PHP 中 preg_match 函数的 isU 修饰符详解
    本文详细解析 PHP 中 preg_match 函数中 isU 修饰符的具体含义及其应用场景,帮助开发者更好地理解和使用正则表达式。 ... [详细]
  • 在使用Maven构建多模块项目时,执行`nvm clean install`命令可能会遇到子模块路径配置错误的问题,导致提示‘pom.xml does not exist’的错误信息。 ... [详细]
  • 本文介绍了一种在Win10 UWP应用中实现根据数值动态改变颜色的控件的方法。通过将椭圆的颜色与整数绑定,并利用值转换器来实现颜色的渐变效果。 ... [详细]
author-avatar
shahua1111
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有