Android中实现监听ScrollView滑动事件
程序员文章站
2022-04-30 22:43:20
时候我们需要监听scroview的滑动情况,比如滑动了多少距离,是否滑到布局的顶部或者底部。可惜的是sdk并没有相应的方法,不过倒是提供了一个
复制代码 代码如下:...
时候我们需要监听scroview的滑动情况,比如滑动了多少距离,是否滑到布局的顶部或者底部。可惜的是sdk并没有相应的方法,不过倒是提供了一个
复制代码 代码如下:
protected void onscrollchanged(int x, int y, int oldx, int oldy)
方法,显然这个方法是不能被外界调用的,因此就需要把它暴露出去,方便使用。解决方式就是写一个接口,
复制代码 代码如下:
package com.example.demo1;
public interface scrollviewlistener {
void onscrollchanged(observablescrollview scrollview, int x, int y, int oldx, int oldy);
}
然后重写scrollview类,给它提供上面写的回调接口。
复制代码 代码如下:
package com.example.demo1;
import android.content.context;
import android.util.attributeset;
import android.widget.scrollview;
public class observablescrollview extends scrollview {
private scrollviewlistener scrollviewlistener = null;
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);
}
public void setscrollviewlistener(scrollviewlistener scrollviewlistener) {
this.scrollviewlistener = scrollviewlistener;
}
@override
protected 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);
}
}
}
注意在xml布局的时候,不要写错了包。
复制代码 代码如下:
<linearlayout 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"
android:orientation="horizontal"
android:paddingbottom="@dimen/activity_vertical_margin"
android:paddingleft="@dimen/activity_horizontal_margin"
android:paddingright="@dimen/activity_horizontal_margin"
android:paddingtop="@dimen/activity_vertical_margin"
tools:context=".mainactivity" >
<com.example.demo1.observablescrollview
android:id="@+id/view1"
android:layout_width="wrap_content"
android:layout_height="match_parent" >
<linearlayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="vertical" >
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试1" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试2" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试3" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试4" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试5" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试6" />
</linearlayout>
</com.example.demo1.observablescrollview>
<com.example.demo1.observablescrollview
android:id="@+id/view2"
android:layout_width="wrap_content"
android:layout_height="match_parent" >
<linearlayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="vertical" >
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试1" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试2" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试3" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试4" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试5" />
<textview
android:layout_width="100dp"
android:layout_height="100dp"
android:text="试试6" />
</linearlayout>
</com.example.demo1.observablescrollview>
</linearlayout>
最后activity代码如下,
复制代码 代码如下:
package com.example.demo1;
import android.os.bundle;
import android.app.activity;
import android.view.menu;
public class mainactivity extends activity implements scrollviewlistener {
private observablescrollview scrollview1 = null;
private observablescrollview scrollview2 = null;
@override
protected void oncreate(bundle savedinstancestate) {
super.oncreate(savedinstancestate);
setcontentview(r.layout.activity_main);
scrollview1 = (observablescrollview) findviewbyid(r.id.view1);
scrollview1.setscrollviewlistener(this);
scrollview2 = (observablescrollview) findviewbyid(r.id.view2);
scrollview2.setscrollviewlistener(this);
}
@override
public boolean oncreateoptionsmenu(menu menu) {
// inflate the menu; this adds items to the action bar if it is present.
getmenuinflater().inflate(r.menu.main, menu);
return true;
}
@override
public void onscrollchanged(observablescrollview scrollview, int x, int y,
int oldx, int oldy) {
if (scrollview == scrollview1) {
scrollview2.scrollto(x, y);
} else if (scrollview == scrollview2) {
scrollview1.scrollto(x, y);
}
}
}
下一篇: 抖音怎么配音说话(给抖音视频配音的方法)
推荐阅读
-
Android中Toolbar随着ScrollView滑动透明度渐变效果实现
-
Android中实现滑动的七种方式总结
-
Android中Fab(FloatingActionButton)实现上下滑动的渐变效果
-
Android开发之Button事件实现与监听方法总结
-
android中Glide实现加载图片保存至本地并加载回调监听
-
Android中实现滑动的七种方式总结
-
Android中Fab(FloatingActionButton)实现上下滑动的渐变效果
-
Android开发之Button事件实现与监听方法总结
-
Android中RecyclerView实现滑动删除与拖拽功能
-
Android实现美团、大众点评的购买悬浮效果(ScrollView滚动监听)