Android ScrollView實(shí)現(xiàn)向上滑動(dòng)控件頂部懸浮效果
本文的方法是通過(guò)addView和removeView來(lái)實(shí)現(xiàn)的。
一、首先讓ScrollView實(shí)現(xiàn)滾動(dòng)監(jiān)聽(tīng):
package com.willen.topFloatDemo;
import android.content.Context;
import android.os.Handler;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.ScrollView;
/**
* ScrollView并沒(méi)有實(shí)現(xiàn)滾動(dòng)監(jiān)聽(tīng),所以我們必須自行實(shí)現(xiàn)對(duì)ScrollView的監(jiān)聽(tīng),
* 我們很自然的想到在onTouchEvent()方法中實(shí)現(xiàn)對(duì)滾動(dòng)Y軸進(jìn)行監(jiān)聽(tīng)
* ScrollView的滾動(dòng)Y值進(jìn)行監(jiān)聽(tīng)
*/
public class MyScrollView extends ScrollView {
private OnScrollListener onScrollListener;
/**
* 主要是用在用戶(hù)手指離開(kāi)MyScrollView,MyScrollView還在繼續(xù)滑動(dòng),我們用來(lái)保存Y的距離,然后做比較
*/
private int lastScrollY;
public MyScrollView(Context context) {
super(context, null);
}
public MyScrollView(Context context, AttributeSet attrs) {
super(context, attrs, 0);
}
public MyScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
/**
* 設(shè)置滾動(dòng)接口
* @param onScrollListener
*/
public void setOnScrollListener(OnScrollListener onScrollListener){
this.onScrollListener = onScrollListener;
}
/**
* 用于用戶(hù)手指離開(kāi)MyScrollView的時(shí)候獲取MyScrollView滾動(dòng)的Y距離,然后回調(diào)給onScroll方法中
*/
private Handler handler = new Handler() {
public void handleMessage(android.os.Message msg) {
int scrollY = MyScrollView.this.getScrollY();
//此時(shí)的距離和記錄下的距離不相等,在隔5毫秒給handler發(fā)送消息
if(lastScrollY != scrollY){
lastScrollY = scrollY;
handler.sendMessageDelayed(handler.obtainMessage(), 5);
}
if(onScrollListener != null){
onScrollListener.onScroll(scrollY);
}
};
};
/**
* 重寫(xiě)onTouchEvent, 當(dāng)用戶(hù)的手在MyScrollView上面的時(shí)候,
* 直接將MyScrollView滑動(dòng)的Y方向距離回調(diào)給onScroll方法中,當(dāng)用戶(hù)抬起手的時(shí)候,
* MyScrollView可能還在滑動(dòng),所以當(dāng)用戶(hù)抬起手我們隔5毫秒給handler發(fā)送消息,在handler處理
* MyScrollView滑動(dòng)的距離
*/
@Override
public boolean onTouchEvent(MotionEvent ev) {
if(onScrollListener != null){
onScrollListener.onScroll(lastScrollY = this.getScrollY());
}
switch(ev.getAction()){
case MotionEvent.ACTION_UP:
handler.sendMessageDelayed(handler.obtainMessage(), 20);
break;
}
return super.onTouchEvent(ev);
}
/**
* 滾動(dòng)的回調(diào)接口
*/
public interface OnScrollListener{
/**
* 回調(diào)方法, 返回MyScrollView滑動(dòng)的Y方向距離
*/
public void onScroll(int scrollY);
}
} 二、定義簡(jiǎn)單布局
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <com.willen.topFloatDemo.MyScrollView android:id="@+id/myScrollView" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" > <RelativeLayout android:id="@+id/rlayout" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" > <TextView android:id="@+id/tv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:gravity="center_vertical" android:text="頂部信息\n頂部信息\n頂部信息\n頂部信息" android:textSize="40dp" /> </RelativeLayout> <LinearLayout android:id="@+id/search02" android:layout_width="match_parent" android:layout_height="40dip" android:orientation="vertical" > <EditText android:id="@+id/search_edit" android:layout_width="match_parent" android:layout_height="40dip" android:background="@drawable/bg_edittext" android:hint="請(qǐng)輸入..." android:padding="5dip" android:singleLine="true" android:textColorHint="#AAAAAA" android:textSize="15dip" /> </LinearLayout> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" android:text="測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容\n測(cè)試內(nèi)容" android:textSize="40dp" /> </LinearLayout> </com.willen.topFloatDemo.MyScrollView> <LinearLayout android:id="@+id/search01" android:layout_width="match_parent" android:layout_height="40dip" android:orientation="vertical" > </LinearLayout> </RelativeLayout>
三、MainActivity
package com.willen.topFloatDemo;
import android.app.Activity;
import android.os.Bundle;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import com.willen.topFloatDemo.MyScrollView.OnScrollListener;
public class MainActivity extends Activity implements OnScrollListener{
private EditText search_edit;
private MyScrollView myScrollView;
private int searchLayoutTop;
LinearLayout search01,search02;
RelativeLayout rlayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//初始化控件
init();
}
private void init() {
search_edit = (EditText)findViewById(R.id.search_edit);
myScrollView = (MyScrollView)findViewById(R.id.myScrollView);
search01 = (LinearLayout)findViewById(R.id.search01);
search02 = (LinearLayout)findViewById(R.id.search02);
rlayout = (RelativeLayout)findViewById(R.id.rlayout);
myScrollView.setOnScrollListener(this);
}
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
if(hasFocus){
searchLayoutTop = rlayout.getBottom();//獲取searchLayout的頂部位置
}
}
//監(jiān)聽(tīng)滾動(dòng)Y值變化,通過(guò)addView和removeView來(lái)實(shí)現(xiàn)懸停效果
@Override
public void onScroll(int scrollY) {
if(scrollY >= searchLayoutTop){
if (search_edit.getParent()!=search01) {
search02.removeView(search_edit);
search01.addView(search_edit);
}
}else{
if (search_edit.getParent()!=search02) {
search01.removeView(search_edit);
search02.addView(search_edit);
}
}
}
}
代碼中均有注釋?zhuān)瑧?yīng)該不用再多解釋了。
本文源碼下載:Android實(shí)現(xiàn)向上滑動(dòng)控件頂部懸浮效果
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android Support Annotations資料整理
這篇文章主要介紹了Android Support Annotations資料整理的相關(guān)資料,需要的朋友可以參考下2017-05-05
Android基于wheelView實(shí)現(xiàn)自定義日期選擇器
這篇文章主要為大家詳細(xì)介紹了Android基于wheelView實(shí)現(xiàn)自定義日期選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07
淺談Android Classloader動(dòng)態(tài)加載分析
這篇文章主要介紹了淺談Android Classloader動(dòng)態(tài)加載分析,詳細(xì)的介紹了ClassLoader概念、分類(lèi),具有一定的參考價(jià)值,有興趣的可以了解一下2018-03-03
簡(jiǎn)單實(shí)現(xiàn)android短信發(fā)送器
這篇文章主要為大家詳細(xì)介紹了如何簡(jiǎn)單實(shí)現(xiàn)android短信發(fā)送器 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
Android實(shí)現(xiàn)雙向滑動(dòng)特效的實(shí)例代碼
這篇文章主要介紹了Android實(shí)現(xiàn)雙向滑動(dòng)特效的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,一起跟隨小編過(guò)來(lái)看看吧2018-05-05
Android開(kāi)發(fā)自學(xué)筆記(一):Hello,world!
這篇文章主要介紹了Android開(kāi)發(fā)自學(xué)筆記(一):Hello,world!本文講解了創(chuàng)建HelloWorld工程、編寫(xiě)代碼、啟動(dòng)模擬器等步驟,需要的朋友可以參考下2015-04-04
Android實(shí)現(xiàn)二級(jí)列表購(gòu)物車(chē)功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)二級(jí)列表購(gòu)物車(chē)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
MPAndroidChart繪制自定義運(yùn)動(dòng)數(shù)據(jù)圖表示例詳解
這篇文章主要為大家介紹了MPAndroidChart繪制自定義運(yùn)動(dòng)數(shù)據(jù)圖表示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Android 中在有序廣播中添加自定義權(quán)限的實(shí)例
這篇文章主要介紹了Android 中在有序廣播中添加自定義權(quán)限的實(shí)例的相關(guān)資料,這里對(duì)有序廣播的用法進(jìn)行了詳細(xì)介紹并附有簡(jiǎn)單實(shí)例,需要的朋友可以參考下2017-07-07

