Android中自定义ScrollView的滑动监听事件,并在滑动时渐变标题栏背景颜色
2017-03-19 19:58
811 查看
效果图滑动前:滑动中:滑动到底部:项目结构
ObservableScrollView
package com.jukopro.titlebarcolor;import android.content.Context;import android.util.AttributeSet;import android.widget.ScrollView;/*** 自定义带滚动监听的scrollview**/public class ObservableScrollView extends ScrollView {/*** 接口回调*/private ScrollViewListener scrollViewListener = null;public interface ScrollViewListener {void onScrollChanged(ObservableScrollView scrollView, int x, int y,int oldx, int oldy);}public void setScrollViewListener(ScrollViewListener scrollViewListener) {this.scrollViewListener = scrollViewListener;}/*** 重写的onScrollChanged方法监听坐标* 这个监听在源码中没有写成回调的样子,* 只是写成了方法的样子,由于修饰这个方法的修饰符是protected,*(protected只能在本类,子类,同一包中调用),* 所以拿到ScrollView对象后在无法activity中调用此方法,* 所以只能重写后,子类中自动调用,* 所以要想在activity调用,* 就要写回调,* 上面就是我写的回调* 在Android源码中这种写法很多,在很多控件中都有*/@Overrideprotected void onScrollChanged(int x, int y, int oldx, int oldy) {super.onScrollChanged(x, y, oldx, oldy);if (scrollViewListener != null) {scrollViewListener.onScrollChanged(this, x, y, oldx, oldy);}}/***构造方法(在这里没用)*/public ObservableScrollView(Context context) {super(context);}public ObservableScrollView(Context context, AttributeSet attrs,int defStyle) {super(context, attrs, defStyle);}public ObservableScrollView(Context context, AttributeSet attrs) {super(context, attrs);}}activity_main.xml
<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="${relativePackage}.${activityClass}" ><com.jukopro.titlebarcolor.ObservableScrollViewandroid:id="@+id/scrollview"android:layout_width="match_parent"android:layout_height="match_parent"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><ImageViewandroid:id="@+id/imageview"android:layout_width="match_parent"android:layout_height="200dp"android:background="@drawable/zuqiu" /><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:text="我是翟浩浩"android:gravity="center"/></LinearLayout></com.jukopro.titlebarcolor.ObservableScrollView><TextViewandroid:id="@+id/textview"android:layout_width="match_parent"android:layout_height="48dp"android:gravity="center"android:text="我是标题"android:textSize="18sp"android:textColor="#ffffff"android:background="#00000000" /></RelativeLayout>MainActivity
package com.jukopro.titlebarcolor;import android.app.Activity;import android.graphics.Color;import android.os.Bundle;import android.util.Log;import android.view.ViewTreeObserver;import android.view.ViewTreeObserver.OnGlobalLayoutListener;import android.widget.ArrayAdapter;import android.widget.ImageView;import android.widget.ListView;import android.widget.TextView;import com.jukopro.titlebarcolor.ObservableScrollView.ScrollViewListener;public class MainActivity extends Activity {private ObservableScrollView scrollView;private ImageView imageView;private TextView textView;private int imageHeight;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);scrollView = (ObservableScrollView) findViewById(R.id.scrollview);imageView = (ImageView) findViewById(R.id.imageview);textView = (TextView) findViewById(R.id.textview);initListeners();}private void initListeners() {// 获取顶部图片高度后,设置滚动监听ViewTreeObserver vto = imageView.getViewTreeObserver();vto.addOnGlobalLayoutListener(new OnGlobalLayoutListener() {@Overridepublic void onGlobalLayout() {imageView.getViewTreeObserver().removeGlobalOnLayoutListener(this);imageHeight = imageView.getHeight();scrollView.setScrollViewListener(new ScrollViewListener() {@Overridepublic void onScrollChanged(ObservableScrollView scrollView, int x, int y, int oldx, int oldy) {// TODO Auto-generated method stub// Log.i("TAG", "y--->" + y + " height-->" + height);if (y <= 0) {// 设置文字背景颜色,白色textView.setBackgroundColor(Color.argb((int) 0, 255, 255, 255));//AGB由相关工具获得,或者美工提供// 设置文字颜色,黑色textView.setTextColor(Color.argb((int) 0, 255, 255, 255));Log.e("111","y <= 0");} else if (y > 0 && y <= imageHeight) {float scale = (float) y / imageHeight;float alpha = (255 * scale);// 只是layout背景透明(仿知乎滑动效果)白色透明textView.setBackgroundColor(Color.argb((int) alpha, 255, 255, 255));// 设置文字颜色,黑色,加透明度textView.setTextColor(Color.argb((int) alpha, 0, 0, 0));Log.e("111","y > 0 && y <= imageHeight");} else {// 白色不透明textView.setBackgroundColor(Color.argb((int) 255, 255, 255, 255));// 设置文字颜色//黑色textView.setTextColor(Color.argb((int) 255, 0, 0, 0));Log.e("111","else");}}});}});}}源码下载:http://download.csdn.net/detail/zhaihaohao1/9786526
相关文章推荐
- Android 监听ScrollView滑动 实现布局背景、文本颜色渐变
- Android 自定义ScrollView的滑动监听事件
- Android中自定义ScrollView的滑动监听事件
- android 监听webView滑动距离和标题栏颜色渐变
- Android中自定义ListView,解决scrollview嵌套listview 滑动事件冲突
- Android中实现监听ScrollView滑动事件
- 自定义ScrollView 滑动改变背景颜色
- Android 自定义toast总结:纯文本,带图像,带标题栏及自定义背景文字颜色
- Android——ViewPager滑动背景渐变(自定义view,ViewPager)
- Android -- 自定义标题栏,背景颜色填充满
- Android ScrollView滑动实现仿QQ空间标题栏渐变
- android自定义标题栏,解决背景颜色…
- APP实用开发—ScrollView滑动标题栏颜色渐变
- Android 自定义ScrollView嵌套滚动兼容,监听滑动状态:顶部、底部、停止、滑动中
- Android监听ScrollView控件的滑动起始和结束事件
- android标题栏颜色渐变效果的实现(标题栏随着scrollview的滚动而变化)
- Android随着scrollView或者recyclerView滑动状态栏颜色渐变效果
- android 监听标题栏颜色渐变
- android标题栏颜色渐变效果的实现(标题栏随着scrollview的滚动而变化)
- Android 监听手指滑动,Toolbar颜色渐变