亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2017年03月27日 15:21:46   作者:disanxiaoyao  
這篇文章主要為大家詳細介紹了Android仿貼吧內(nèi)容下的簡單ListView嵌套GridView,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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é)束當前事件消費
//      return true;
//    }
//    return super.dispatchTouchEvent(ev);
//  }

   /**
   * 如果是嵌套在ScollView中的,則這樣寫
   * 設(shè)置是否有ScrollBar,當要在ScollView中顯示時,應(yī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) {
//最后一個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é)習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android編程實現(xiàn)攔截短信并屏蔽系統(tǒng)Notification的方法

    Android編程實現(xiàn)攔截短信并屏蔽系統(tǒng)Notification的方法

    這篇文章主要介紹了Android編程實現(xiàn)攔截短信并屏蔽系統(tǒng)Notification的方法,較為詳細的分析了Android短信與Notification的原理及對應(yīng)的設(shè)置取消技巧,需要的朋友可以參考下
    2015-12-12
  • Android實現(xiàn)接近傳感器

    Android實現(xiàn)接近傳感器

    這篇文章主要為大家詳細介紹了Android實現(xiàn)接近傳感器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • Jetpack Compose實現(xiàn)對話框和進度條實例解析

    Jetpack Compose實現(xiàn)對話框和進度條實例解析

    對話框和進度條其實并無多大聯(lián)系,放在一起寫是因為兩者的內(nèi)容都不多,所以湊到一起,對話框是我們平時開發(fā)使用得比較多的組件,進度條的使用頻率也很高,比如下載文件,上傳文件,處理任務(wù)時都可以使用進度條
    2023-04-04
  • flutter InheritedWidget使用方法總結(jié)

    flutter InheritedWidget使用方法總結(jié)

    這篇文章主要為大家介紹了flutter InheritedWidget使用方法總結(jié)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • Android開發(fā)中ListView自定義adapter的封裝

    Android開發(fā)中ListView自定義adapter的封裝

    這篇文章主要為大家詳細介紹了android開發(fā)中ListView自定義adapter的封裝,ListView的模板寫法,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Android 異步任務(wù)和消息機制面試題分析

    Android 異步任務(wù)和消息機制面試題分析

    這篇文章主要為大家介紹了Android 異步任務(wù)和消息機制面試題分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • Android Studio多工程引用同一個library項目配置的解決方法

    Android Studio多工程引用同一個library項目配置的解決方法

    大家在使用android studio的時候,會遇到多個項目引用相同的library這篇文章主要介紹了Android Studio多工程引用同一個library項目配置方法,需要的朋友可以參考下
    2018-03-03
  • android仿百度福袋紅包界面

    android仿百度福袋紅包界面

    雙十一馬上到了,又進入到搶紅包的季節(jié),本篇文章介紹了android仿百度福袋紅包界面,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-11-11
  • Android中ViewPager帶來的滑動卡頓問題解決要點解析

    Android中ViewPager帶來的滑動卡頓問題解決要點解析

    這里我們主要針對ViewGroup的SwipeRefreshLayout中引入ViewPager所引起的滑動沖突問題進行討論,一起來看一下Android中ViewPager帶來的滑動卡頓問題解決要點解析:
    2016-06-06
  • Android App中使用SurfaceView制作多線程動畫的實例講解

    Android App中使用SurfaceView制作多線程動畫的實例講解

    這篇文章主要介紹了Android App中使用SurfaceView制作多線程動畫的實例講解,SurfaceView經(jīng)常被用來制作游戲中的動畫,不過同時要注意畫面閃爍的問題,需要的朋友可以參考下
    2016-04-04

最新評論