怎么在Android中利用ScrollView实现一个渐变导航栏效果
怎么在Android中利用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); } }
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。
文章标题:怎么在Android中利用ScrollView实现一个渐变导航栏效果
分享链接:http://scyanting.com/article/ghocce.html