Android开发基于ScrollView实现的渐变导航栏效果示例
作者:Surkey1030
这篇文章主要介绍了Android开发基于ScrollView实现的渐变导航栏效果,涉及ScrollView事件响应及元素属性动态操作相关实现技巧,需要的朋友可以参考下
本文实例讲述了Android开发基于ScrollView实现的渐变导航栏效果。分享给大家供大家参考,具体如下:
前些日子项目要在原来的页面上加入渐变导航栏的功能,查了很多资料,很多资源都是监听到listview的高度来实现渐变导航栏的效果,可是项目里面很多的界面都是使用ScrollView来实现滑动效果。
实在没办法,就自己写了一个test来实现这个效果。
话不多说,马上看一下思路吧,其实渐变导航栏无非就是改变导航栏的透明度也就是可以设定一个高度,根据这个高度,监听ScrollView滑动的距离,从而实现渐变导航栏的效果。
下面看代码吧
首先自定义一个ScrollView
1、ObservableScrollView.java
package com.example.test; import android.content.Context; import android.os.Build; import android.util.AttributeSet; import android.widget.ScrollView; public class ObservableScrollView extends ScrollView implements ObservableScrollable { private boolean mDisableEdgeEffects = true; private OnScrollChangedCallback mOnScrollChangedListener; public ObservableScrollView(Context context) { super(context); } public ObservableScrollView(Context context, AttributeSet attrs) { super(context, attrs); } public ObservableScrollView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onScrollChanged(int l, int t, int oldl, int oldt) { super.onScrollChanged(l, t, oldl, oldt); if (mOnScrollChangedListener != null) { mOnScrollChangedListener.onScroll(l, t); } } @Override protected float getTopFadingEdgeStrength() { if (mDisableEdgeEffects && Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) { return 0.0f; } return super.getTopFadingEdgeStrength(); } @Override protected float getBottomFadingEdgeStrength() { if (mDisableEdgeEffects && Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) { return 0.0f; } return super.getBottomFadingEdgeStrength(); } @Override public void setOnScrollChangedCallback(OnScrollChangedCallback callback) { mOnScrollChangedListener = callback; } }
这里面定义了两个接口
2、ObservableScrollable.java
package com.example.test; public interface ObservableScrollable { void setOnScrollChangedCallback(OnScrollChangedCallback callback); }
3、OnScrollChangedCallback.java
package com.example.test; public interface OnScrollChangedCallback { void onScroll(int l, int t); }
这里的回调函数,实现了对ScrollView的监听
然后就是main方法
4、MainActivity.java
package com.example.test; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.Window; import android.widget.RelativeLayout; import android.widget.ScrollView; public class MainActivity extends Activity implements OnScrollChangedCallback { ObservableScrollable sv; RelativeLayout rl; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); rl = (RelativeLayout) findViewById(R.id.rl); sv = (ObservableScrollable) findViewById(R.id.sv); sv.setOnScrollChangedCallback(this); } @Override public void onScroll(int l, int t) { float newAlpha = (float)t/500; rl.setAlpha(newAlpha); } }
main中设置对ScrollView的监听,同时设置监听高度为500,将500分为100%来实现渐变导航栏的改变
然后在xml文件上继承ObservableScrollView类即可。
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android基本组件用法总结》、《Android开发入门与进阶教程》、《Android布局layout技巧总结》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android资源操作技巧汇总》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
您可能感兴趣的文章:
- android开发仿ios的UIScrollView实例代码
- 详解Android ScrollView嵌套EditText出现的滑动问题
- android ScrollView实现下拉放大头部图片
- Android自定义scrollView实现顶部图片下拉放大
- Android给scrollView截图超过屏幕大小形成长图
- Android沉浸式状态栏 + actionBar渐变 + scrollView顶部伸缩效果
- Android自定义ScrollView使用自定义监听
- Android开发实现ScrollView中嵌套两个ListView的方法
- Android开发实现标题随scrollview滑动变色的方法详解
- Android Webview与ScrollView的滚动兼容及留白处理的方法
- Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码)
- Android ScrollView粘性头部代码分享