github地址(完整Demo)
https://github.com/zhouxu88/CustomLayoutManager
最近瀏覽github雏搂,發(fā)現(xiàn)了一個特別炫酷的效果藕施,可以用來讓你的APP逼格更高,特此和大家分享一下畔派。
效果圖
自定義LayoutManager.gif
自定義customLayoutManager會幫你處理一部分放置铅碍、回收、以及滾動的邏輯线椰,你只需關(guān)注你想隨著滾動改變的屬性胞谈,他是如何改變的,以及達到哪個值時會被回收即可。所以我們只需要新建一個自己的layoutManager并繼承CustomLayoutManager,在這里先提一下烦绳,CustomLayoutManager有幾個默認的屬性是你可以直接使用的卿捎。
protected Context context;
//子view的寬度
protected int mDecoratedChildWidth;
//子view的高度
protected int mDecoratedChildHeight;
//子view距離屏幕最左的偏移,也可以理解為第一個子view在初始狀態(tài)下距離屏幕左側(cè)的位移径密,默認居中
protected int startLeft;
//子view距離屏幕頂部的位移午阵,默認居中
protected int startTop;
//主要隨滑動所改變的屬性的偏移量,考慮到view的屬性有int,有float所以這邊統(tǒng)一用float表示偏移
protected float offset;
//相鄰兩個子view間享扔,主要隨滑動而改變的屬性的差值(比如隨滑動改變的是view的角度底桂,那么這個值就是各個view之間的角度間隔)
protected float interval;
繼承CustomLayoutManager之后你必須實現(xiàn)這幾個方法
public class MyLayoutManager extends CustomLayoutManager{
//默認isClockWise為true
public MyLayoutManager(Context context) {
super(context);
}
//isClockWise為true時從左往右排列,不然則從右往左排列
public MyLayoutManager(Context context, boolean isClockWise) {
super(context, isClockWise);
}
//這個方法會設(shè)置默認的interval變量惧眠,之后可以直接使用interval
@Override
protected float setInterval() {
return 0;
}
//初始化方法籽懦,你可以在這里初始化自己的一些參數(shù),比如實現(xiàn)圓弧布局的半徑氛魁,或是更改一些默認的屬性暮顺,比如startLeft,startTop
@Override
protected void setUp() {
}
//itemView就是每一個子view,targetOffset就是其對應(yīng)的將要改變到的屬性值秀存,你可以在這里根據(jù)targetOffset對子view的一些屬性進行設(shè)置
@Override
protected void setItemViewProperty(View itemView, float targetOffset) {
}
}
此外還有6個你可以選擇重寫的方法
//當子view的屬性超過這個值時捶码,就會被回收掉
@Override
protected float maxRemoveOffset() {
return getHorizontalSpace() - startLeft;
}
//當子view的屬性小于這個值時,就會被回收掉
@Override
protected float minRemoveOffset() {
return -mDecoratedChildWidth-getPaddingLeft() - startLeft;
}
//當view的屬性等于targetOffset時或链,此view基于初始位置的x坐標,一般返回targetOffset
@Override
protected int calItemLeftPosition(float targetOffset) {
return targetOffset;
}
//當view的屬性等于targetOffset時惫恼,此view基于初始位置的y坐標,一般返回0
@Override
protected int calItemTopPosition(float targetOffset) {
return 0;
}
//這邊返回在滾動時子view主要改變的屬性的值
@Override
protected float propertyChangeWhenScroll(View itemView) {
return itemView.getLeft()-startLeft;
}
//滑動產(chǎn)生的偏移dx與offset的比例,默認為1
protected float getDistanceRatio(){
return 1f;
}