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)辦法,就自己寫了一個(gè)test來(lái)實(shí)現(xiàn)這個(gè)效果。

話不多說(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類即可。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android基本組件用法總結(jié)》、《Android開(kāi)發(fā)入門與進(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實(shí)現(xiàn)判斷某個(gè)服務(wù)是否正在運(yùn)行的方法
這篇文章主要介紹了Android實(shí)現(xiàn)判斷某個(gè)服務(wù)是否正在運(yùn)行的方法,涉及Android針對(duì)系統(tǒng)服務(wù)運(yùn)行狀態(tài)的判斷技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10
Android仿騰訊視頻實(shí)現(xiàn)懸浮窗效果
對(duì)view比較熟悉的同學(xué)們應(yīng)該發(fā)現(xiàn)了,其實(shí)我們的懸浮窗就是一個(gè)view,我們只需要把view添加到windowManager上就可以了。那么,下面通過(guò)本文給大家分享Android仿騰訊視頻實(shí)現(xiàn)懸浮窗效果,一起看看吧2021-06-06
Android PopWindow 設(shè)置背景亮度的實(shí)例
這篇文章主要介紹了Android PopWindow 設(shè)置背景亮度的實(shí)例的相關(guān)資料,這里提供實(shí)現(xiàn)方法,希望能幫助有所需要的朋友,需要的朋友可以參考下2017-08-08
Android自定義ViewGroup實(shí)現(xiàn)豎向引導(dǎo)界面
這篇文章主要為大家詳細(xì)介紹了Andoird自定義ViewGroup實(shí)現(xiàn)豎向引導(dǎo)界面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03
Android中使用OkHttp包處理HTTP的get和post請(qǐng)求的方法
OkHttp包為安卓開(kāi)發(fā)中的HTTP協(xié)議網(wǎng)絡(luò)編程帶來(lái)了很大的便利,這里我們就來(lái)看一下最基本的、Android中使用OkHttp包處理HTTP的get和post請(qǐng)求的方法:2016-07-07
Android控件實(shí)現(xiàn)直播App點(diǎn)贊飄心動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了FlowLikeView控件實(shí)現(xiàn)直播App特效之點(diǎn)贊飄心動(dòng)畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03

