我可以自定义列表视图滚动条???????
a)拇指应该是可点击和可拖动的。
b)每侧应包含按钮,相应地上下滑动列表视图。
c)滚动条轨道应该更宽。
谢谢。
答案 0 :(得分:0)
要自定义滚动条,您可以使用以下样式。将此样式应用于滚动条。
<style name="your_style_name">
<item name="android:scrollbarAlwaysDrawVerticalTrack">true</item>
<item name="android:scrollbarStyle">outsideOverlay</item>
<item name="android:scrollbars">vertical</item>
<item name="android:fadeScrollbars">false</item>
<item name="android:scrollbarThumbVertical">@drawable/scroller_image</item>
其中scroller_image是滚动箭头的图像。如果要添加上下按钮,可以在Scrollview的上方和下方放置两个按钮。并按钮单击以编程方式滚动滚动条。 为此,您可以使用以下代码,
scrollview.scrollTo(5, 10);
答案 1 :(得分:0)
我解决了这个问题,在ListView上使用OnScrollListener,在VerticalSeekbar上使用OnTouchListener,如下所示:
mListView.setOnScrollListener(this);
mScrollbar.setOnTouchListener(this);
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// TODO Auto-generated method stub
mCurrentPosition = firstVisibleItem;
if (totalItemCount - visibleItemCount > 0) {
int progress = mScrollbar.getMax() * firstVisibleItem
/ (totalItemCount - visibleItemCount);
mScrollbar.setProgress(progress);
}
}
@Override
public boolean onTouch(View v, MotionEvent event) {
Adapter adapter = mListView.getAdapter();
if (adapter == null) {
return false;
}
if (adapter instanceof HeaderViewListAdapter) {
adapter = ((HeaderViewListAdapter) adapter).getWrappedAdapter();
}
int itemCount = adapter.getCount();
if (itemCount == 0)
return false;
switch (event.getActionMasked()) {
case MotionEvent.ACTION_DOWN:
scroll(event.getY());
return true;
case MotionEvent.ACTION_MOVE:
scroll(event.getY());
return true;
case MotionEvent.ACTION_UP:
scroll(event.getY());
return true;
default:
return false;
}
}
private void scroll(float height) {
mItemCount = mListView.getAdapter().getCount();
int scrollHeight = mScrollbar.getHeight();
Log.e(TAG, "Scrollbar height: " + scrollHeight);
int position = (int) ((height / mScrollbar.getHeight()) * mItemCount);
Log.e(TAG, "Position scroll: " + position);
if (position < 0)
position = 0;
else if (position >= mItemCount)
position = mItemCount - 1;
mListView.setSelection(position);
}