项目中有一个需求
用户点击某一个按钮,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
效果图如下
相关推荐
- 可以通过`ListView.smoothScrollToPositionFromTop(int position, int offset)`方法实现平滑滚动到指定位置,并指定偏移量,使得点击项居中。 4. **计算居中位置** - 首先,我们需要知道ListView的高度以及每个...
6. **Smooth Scrolling**:为了让用户体验更佳,可以使用ListView的smoothScrollToPositionFromTop方法,平滑地滚动到指定位置,而不是瞬间跳转。 7. **自定义Adapter**:可能需要自定义Adapter类,扩展BaseAdapter...
实现这个功能可以通过监听SideBarView的点击事件,并使用ListView的smoothScrollToPositionFromTop方法来平滑滚动到对应位置。 在Adapter中,我们需要为每个数据项计算其对应的字母索引。这通常涉及到对数据进行...
你可以使用ListView的smoothScrollToPositionFromTop()方法来实现平滑滚动。 4. 实现标题栏停靠,即当用户滚动到以特定字母开头的数据时,SideBar中的相应字母自动高亮。这可以通过监听ListView的OnScrollListener...
当用户点击快速查找栏中的字母时,根据首字母与当前可视区域的关系,计算出滚动的距离,然后调用ListView的smoothScrollToPositionFromTop()方法进行平滑滚动。 4. **数据排序**: 数据集应当预先按照首字母排序,...
为了实现ListView的平滑滚动,我们可以使用smoothScrollToPositionFromTop方法。此外,还可以结合HeaderView和FooterView来完善整个界面,使索引栏与ListView内容区分离,提升视觉效果。 另外,考虑到性能优化,...
- SmoothScroller是一个帮助ListView平滑滚动到指定位置的工具,可以配合AbsListView的`smoothScrollToPositionFromTop()`方法使用。 - Fling动画则模拟了用户快速滑动屏幕的动作,通过`AbsListView.startScroll()...
5. **同步字母栏和列表**:当用户点击字母栏时,调用ListView的`smoothScrollToPositionFromTop()`方法,让列表平滑滚动到对应位置。 `PinnedHeaderListView`库是一个专门为实现头部固定和字母导航而设计的第三方...
同时,为了提供更好的用户体验,可以添加平滑滚动动画。 9. **代码示例**: 压缩包中的"ListView 实现点击侧边A-Z快速查找"很可能是一个包含源代码的文件,可以作为实际操作的参考。打开这个文件,查看并理解代码...
5. **触摸事件监听**:当用户点击索引栏的某个字母时,需要监听触摸事件,然后调用ListView的`smoothScrollToPositionFromTop()`方法,平滑滚动到相应位置。 6. **过滤搜索**:为了实现搜索功能,可以添加一个搜索...
5. **监听器处理**:设置监听器监听侧滑菜单的点击事件,当用户点击某个字母时,调用ListView的`smoothScrollToPositionFromTop()`方法,平滑滚动到对应位置。 6. **优化性能**:由于ListView通常需要处理大量数据...
例如,可以使用`AbsListView#smoothScrollToPositionFromTop()`方法实现平滑滚动,同时配合颜色过渡动画实现导航栏的高亮效果。 6. **性能优化**: - 由于通讯录可能包含大量数据,为了避免一次性加载造成内存压力...
6. **动画效果**:如果需要,可以添加展开和折叠的动画效果,通过`ExpandableListView`的`setGroupIndicator()`和`setChildIndicator()`方法设置指示器,或者通过`smoothScrollToPositionFromTop()`实现平滑滚动。...
可以使用`smoothScrollToPositionFromTop()`或`smoothScrollToPosition()`方法实现。 6. **动态标题更新**: 使用`OnScrollListener`监听列表的滚动事件,当滚动到新的字母开头的联系人时,更新顶部的标题。 7. **...
可以添加动画效果来增强用户体验,例如使用`smoothScrollToPositionFromTop()`平滑滚动到特定位置,或者自定义展开/折叠动画。 8. **源码分析** 压缩包中的“源码说明.txt”很可能是对示例代码的解释,可能包括...