国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

Android仿貼吧內(nèi)容下的簡單ListView嵌套GridView

2019-12-12 03:15:57
字體:
供稿:網(wǎng)友

ListView嵌套GridView的簡單實例

我的項目想實現(xiàn)一個listview里面的每個item都嵌套一個GridView,頂部還有主題等內(nèi)容,如

這里寫圖片描述

總所周知,關(guān)于ListView嵌套GridView,最主要問題莫過于嵌套狀態(tài)下滑動沖突問題,具體怎么解決,喜歡冗長無注釋的代碼的,請點擊這里這篇文章跟其他的都大同小異了,不過在缺少注釋的情況下,我發(fā)現(xiàn)了一點點小問題:

/** * 創(chuàng)建日期:2017/3/21. * 說明:構(gòu)造方法會根據(jù)你的SDK最低版本不同而要求不同,如18的至少必須重寫前 * 三個,第四個SDK要求最低21,可以不重寫,但前三個必須寫,否則這個自定義的 * MyGridView 在運用時會報錯; * onMeasure:自定義GridView 控件,實現(xiàn)無法滾動(拖動)的方法 */public class MyGridView extends GridView {  public MyGridView(Context context) {    super(context);  }  public MyGridView(Context context, AttributeSet attrs) {    super(context, attrs);  }  public MyGridView(Context context, AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);  }//public MyGridView(Context context, AttributeSet attrs, int  //defStyleAttr, int defStyleRes) {//    super(context, attrs, defStyleAttr, defStyleRes);//  }  /**   * 重寫測量GridView的內(nèi)容空間(有多少數(shù)據(jù)內(nèi)容)   * @param widthMeasureSpec 占用寬度   * @param heightMeasureSpec 占用高度   */  @Override  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {    // expandSpec:拓展空間,其中MeasureSpec.AT_MOST為“最大模式”    // AT_MOST:最大模式,比喻為布局里的match_parent    // EXACTLY:精確模式,比喻為布局里的"50dp"    // UNSPECIFIED:未指定模式,比喻為布局里的wrap_content    int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);    super.onMeasure(widthMeasureSpec, expandSpec);  }  /**   * 重寫事件分發(fā):因為兩個都是ViewGroup,這個方法不知道是否可行,   * 有興趣的朋友自行腦補   *///  @Override//  public boolean dispatchTouchEvent(MotionEvent ev) {//    if (ev.getAction() == MotionEvent.ACTION_MOVE){//      //返回true直接結(jié)束當(dāng)前事件消費//      return true;//    }//    return super.dispatchTouchEvent(ev);//  }   /**   * 如果是嵌套在ScollView中的,則這樣寫   * 設(shè)置是否有ScrollBar,當(dāng)要在ScollView中顯示時,應(yīng)當(dāng)設(shè)置為   * false。 默認為 true   *///  boolean haveScrollbars = false;//  public void setHaveScrollbar(boolean haveScrollbar) {//    this.haveScrollbar = haveScrollbar;//  }//  @Override//  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {//    if (haveScrollbars == false) {//      int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);//      super.onMeasure(widthMeasureSpec, expandSpec);//    } else {//      super.onMeasure(widthMeasureSpec, heightMeasureSpec);//    }//  }}

上面這個GridView就算自定義好了,接下來我們簡單貼上listview的適配器主要方法getview(…)

 @Override  public View getView(final int position, View convertView, ViewGroup parent) {    ViewHolder holder = null;    if (convertView == null) {      holder = new ViewHolder();      convertView = mInflater.inflate(R.layout.item_lv_gridview, null);      holder.mMyGridView = (MyGridView) convertView.findViewById(R.id.gridView_show_controller);      convertView.setTag(holder);    } else {      holder = (ViewHolder) convertView.getTag();    }//注意:這是重要的地方//鑒于我們想讓每個item下的GridView都能獨立,因此只能通過new 出適配器來//單獨定義每個item,這樣才能讓每個listview的item內(nèi)容都有不同的GridView    DevicesAdapter devicesAdapter = new DevicesAdapter(mContext);    devicesAdapter.setDevicesList(deviceList);    holder.mMyGridView.setAdapter(devicesAdapter);    holder.mMyGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {      @Override      public void onItemClick(AdapterView<?> parent, View view, int position, long id) {//監(jiān)聽最后一個item(position==list.size()-1),//動態(tài)更改其作用功能(比如增加一條數(shù)據(jù),或者blablabla...)        if (position == parent.getCount() - 1) {          mItemListener.onAddClick();        } else {  mItemListener.onDeviceItemClick(deviceList.get(position));        }      }    });    return convertView;  }  static class ViewHolder {    MyGridView mMyGridView;  }

只要再定義GridView的適配器就大功告成了(適配器相信到這時候大家應(yīng)該都很熟了,我就不注釋了哈,請原諒我比較懶)

public class DevicesAdapter extends BaseAdapter {  private final LayoutInflater mInflater;  private ArrayList<DeviceInfos> devicesList;  public DevicesAdapter(Context context) {    mInflater = LayoutInflater.from(context);  }  public void setDevicesList(ArrayList<DeviceInfos> devicesList) {    this.devicesList = devicesList;  }  @Override  public int getCount() {    if (devicesList == null) {      return 1;    }    return devicesList.size() + 1;  }  @Override  public Object getItem(int position) {    return null;  }  @Override  public long getItemId(int position) {    return position;  }  @Override  public View getView(int position, View convertView, ViewGroup parent) {    ViewHolder holder = null;    if (convertView == null) {      convertView = mInflater.inflate(R.layout.item_grid_view, null);      holder = new ViewHolder();      holder.mImageView = (ImageView) convertView.findViewById(R.id.img_controller);      holder.mTextView = (TextView) convertView.findViewById(R.id.tv_controller_name);      convertView.setTag(holder);    } else {      holder = (ViewHolder) convertView.getTag();    }    if (devicesList!=null && position < devicesList.size()) {      String childDeviceName = devicesList.get(position).getChildDeviceName();      holder.mImageView.setImageResource(R.drawable.huajidadi);      holder.mTextView.setText(childDeviceName);    } else {      holder.mImageView.setImageResource(R.drawable.add);      holder.mTextView.setVisibility(View.GONE);    }    return convertView;  }  static class ViewHolder {    ImageView mImageView;    TextView mTextView;  }}

布局我就不給了,就簡單的幾個item的布局,請同學(xué)們自己定義吧…

總結(jié):解決滑動沖突的方法或者涉及點擊、移動等屬性的,用自定義控件再重寫事件分發(fā),可以很好的解決。但是對于同樣是ViewGroup就沒辦法像View的組件那樣,通過調(diào)用onInterceptTouchEvent(MotionEvent ev)進行攔截了,因此只能另尋他法,而這關(guān)鍵就是重寫onMeasure(int widthMeasureSpec, int heightMeasureSpec)這個方法,使得GridView的“控件大小”被固定,這樣就不會與另一個滑動事件沖突了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鹿邑县| 互助| 萝北县| 濮阳市| 武冈市| 丹棱县| 博罗县| 宣城市| 香河县| 青州市| 潼南县| 突泉县| 庄河市| 阿拉善盟| 佛山市| 黄平县| 广东省| 南平市| 四平市| 水城县| 休宁县| 澄江县| 石渠县| 福清市| 郓城县| 曲阳县| 青铜峡市| 五河县| 昌黎县| 庆云县| 泗水县| 宁化县| 辽阳县| 石景山区| 棋牌| 漳州市| 德清县| 香格里拉县| 广河县| 津南区| 托里县|