亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

計算realPosition的問題

int realPosition= position - mPositions.get(viewType);?

如果position為0, mPositions根據當前類型獲取的集合的長度, ?它們一減,肯定是一個負數啊,為什么在下面List直接使用沒有報索引越界,?

正在回答

4 回答

我自己寫了個demo,那個方法是:

private?void?addTypeByList(int?type,?List?list)?{
???positions.put(type,?types.size());
???for?(int?i?=?0;?i?<?list.size();?i++)?{
???????types.add(type);
???}
}

因為第一次加list1的時候,types.size()=0,所以不會出現負數的情況。

1 回復 有任何疑惑可以回復我~

有了個可以兼容數據長度的方法

private List<Object> allList = new ArrayList<>();

在構造方法中或者在add方法中

allList.addAll(dataListOne);
allList.addAll(dataListTwo);
allList.addAll(dataListThree);

在onBindViewHolder方法中

int realPosition = 0;
Object object = allList.get(position);
if(object instanceof DataModelOne){
? ?for (int i=0;i<dataListOne.size();i++){
? ? ? ?if(object == dataListOne.get(i)){
? ? ? ? ? ?realPosition = i;
? ? ? ?}
? ?}
}else if(object instanceof DataModelTwo){
? ?for (int i=0;i<dataListTwo.size();i++){
? ? ? ?if(object == dataListTwo.get(i)){
? ? ? ? ? ?realPosition = i;
? ? ? ?}
? ?}
}else if(object instanceof DataModelThree){
? ?for (int i=0;i<dataListThree.size();i++){
? ? ? ?if(object == dataListThree.get(i)){
? ? ? ? ? ?realPosition = i;
? ? ? ?}
? ?}
}

這樣就能拿到realPosition的位置了

0 回復 有任何疑惑可以回復我~

if(position<10){
? ?realPosition = position - mPosition.get(viewType) +10;
}else if(position>=10 && position<20){
? ?realPosition = position - mPosition.get(viewType);
}else{
? ?realPosition = position - mPosition.get(viewType) -10;
}

這樣可以解決,但是這個方法太局限了,我再找個好點的方法

0 回復 有任何疑惑可以回復我~

我這邊寫的時候,一直是越界的,老師寫的時候我就覺得這里肯定有問題,但是不知道為什么,老師能運行起來

1 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
不一樣的RecyclerView優雅實現復雜列表布局
  • 參與學習       19314    人
  • 解答問題       37    個

教你更快捷簡單的實現復雜列表布局,快來掌握她吧,她等著你哦

進入課程

計算realPosition的問題

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號