`

Android中Listview的平滑滚动(smoothScrollToPositionFromTop方法)

阅读更多

项目中有一个需求

用户点击某一个按钮,listview滚动到指定的位置的item,需要的效果是平滑的滑动

研究了一下listview,在真机和模拟器上都试了一下(小米4,系统为6.0)模拟器系统为(4.0.3)

代码如下

 

package org.dengzh;

import java.util.ArrayList;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.ListAdapter;
import android.widget.ListView;

/**
 * 
 * @author dengzh
 * 
 */
public class MainActivity extends Activity implements View.OnClickListener {

	private ListView lv;
	private ImageView iv_back_top;
	private ArrayList<String> list = new ArrayList<String>();
	//private boolean isBackTop = false;
	private Animation fadeInAnim;
	private Animation fadeOutAnim;
	private Button position_1, position_2, position_3;

	//记录当前要滚动的目标位置
	private int curScrollToPosition = 0;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		init();
	}

	private void init() {
		fadeInAnim = AnimationUtils.loadAnimation(this, R.anim.anim_fade_in);
		fadeInAnim.setFillAfter(true);
		fadeOutAnim = AnimationUtils.loadAnimation(this, R.anim.anim_fade_out);
		fadeOutAnim.setFillAfter(true);

		position_1 = (Button) findViewById(R.id.position_1);
		position_2 = (Button) findViewById(R.id.position_2);
		position_3 = (Button) findViewById(R.id.position_3);

		lv = (ListView) findViewById(R.id.lv);
		iv_back_top = (ImageView) findViewById(R.id.iv_back_top);

		for (int i = 0; i < 999; i++) {
			list.add(i + "");
		}
		ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
				android.R.layout.simple_list_item_1, list);
		lv.setAdapter(adapter);

		lv.setOnScrollListener(new AbsListView.OnScrollListener() {

			@Override
			public void onScrollStateChanged(AbsListView view, int scrollState) {

				//处理滚动条滚动停止时
				if (scrollState == SCROLL_STATE_IDLE) {
					Log.d("android", "SCROLL_STATE_IDLE");
					//判断是否滚动到了第0项,如果是,就隐藏 右下角的 图标,
                                        //如果不是,那么显示
					if (lv.getFirstVisiblePosition() == 0) {
						if (iv_back_top.getVisibility() == View.VISIBLE) {
							iv_back_top.startAnimation(fadeOutAnim);
							iv_back_top.setVisibility(View.GONE);
						}
					} else {
						if (iv_back_top.getVisibility() == View.GONE) {
							iv_back_top.setVisibility(View.VISIBLE);
							iv_back_top.startAnimation(fadeInAnim);
						}
					}
					
					//如果当前滚动的目标位置不为-1,也就是说这是由点击按钮触发的自动滚动,
                                        //那么最后定位到对应的curScrollPosition
					if (curScrollToPosition != -1) {
						lv.setSelection(curScrollToPosition);
					}
					//最后把curScrollToPosition置为-1, 这样不这样做,那么当自动定位结束后,
                                        //再去用手指滑动listview,当滑动结束后,listview在这里仍然会自动定位到上一个curScrollPosition去
					curScrollToPosition = -1;
				}
			}

			@Override
			public void onScroll(AbsListView view, int firstVisibleItem,
					int visibleItemCount, int totalItemCount) {

			}
		});
		lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
			@Override
			public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
					long arg3) {
				Log.d("android", arg3 + "");
			}
		});

		iv_back_top.setOnClickListener(this);

		position_1.setOnClickListener(this);
		position_2.setOnClickListener(this);
		position_3.setOnClickListener(this);

	}

	@Override
	public void onClick(View v) {
		int position = 0;
		switch (v.getId()) {
		case R.id.iv_back_top:
			//返回顶端
			//smoothScrollToPositionFromTop我在手机(小米4)和模拟器(4.0.3)上测了很久
			//手机上完全没有问题,但是模拟器上的话,如果position的位置很大,比较要滚动到900,那么有时候会滚动到一半停止了,并没有最终滚动到900的位置
			//所以这里用curScrollPosition保存了滚动的目标位置,在onScrollStateChanged监听中,当滚动样状态为停止时,再调用lv.setSelection(curScrollToPosition)来最终再一次将listview的位置定位到目标位置
			//smoothScrollToPositionFromTop中的第二个参数,我看文档中的意思为Desired distance in pixels of position from the top of the view when scrolling is finished
			//理解为当滚动停止时,当前定位的这个item,距离top的距离是多少,我在这儿设置为0
			lv.smoothScrollToPositionFromTop(0, 0, 5000);
			break;
		case R.id.position_1:
			position = Integer.parseInt(position_1.getTag().toString());
			curScrollToPosition = position;
			lv.smoothScrollToPositionFromTop(position, 0, 5000);
			break;
		case R.id.position_2:
			position = Integer.parseInt(position_2.getTag().toString());
			curScrollToPosition = position;
			lv.smoothScrollToPositionFromTop(position, 0, 5000);
			break;
		case R.id.position_3:
			position = Integer.parseInt(position_3.getTag().toString());
			curScrollToPosition = position;
			lv.smoothScrollToPositionFromTop(position, 0, 5000);

			break;
		}

	}

}

smoothScrollToPositionFromTop我在手机(小米4)和模拟器(4.0.3)上测了很久

手机上完全没有问题,但是模拟器上的话,如果position的位置很大,比较要滚动到900,那么有时候会滚动到一半停止了,并没有最终滚动到900的位置

所以这里用curScrollPosition保存了滚动的目标位置,在onScrollStateChanged监听中,当滚动样状态为停止时,再调用lv.setSelection(curScrollToPosition)来最终再一次将listview的位置定位到目标位置

smoothScrollToPositionFromTop中的第二个参数,我看文档中的意思为Desired distance in pixels of position from the top of the view when scrolling is finished

理解为当滚动停止时,当前定位的这个item,距离top的距离是多少,我在这儿设置为0

 

 

效果图如下



 

 

  • 大小: 2.6 MB
分享到:
评论

相关推荐

    listview点击居中

    - 可以通过`ListView.smoothScrollToPositionFromTop(int position, int offset)`方法实现平滑滚动到指定位置,并指定偏移量,使得点击项居中。 4. **计算居中位置** - 首先,我们需要知道ListView的高度以及每个...

    Android ListView城市列表,按a-z分组字母索引排序

    6. **Smooth Scrolling**:为了让用户体验更佳,可以使用ListView的smoothScrollToPositionFromTop方法,平滑地滚动到指定位置,而不是瞬间跳转。 7. **自定义Adapter**:可能需要自定义Adapter类,扩展BaseAdapter...

    Android应用源码ListView 实现点击侧边A-Z快速查找.zip

    实现这个功能可以通过监听SideBarView的点击事件,并使用ListView的smoothScrollToPositionFromTop方法来平滑滚动到对应位置。 在Adapter中,我们需要为每个数据项计算其对应的字母索引。这通常涉及到对数据进行...

    Android listview字母A-z排序,标题栏停靠

    你可以使用ListView的smoothScrollToPositionFromTop()方法来实现平滑滚动。 4. 实现标题栏停靠,即当用户滚动到以特定字母开头的数据时,SideBar中的相应字母自动高亮。这可以通过监听ListView的OnScrollListener...

    安卓Android源码——ListView 实现点击侧边A-Z快速查找.zip

    当用户点击快速查找栏中的字母时,根据首字母与当前可视区域的关系,计算出滚动的距离,然后调用ListView的smoothScrollToPositionFromTop()方法进行平滑滚动。 4. **数据排序**: 数据集应当预先按照首字母排序,...

    ListView快速索引 通讯录快速定位

    为了实现ListView的平滑滚动,我们可以使用smoothScrollToPositionFromTop方法。此外,还可以结合HeaderView和FooterView来完善整个界面,使索引栏与ListView内容区分离,提升视觉效果。 另外,考虑到性能优化,...

    listview以动画方式出现

    - SmoothScroller是一个帮助ListView平滑滚动到指定位置的工具,可以配合AbsListView的`smoothScrollToPositionFromTop()`方法使用。 - Fling动画则模拟了用户快速滑动屏幕的动作,通过`AbsListView.startScroll()...

    listview头部固定和右侧字母导航

    5. **同步字母栏和列表**:当用户点击字母栏时,调用ListView的`smoothScrollToPositionFromTop()`方法,让列表平滑滚动到对应位置。 `PinnedHeaderListView`库是一个专门为实现头部固定和字母导航而设计的第三方...

    ListView 实现点击侧边A-Z快速查找.zip

    同时,为了提供更好的用户体验,可以添加平滑滚动动画。 9. **代码示例**: 压缩包中的"ListView 实现点击侧边A-Z快速查找"很可能是一个包含源代码的文件,可以作为实际操作的参考。打开这个文件,查看并理解代码...

    android list带索引

    5. **触摸事件监听**:当用户点击索引栏的某个字母时,需要监听触摸事件,然后调用ListView的`smoothScrollToPositionFromTop()`方法,平滑滚动到相应位置。 6. **过滤搜索**:为了实现搜索功能,可以添加一个搜索...

    A-Z索引排序

    5. **监听器处理**:设置监听器监听侧滑菜单的点击事件,当用户点击某个字母时,调用ListView的`smoothScrollToPositionFromTop()`方法,平滑滚动到对应位置。 6. **优化性能**:由于ListView通常需要处理大量数据...

    android 本地通讯录列表滑动+侧边字母导航栏

    例如,可以使用`AbsListView#smoothScrollToPositionFromTop()`方法实现平滑滚动,同时配合颜色过渡动画实现导航栏的高亮效果。 6. **性能优化**: - 由于通讯录可能包含大量数据,为了避免一次性加载造成内存压力...

    ExpandableListView,扩展ListView

    6. **动画效果**:如果需要,可以添加展开和折叠的动画效果,通过`ExpandableListView`的`setGroupIndicator()`和`setChildIndicator()`方法设置指示器,或者通过`smoothScrollToPositionFromTop()`实现平滑滚动。...

    Android-联系人A-Z索引列表

    可以使用`smoothScrollToPositionFromTop()`或`smoothScrollToPosition()`方法实现。 6. **动态标题更新**: 使用`OnScrollListener`监听列表的滚动事件,当滚动到新的字母开头的联系人时,更新顶部的标题。 7. **...

    安卓Android源码——expandableList扩展列表.zip

    可以添加动画效果来增强用户体验,例如使用`smoothScrollToPositionFromTop()`平滑滚动到特定位置,或者自定义展开/折叠动画。 8. **源码分析** 压缩包中的“源码说明.txt”很可能是对示例代码的解释,可能包括...

Global site tag (gtag.js) - Google Analytics