之前也寫了一個ViewGroup
版本的流式佈局,該流式佈局有兩大優點:可以設定行數和是否內容在該行中居中顯示(猛戳),說真的自從對RecyclerView的LayoutManager有新的認識後,完全不用擔心很多的複雜佈局了。而且對ViewGroup測量過程也不用擔心了,因為裡面有LayoutManager幫我們實現了。下面就進入該篇文章的主題吧,廢話不多說,直接上圖更有說服力。
data:image/s3,"s3://crabby-images/5e27f/5e27f4ab683915f471034e6e00980574f2a58c36" alt="simple.gif"
上面的示例圖是我把ItemView分別用了TextView和ImageView。其實這些是沒什麼好說的,主要是如何定義這樣的LayoutManager。相信大家都用過了LinearLayoutManager吧,系統提供的LayoutManager都是對齊的方式進行排版的,我們這裡的flow的樣式就是在排版item之前,判斷了該行多餘的空間還夠不夠顯示,如果不夠直接換行顯示的思路。
使用:
詳見TextFlowActivity、DiffHeightTextFlowActivity、PhotoFlowActivity
RecyclerView recyclerView = (RecyclerView) findViewById(flow);
FlowLayoutManager flowLayoutManager = new FlowLayoutManager();
//設定每一個item間距
recyclerView.addItemDecoration(new SpaceItemDecoration(dp2px(10)));
recyclerView.setLayoutManager(flowLayoutManager);
recyclerView.setAdapter(new FlowAdapter());
複製程式碼
常見商品屬性介面(RV巢狀RV,item高度為wrap_content):
data:image/s3,"s3://crabby-images/d1577/d1577be401dc96831ac25fb1b65ec3db6256770b" alt="商品屬性介面.gif"
使用:見ProductActivity
常見懸浮商品屬性介面(RV巢狀RV,item高度為wrap_content):
data:image/s3,"s3://crabby-images/e4ec3/e4ec3cf68c3de31f9a78832098507ad094da4e04" alt="懸浮商品屬性介面.gif"
動畫修復問題:
data:image/s3,"s3://crabby-images/a3612/a3612b56df627ab54b823c9d8dc42d478bc88867" alt="動畫演示.gif"
使用:見TextFlowActivity
viewpager中流式佈局應用:
data:image/s3,"s3://crabby-images/2b72b/2b72ba70f0a379f9c7a4512917115cd1fe740dcb" alt="viewpager中流式佈局.gif"
新增RV巢狀RV高度為wrap_content不顯示問題,請使用: NestedRecyclerView
新增長點選進入刪除效果,點選外面進入正常模式:
data:image/s3,"s3://crabby-images/8a94b/8a94b6b3221b734861e5991e07bba5fc6cf2d1d1" alt="長點選刪除介面.gif"
gradle依賴:
all projects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
dependencies {
compile 'com.github.1002326270xc:LayoutManager-FlowLayout:v1.6'
}
複製程式碼
歡迎大家提出問題,留言板留言或郵箱直接聯絡我。我會第一時間測試相關的bug
歡迎客官到本店光臨:184793647
(qq群)
關於我:
email: a1002326270@163.com
csdn:enter
github:enter