Android開發(fā)基于ScrollView實現(xiàn)的漸變導航欄效果示例
本文實例講述了Android開發(fā)基于ScrollView實現(xiàn)的漸變導航欄效果。分享給大家供大家參考,具體如下:
前些日子項目要在原來的頁面上加入漸變導航欄的功能,查了很多資料,很多資源都是監(jiān)聽到listview的高度來實現(xiàn)漸變導航欄的效果,可是項目里面很多的界面都是使用ScrollView來實現(xiàn)滑動效果。
實在沒辦法,就自己寫了一個test來實現(xiàn)這個效果。
話不多說,馬上看一下思路吧,其實漸變導航欄無非就是改變導航欄的透明度也就是可以設定一個高度,根據(jù)這個高度,監(jiān)聽ScrollView滑動的距離,從而實現(xiàn)漸變導航欄的效果。
下面看代碼吧
首先自定義一個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); }
這里的回調(diào)函數(shù),實現(xiàn)了對ScrollView的監(jiān)聽
然后就是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的監(jiān)聽,同時設置監(jiān)聽高度為500,將500分為100%來實現(xiàn)漸變導航欄的改變
然后在xml文件上繼承ObservableScrollView類即可。
更多關于Android相關內(nèi)容感興趣的讀者可查看本站專題:《Android基本組件用法總結》、《Android開發(fā)入門與進階教程》、《Android布局layout技巧總結》、《Android視圖View技巧總結》、《Android編程之a(chǎn)ctivity操作技巧總結》、《Android資源操作技巧匯總》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
- android開發(fā)仿ios的UIScrollView實例代碼
- 詳解Android ScrollView嵌套EditText出現(xiàn)的滑動問題
- android ScrollView實現(xiàn)下拉放大頭部圖片
- Android自定義scrollView實現(xiàn)頂部圖片下拉放大
- Android給scrollView截圖超過屏幕大小形成長圖
- Android沉浸式狀態(tài)欄 + actionBar漸變 + scrollView頂部伸縮效果
- Android自定義ScrollView使用自定義監(jiān)聽
- Android開發(fā)實現(xiàn)ScrollView中嵌套兩個ListView的方法
- Android開發(fā)實現(xiàn)標題隨scrollview滑動變色的方法詳解
- Android Webview與ScrollView的滾動兼容及留白處理的方法
- Android 自定義 HorizontalScrollView 打造多圖片OOM 的橫向滑動效果(實例代碼)
- Android ScrollView粘性頭部代碼分享
相關文章
Android實現(xiàn)判斷某個服務是否正在運行的方法
這篇文章主要介紹了Android實現(xiàn)判斷某個服務是否正在運行的方法,涉及Android針對系統(tǒng)服務運行狀態(tài)的判斷技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10Android自定義ViewGroup實現(xiàn)豎向引導界面
這篇文章主要為大家詳細介紹了Andoird自定義ViewGroup實現(xiàn)豎向引導界面,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-03-03Android中使用OkHttp包處理HTTP的get和post請求的方法
OkHttp包為安卓開發(fā)中的HTTP協(xié)議網(wǎng)絡編程帶來了很大的便利,這里我們就來看一下最基本的、Android中使用OkHttp包處理HTTP的get和post請求的方法:2016-07-07