android搜索框上下滑動(dòng)變色效果
搜索框上下滑動(dòng)變透明度是現(xiàn)在APP中很常見的效果,先看看效果:

首先來看下布局骨架:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="www.sf.com.searchframe.MainActivity"> <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent" /> <!--搜索框--> <LinearLayout android:id="@+id/ll_search" android:layout_width="match_parent" android:layout_height="50dp" android:background="#00ab95" android:orientation="horizontal"> ...... </LinearLayout> </RelativeLayout>
整體就是一個(gè)相對布局,搜索框直接覆蓋在listview上面,效果圖最上方的圖片是listview的頭布局;
這個(gè)效果主要用到listview的滑動(dòng)監(jiān)聽;
在listview滑動(dòng)的時(shí)候不停的獲取,imageview距離屏幕頂部的距離;
然后獲取到imageview本身的高度;
通過這兩個(gè)值判斷imageview是否滑出屏幕,根據(jù)不同情況設(shè)置搜索框的透明度;
mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
//監(jiān)聽滑動(dòng)狀態(tài)的改變
public void onScrollStateChanged(AbsListView view, int scrollState) {
}
//用于監(jiān)聽ListView屏幕滾動(dòng)
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
int[] ints = new int[2];
mImage.getLocationOnScreen(ints);
/**
* mImage距離屏幕頂部的距離(圖片頂部在屏幕最上面,向上滑動(dòng)為負(fù)數(shù),所以取反)
* 如果不隱藏狀態(tài)欄,需要加上狀態(tài)欄的高度;隱藏狀態(tài)欄就不用加了;
*/
int scrollY = -ints[1]+statusHeight;
//mImage這個(gè)view的高度
int imageHeight = mImage.getHeight();
if (mImage != null && imageHeight > 0) {
//如果“圖片”沒有向上滑動(dòng),設(shè)置為全透明
if (scrollY < 0) {
llSearch.getBackground().setAlpha(0);
} else {
//“圖片”已經(jīng)滑動(dòng),而且還沒有全部滑出屏幕,根據(jù)滑出高度的比例設(shè)置透明度的比例
if (scrollY < imageHeight) {
int progress = (int) (new Float(scrollY) / new Float(imageHeight) * 255);//255
llSearch.getBackground().setAlpha(progress);
} else {
//“圖片”全部滑出屏幕的時(shí)候,設(shè)為完全不透明
llSearch.getBackground().setAlpha(255);
}
}
}
}
});
源碼下載:http://xiazai.jb51.net/201611/yuanma/AndroidSearch(jb51.net).rar
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- android自定義進(jìn)度條漸變色View的實(shí)例代碼
- Android實(shí)現(xiàn)TextView字符串關(guān)鍵字變色的方法
- Android實(shí)現(xiàn)漸變色的圓弧虛線效果
- android表格效果之ListView隔行變色實(shí)現(xiàn)代碼
- Android 自定義圓形帶刻度漸變色的進(jìn)度條樣式實(shí)例代碼
- Android App仿微信界面切換時(shí)Tab圖標(biāo)變色效果的制作方法
- Android中button點(diǎn)擊后字體的變色效果
- Android自定義帶水滴的進(jìn)度條樣式(帶漸變色效果)
- Android實(shí)現(xiàn)歌詞漸變色和進(jìn)度的效果
- android自定義view仿今日頭條加載文字變色效果
相關(guān)文章
Android Studio下Flutter環(huán)境搭建圖文教程
這篇文章主要為大家詳細(xì)介紹了Android Studio下Flutter環(huán)境搭建圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
Android PC端用ADB抓取指定應(yīng)用日志實(shí)現(xiàn)步驟
這篇文章主要介紹了Android PC端用ADB抓取指定應(yīng)用日志實(shí)現(xiàn)步驟,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04
如何自己實(shí)現(xiàn)Android View Touch事件分發(fā)流程
這篇文章主要介紹了如何自己實(shí)現(xiàn)Android View Touch事件分發(fā)流程,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下2021-03-03
Android的ImageButton當(dāng)顯示Drawable圖片時(shí)就不顯示文字
Android提供的ImageButton當(dāng)顯示Drawable圖片時(shí)就不會再顯示文字了,下面與大家分享下3種解決方法,不會的朋友可以了解下哈2013-06-06
Flutter 側(cè)滑欄及城市選擇UI的實(shí)現(xiàn)方法
這篇文章主要介紹了Flutter 側(cè)滑欄及城市選擇UI的實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07
Android dip,px,pt,sp 的區(qū)別詳解
本篇文章是對Android中dip,px,pt,sp的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
Flutter 利用CustomScrollView實(shí)現(xiàn)滑動(dòng)效果
我們可以使用ListView將幾個(gè)GridView組合在一起實(shí)現(xiàn)了不同可滑動(dòng)組件的粘合,但是這里必須要設(shè)置禁止 GridView 的滑動(dòng),防止多個(gè)滑動(dòng)組件的沖突。這種方式寫起來不太方便,事實(shí)上 Flutter 提供了 CustomScrollView 來粘合多個(gè)滑動(dòng)組件,并且可以實(shí)現(xiàn)更有趣的滑動(dòng)效果。2021-06-06
Android加載大分辨率圖片到手機(jī)內(nèi)存中的實(shí)例方法
有些圖片的分辨率比較高,把它直接加載到手機(jī)內(nèi)存中之后,會導(dǎo)致堆內(nèi)存溢出的問題,下面就講解一下Android的堆內(nèi)存以及如何在Android應(yīng)用中加載一個(gè)高分辨率的圖片的方法2013-11-11

