日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
組件開發(fā)ScrollView嵌套ListContainer滑動問題詳解

想了解更多內(nèi)容,請訪問:

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:域名申請、網(wǎng)絡空間、營銷軟件、網(wǎng)站建設、尼木網(wǎng)站維護、網(wǎng)站推廣。

和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.

ScrollView嵌套ListContainer

就ScrollView嵌套ListContainer的滑動問題,社區(qū)問答中也是遇見了兩次提問的小伙伴。在幫助第一個小伙解決這個問題的時候,我提供了一個思路和以前在寫Android ScrollView嵌套ListView滑動問題的解決方法。經(jīng)過方法的修改也是解決了他的問題,后續(xù)沒有再把這個問題解決的全過程記錄下來,直到發(fā)現(xiàn)有第二個小伙伴也遇到了同樣的問題,準備把這個小問題寫成一篇帖子,希望后面再遇到“ScrollView嵌套ListContainer 滑動問題”的同學可以幫助到你們。

思路

一、ScrollView嵌套ListContainer 想讓ListContainer不滑動,只滑動ScrollView。在Android中有個東西叫做攔截器,ScrollView的攔截器,通過對攔截器的賦值達到只滑動ScrollView,不滑動ListView。

調(diào)用方式

因為ScrollView繼承自ViewGroup,在ViewGroup中有有dispatchTouchEvent()這個方法,

但是在HarmonyOS中,ScrollView繼承自ComponentContainer,而且在ComponentContainer中沒有類似于dispatchTouchEvent的攔截器方法,那么攔截器不能搞就得換方法。

二、這時第二個思路也成型了,因為ScrollView的高度是根據(jù)它內(nèi)部的組件的高度變化的,當內(nèi)部的組件高度大于手機屏幕的高度時會出現(xiàn)ScrollView的滾動,反之不會出現(xiàn)。

那么就只能從ScrollView的高度入手了,要改變ScrollView的高度就必須去改變它內(nèi)部組件的高度,那么問題來了ScrollView嵌套ListContainer,ListContainer的高度最大只能到屏幕大小或者是固定于屏幕內(nèi)部,一旦高度達到所設置的高度,ListContainer就會出現(xiàn)自動滾動此時ScrollView的滾動也會失效,這里是焦點的關(guān)系滑動動作取到的焦點會在它當前組件上。

思路到這里也就清晰了,ListContainer的高度大于原始設置的高度時會發(fā)生滑動,ScrollView在內(nèi)部組件高度大于手機屏幕時才會滑動。那么如果把ListContainer的高度設置成一個動態(tài)的固定值,ListContainer的數(shù)據(jù)永遠不會被填充滿,ListContainer就不會出現(xiàn)滑動。隨即ListContainer的高度如果大于了屏幕的高度ScrollView就會滑動。

OK,問題找到了,解決ListContainer的動態(tài)高度就解決的滑動沖突。

解決問題

首先我找到了當初寫Android時動態(tài)Listview高度的方法。這里就粘一下圖

思路沒有變,將每次listview的Item高度相加作為listview的整體高度,listview的高度就是動態(tài)的變化,listview的高度會根據(jù)數(shù)據(jù)的增加而變化。

根據(jù)參考

下面開始寫代碼

首先整體布局文件,很簡單ScrollView嵌套ListContainer

為了效果明顯加入了一個圖片

 
 
 
 
  1.  
  2.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  3.     ohos:height="match_parent" 
  4.     ohos:width="match_parent"> 
  5.     
  6.         ohos:id="$+id:view" 
  7.         ohos:height="match_parent" 
  8.         ohos:width="match_parent"> 
  9.          
  10.         
  11.             ohos:height="match_parent" 
  12.             ohos:width="match_parent" 
  13.             ohos:alignment="center" 
  14.             ohos:orientation="vertical"> 
  15.             
  16.                 ohos:id="$+id:img" 
  17.                 ohos:height="100vp" 
  18.                 ohos:width="100vp" 
  19.                 ohos:image_src="$media:icon"> 
  20.             
  21.                 ohos:id="$+id:list" 
  22.                 ohos:height="match_parent" 
  23.                 ohos:width="match_parent" 
  24.                 > 
  25.          
  26.      
  27.  

ListContainer的Item 布局,這里很簡單就放一個文本

 
 
 
 
  1.  
  2.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  3.     ohos:height="match_content" 
  4.     ohos:width="match_parent" 
  5.     ohos:left_margin="16vp" 
  6.     ohos:right_margin="16vp" 
  7.     ohos:orientation="vertical"> 
  8.     
  9.         ohos:id="$+id:item_index" 
  10.         ohos:height="match_content" 
  11.         ohos:width="match_content" 
  12.         ohos:padding="4vp" 
  13.         ohos:text="Item0" 
  14.         ohos:text_size="20fp" 
  15.         ohos:layout_alignment="center"/> 
  16.  

 創(chuàng)建SampleItem.java,作為ListContainer的數(shù)據(jù)包裝類。

 
 
 
 
  1. public class SampleItem { 
  2.     private String name; 
  3.     public SampleItem(String name) { 
  4.         this.name = name; 
  5.     } 
  6.     public String getName() { 
  7.         return name; 
  8.     } 
  9.     public void setName(String name) { 
  10.         this.name = name; 
  11.     } 

 寫一個ListContainer的適配器用于放數(shù)據(jù)

 
 
 
 
  1. public class SampleItemProvider extends BaseItemProvider { 
  2.  
  3.     private List list; 
  4.     private AbilitySlice slice; 
  5.  
  6.     public SampleItemProvider(List list, AbilitySlice slice) { 
  7.         this.list = list; 
  8.         this.slice = slice; 
  9.     } 
  10.  
  11.     @Override 
  12.     public int getCount() { 
  13.         return list == null ? 0 : list.size(); 
  14.     } 
  15.  
  16.     @Override 
  17.     public Object getItem(int position) { 
  18.         if (list != null && position >= 0 && position < list.size()){ 
  19.             return list.get(position); 
  20.         } 
  21.         return null; 
  22.     } 
  23.  
  24.     @Override 
  25.     public long getItemId(int position) { 
  26.         return position; 
  27.     } 
  28.  
  29.     @Override 
  30.     public Component getComponent(int position, Component component, ComponentContainer componentContainer) { 
  31.         final Component cpt; 
  32.         if (component == null) { 
  33.             cpt = LayoutScatter.getInstance(slice).parse(ResourceTable.Layout_item_sample, null, false); 
  34.         } else { 
  35.             cpt = component; 
  36.         } 
  37.         SampleItem sampleItem = list.get(position); 
  38.         Text text = (Text) cpt.findComponentById(ResourceTable.Id_item_index); 
  39.         text.setText(sampleItem.getName()); 
  40.         return cpt; 
  41.     } 

在Java代碼中添加ListContainer的數(shù)據(jù),并適配其數(shù)據(jù)結(jié)構(gòu)。

還沒有加動態(tài)高度的方法。

 
 
 
 
  1. public class MainAbilitySlice extends AbilitySlice { 
  2.  
  3.     @Override 
  4.     public void onStart(Intent intent) { 
  5.         super.onStart(intent); 
  6.         super.setUIContent(ResourceTable.Layout_ability_main); 
  7.         initListContainer(); 
  8.     } 
  9.  
  10.     private void initListContainer() { 
  11.         ListContainer listContainer = (ListContainer) findComponentById(ResourceTable.Id_list); 
  12.         List list = getData(); 
  13.         listContainer.setBoundarySwitch(true);  //添加分界線 
  14.         SampleItemProvider sampleItemProvider = new SampleItemProvider(list, this); 
  15.         listContainer.setItemProvider(sampleItemProvider); 
  16.     } 
  17.  
  18.     private ArrayList getData() { 
  19.         ArrayList list = new ArrayList<>(); 
  20.         for (int i = 0; i < 30; i++) { 
  21.             list.add(new SampleItem("Item" + i)); 
  22.         } 
  23.         return list; 
  24.     } 

查看效果

編寫自定義高度方法:

 
 
 
 
  1. private void setListContainerHeight(ListContainer listContainer) { 
  2.         //獲取當前l(fā)istContainer的適配器 
  3.         BaseItemProvider BaseItemProvider = listContainer.getItemProvider(); 
  4.        if (BaseItemProvider == null){ 
  5.            return; 
  6.        } 
  7.         int itemHeight = 0; 
  8.         for (int i = 0; i < BaseItemProvider.getCount(); i++) { 
  9.             //循環(huán)將listContainer適配器的Item數(shù)據(jù)進行累加 
  10.             Component listItem = BaseItemProvider.getComponent(i, null, listContainer); 
  11.             itemHeight += listItem.getHeight(); 
  12.         } 
  13.         //對當前l(fā)istContainer進行高度賦值 
  14.         ComponentContainer.LayoutConfig config = listContainer.getLayoutConfig(); 
  15.         //這邊加上(listContainer.getBoundaryThickness() * (BaseItemProvider.getCount()+1)) 
  16.         //listContainer.getBoundaryThickness() 就是分界線的高度 
  17.         //(BaseItemProvider.getCount()+1) 是Item的數(shù)量  加1  是因為頂部還有一條分界線 
  18.         config.height = itemHeight 
  19.                 + (listContainer.getBoundaryThickness() * (BaseItemProvider.getCount()+1)); 
  20.         //賦值 
  21.         listContainer.setLayoutConfig(config); 
  22.     } 

調(diào)用方法:

實現(xiàn)效果:

出問題了,不能滑動!!!!!!!

找到了,問題在布局中。

重新運行,查看結(jié)果:

OK了,以達到了最終的效果。

代碼放在了下面的資源鏈接里,大家可以進行參考。

FirstDemo.zip

想了解更多內(nèi)容,請訪問:

和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.


網(wǎng)站名稱:組件開發(fā)ScrollView嵌套ListContainer滑動問題詳解
本文鏈接:http://m.5511xx.com/article/djhjdoj.html