Android開(kāi)發(fā)基于ScrollView實(shí)現(xiàn)的漸變導(dǎo)航欄效果示例
本文實(shí)例講述了Android開(kāi)發(fā)基于ScrollView實(shí)現(xiàn)的漸變導(dǎo)航欄效果。分享給大家供大家參考,具體如下:
前些日子項(xiàng)目要在原來(lái)的頁(yè)面上加入漸變導(dǎo)航欄的功能,查了很多資料,很多資源都是監(jiān)聽(tīng)到listview的高度來(lái)實(shí)現(xiàn)漸變導(dǎo)航欄的效果,可是項(xiàng)目里面很多的界面都是使用ScrollView來(lái)實(shí)現(xiàn)滑動(dòng)效果。
實(shí)在沒(méi)辦法,就自己寫(xiě)了一個(gè)test來(lái)實(shí)現(xiàn)這個(gè)效果。

話(huà)不多說(shuō),馬上看一下思路吧,其實(shí)漸變導(dǎo)航欄無(wú)非就是改變導(dǎo)航欄的透明度也就是可以設(shè)定一個(gè)高度,根據(jù)這個(gè)高度,監(jiān)聽(tīng)ScrollView滑動(dòng)的距離,從而實(shí)現(xiàn)漸變導(dǎo)航欄的效果。
下面看代碼吧
首先自定義一個(gè)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;
}
}
這里面定義了兩個(gè)接口
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ù),實(shí)現(xiàn)了對(duì)ScrollView的監(jiān)聽(tīng)
然后就是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中設(shè)置對(duì)ScrollView的監(jiān)聽(tīng),同時(shí)設(shè)置監(jiān)聽(tīng)高度為500,將500分為100%來(lái)實(shí)現(xiàn)漸變導(dǎo)航欄的改變
然后在xml文件上繼承ObservableScrollView類(lèi)即可。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Android基本組件用法總結(jié)》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android布局layout技巧總結(jié)》、《Android視圖View技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android資源操作技巧匯總》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- android開(kāi)發(fā)仿ios的UIScrollView實(shí)例代碼
- 詳解Android ScrollView嵌套EditText出現(xiàn)的滑動(dòng)問(wèn)題
- android ScrollView實(shí)現(xiàn)下拉放大頭部圖片
- Android自定義scrollView實(shí)現(xiàn)頂部圖片下拉放大
- Android給scrollView截圖超過(guò)屏幕大小形成長(zhǎng)圖
- Android沉浸式狀態(tài)欄 + actionBar漸變 + scrollView頂部伸縮效果
- Android自定義ScrollView使用自定義監(jiān)聽(tīng)
- Android開(kāi)發(fā)實(shí)現(xiàn)ScrollView中嵌套兩個(gè)ListView的方法
- Android開(kāi)發(fā)實(shí)現(xiàn)標(biāo)題隨scrollview滑動(dòng)變色的方法詳解
- Android Webview與ScrollView的滾動(dòng)兼容及留白處理的方法
- Android 自定義 HorizontalScrollView 打造多圖片OOM 的橫向滑動(dòng)效果(實(shí)例代碼)
- Android ScrollView粘性頭部代碼分享
相關(guān)文章
android 布局之ConstraintLayout的使用
這篇文章主要介紹了android 布局之ConstraintLayout的使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
Android XmlPullParser 方式解析 Xml 文檔
這篇文章主要介紹了Android XmlPullParser 方式解析 Xml 文檔的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android控件之ProgressBar用法實(shí)例分析
這篇文章主要介紹了Android控件之ProgressBar用法,以一個(gè)完整實(shí)例形式較為詳細(xì)的分析了ProgressBar控件操作進(jìn)度顯示的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
Android開(kāi)發(fā)實(shí)現(xiàn)保存圖片到手機(jī)相冊(cè)功能
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)保存圖片到手機(jī)相冊(cè)功能,涉及Android圖形及文件相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
Android ListView列表實(shí)現(xiàn)倒計(jì)時(shí)
這篇文章主要為大家詳細(xì)介紹了Android ListView列表實(shí)現(xiàn)倒計(jì)時(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Android顏色處理SweepGradient掃描及梯度渲染示例
這篇文章主要為大家介紹了Android顏色處理SweepGradient掃描渲染及梯度渲染示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Android中ActionBar和ToolBar添加返回箭頭的實(shí)例代碼
這篇文章主要介紹了Android中ActionBar和ToolBar添加返回箭頭的實(shí)例代碼,需要的朋友可以參考下2017-09-09

