Android ListView的滾動條樣式
使用ListView FastScroller,預設滑塊和自定義滑塊圖片的樣子如下兩圖:
設定快速滾動屬性很容易,只需在佈局的xml檔案裡設定屬性即可:
<ListView android:id="@+id/listView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:fastScrollEnabled="true"
android:focusable="true" />
但是有時候會發現設定屬性無效,滾動ListView並未出現滑塊。原因是該屬性生效有最小記錄限制。當ListView記錄能夠在4屏以內顯示(也就是說滾動4頁)就不會出現滑塊。可能是api設計者認為這麼少的記錄不需要快速滾動。
依據是android原始碼,見FastScroller的常量宣告:
// Minimum number of pages to justify showing a fast scroll thumb
private static int MIN_PAGES = 4;
以及:
// Are there enough pages to require fast scroll? Recompute only if total count changes
if (mItemCount != totalItemCount && visibleItemCount > 0) {
mItemCount = totalItemCount;
mLongList = mItemCount / visibleItemCount >= MIN_PAGES;
}
通篇檢視了ListView及其超累AbsListView,都未找到自定義圖片的設定介面。看來是沒打算讓開發者更改了。但是使用者要求我們自定義這個圖片。那隻能用非常手段了。
經過分析發現,該圖片是ListView超類AbsListView的一個成員mFastScroller物件的成員mThumbDrawable。這裡mThumbDrawable是Drawable型別的。mFastScroller是FastScroller型別,這個型別比較麻煩,類的宣告沒有modifier,也就是default(package),只能供包內的類呼叫。
因此反射程式碼寫的稍微麻煩一些:
try {
Field f = AbsListView.class.getDeclaredField("mFastScroller");
f.setAccessible(true);
Object o=f.get(listView);
f=f.getType().getDeclaredField("mThumbDrawable");
f.setAccessible(true);
Drawable drawable=(Drawable) f.get(o);
drawable=getResources().getDrawable(R.drawable.icon);
f.set(o,drawable);
Toast.makeText(this, f.getType().getName(), 1000).show();
} catch (Exception e) {
throw new RuntimeException(e);
}
相關文章
- div滾動條樣式,水平滾動
- 超美的滾動條樣式
- 純css美化滾動條樣式CSS
- css 改變scroll滾動條的樣式CSS
- android之豎直滾動控制元件-ListViewAndroid控制元件View
- css實現修改預設滾動條樣式CSS
- 短視訊平臺搭建,自定義滾動條的樣式
- 直播平臺開發,滾動條樣式的修改和更換
- Flutter可滾動Widgets-ListViewFlutterView
- 直播app系統原始碼,css優化滾動條樣式APP原始碼CSS優化
- 使用 flutter 的ListView實現滾動列表FlutterView
- Flutter 滾動控制元件篇-->ListViewFlutter控制元件View
- Flutter滾動型容器元件 - ListView篇Flutter元件View
- echarts圖表漸變色 、及X軸滾動條樣式處理Echarts
- Android 設定TextView滑動滾動條和滑動效果AndroidTextView
- 一種統計ListView滾動距離的方法View
- Android控制之垂直滾動廣告條ViewFLipper解析AndroidView
- Android——仿淘寶頭條垂直滾動廣告Android
- 隱藏滾動條保留滾動效果
- android中的ListViewAndroidView
- css隱藏滾動條並可以滾動CSS
- CSS滾動條美化CSS
- Xamarin.Forms: 無限滾動的ListView(懶載入方式)ORMView
- 移動端div跟隨滾動條滾動(自制
- 使用js控制滾動條的位置JS
- tbody 滾動條設定
- 表格顯示滾動條
- css隱藏滾動條CSS
- Bootstrap列表新增滾動條boot
- Vue.js 桌面端自定義滾動條元件|vue美化滾動條VScrollVue.js元件
- vue2.x自定義虛擬滾動條|vue美化滾動條元件VscrollVue元件
- element-ui滾動條元件UI元件
- selenium+python 操作滾動條Python
- bootstrap table 橫向滾動條boot
- Tkinter (17) 滾動條部件 Scrollbar
- css實現隱藏滾動條並可以滾動內容CSS
- 瀏覽器滾動條高度的獲取瀏覽器
- Android ScrollView滾動到指定View的位置AndroidView
- div有滾動條 返回頂部