自定义控件之android列表分组及字母导航

有了以上两篇文章的重构,现在把ListView分组列表重构为自定义控件就会非常简单,只需要把初始化操作放在自定义控件的构造函数里面。重构后的自定义控件以上一篇的注解重构为基础。

基本结构

这里首先贴上一张上篇文章重构后的activity的代码结构,相关的方法实现在之前两篇文章中都有贴出。


再贴一张重构后的View的结构。可见两者的结构都及其相似。不同的是上边的activity中有抽象方法getDataList(),而下边的没有,但是多了一个ILoadRulerData<T> iLoadData 类型的接口。用于加载数据。


且自定义View中把activity 中initdata()方法改为loaddata(),以供主动调用后开始加载数据。

重构后基本代码如下,省略了一部分和之前重复的代码:

首先是数据加载接口:

public interface ILoadRulerData<T> {
 
    public List<T> getDataList();
   
}


然后是自定义view的基本代码:

/**  
 * @Description: 需要先调用 setiLoadData,设置获取数据的接口,然后再调用  loadData方法
 */
public class RulerView<T> extends LinearLayout{
 
    private View baseView;
    private TextView noDataView;
   
    private TextView RulerTag;
    private ProgressBarWithText progress;
   
    private ListView listView;
   
    private RulerWidget ruler;
 
    private ILoadRulerData<T> iLoadData;
    private List<T> originalList;
    public  List<RulerListDataWrapper<T>> dealedList;
    private HashMap<String, Integer> tagLocation = new HashMap<String, Integer>();
    private RulerAdapter<T> rulerAdapter;
 
    public RulerView(Context context) {
       super(context);
       init( context);
    }
   
    public RulerView(Context context, AttributeSet attrs) {
       super(context, attrs);
       init( context);
    }
   
    public RulerView(Context context, AttributeSet attrs, int defStyle) {
       super(context, attrs);
       init( context);
    }
 
   
    /**  
    * @Description: 设置数据加载接口
    * @param  
    * @return void
    */
    public void setiLoadData(ILoadRulerData<T> iLoadData) {
       this.iLoadData = iLoadData;
    }
 
    private void init(Context context){
       baseView = LayoutInflater.from(context).inflate(R.layout.g_ruler, null);
       noDataView = (TextView) baseView.findViewById(R.id.g_base_list_nodata);
       RulerTag = (TextView) baseView.findViewById(R.id.g_ruler_tag);
       progress = (ProgressBarWithText) baseView.findViewById(R.id.g_base_progressbar_withtext);
       listView = (ListView) baseView.findViewById(R.id.g_base_list);
       ruler = (RulerWidget) baseView.findViewById(R.id.g_ruler);
       progress.setVisibility(View.VISIBLE);
       RulerTag.setVisibility(View.GONE);
       noDataView.setVisibility(View.GONE);
       listView.setVisibility(View.GONE);
       ruler.setVisibility(View.GONE);
       addView(baseView, LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);
    }
   
 
    public void loadData(){
       new GetDataAsyTask().execute();
    }
   
    。。。。。
        }

测试

布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    >
    
   <TextView 
       android:layout_marginTop="10dp"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="wbxtest view"
       android:textColor="@color/g_black"
       />
   <******.ruler.view.RulerView
       android:id="@+id/test_ruler_view_id"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       />
</LinearLayout>

Activity

public class TestViewActivity extends Activity{
 
   
   
    private RulerView<TestAnnotationBo> rulerView;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(R.layout.test_ruler_view);
        rulerView = (RulerView<TestAnnotationBo>) findViewById(R.id.test_ruler_view_id);
        rulerView.setiLoadData(new ILoadRulerData<TestAnnotationBo>() {
          
           @Override
           public List<TestAnnotationBo> getDataList() {
             
              return new TestAnnnoDao().getBoList();
           }
       });
        rulerView.loadData();
      
    }
}

此系列完毕。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。