Android RecyclerView 布局编辑后滚动不起作用

问题描述 投票:0回答:2

我正在尝试在另一个RecyclerView中实现水平滚动RecyclerView,这意味着父RecyclerView(垂直滚动)和子RecyclerView(水平滚动)位于父RecyclerView中。我提到了有关此要求的几个问题,并从这个问题How to have a ListView/RecyclerView inside a Parent RecyclerView? 找到了更好的解决方案,并成功实施。 子适配器的布局文件编辑后,子 RecyclerView 的滚动被禁用。

这是我的代码, 这是父片段。

public class MarketFragment extends Fragment {

private String log = "abcpappaHomeFragment";
private Button loadMore ;
private ArrayList<ProductCategoryBean> productCategoryList=null;
private ProductCategoryService productCategoryService;
private RecyclerView.Adapter mAdapter;
private RecyclerView mRecyclerView;
private LinearLayoutManager mLayoutManager;

public MarketFragment() {
    // Required empty public constructor
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {

    productCategoryService = new ProductCategoryService();
    productCategoryList =(ArrayList<ProductCategoryBean>)productCategoryService.getAllCategories();
    View rootView = inflater.inflate(R.layout.market_fragment, container, false);
    mRecyclerView = (RecyclerView)rootView.findViewById(R.id.market_recycle_list);
    mRecyclerView.setHasFixedSize(true);
    mLayoutManager = new LinearLayoutManager(getContext());
    mRecyclerView.setLayoutManager(mLayoutManager);
    mAdapter = new MarketRecyclerAdapter(getContext(),productCategoryList,this);
    mRecyclerView.setAdapter(mAdapter);
    return rootView;

}

@Override
public void onAttach(Activity activity) {
    super.onAttach(activity);
}

@Override
public void onDetach() {
    super.onDetach();
}
}

这是布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:tools="http://schemas.android.com/tools"
tools:context="bodhiinfo.abcpappa.activity.MarketFragment">>

<android.support.v7.widget.RecyclerView
    android:id="@+id/market_recycle_list"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="4dp" />

父 RecyclerView 的适配器类

public class MarketRecyclerAdapter extends RecyclerView.Adapter<MarketRecyclerAdapter.ViewHolder> {

private Context context;
private List<ProductCategoryBean> productCategoryList=null;
private List<ProductBean> productDetailList=null;
private RecyclerView.Adapter mAdapter;
public MarketFragment marketFragment;
// private marketList


public  MarketRecyclerAdapter(Context context,List<ProductCategoryBean> productCategoryList,MarketFragment marketFragment){
    this.context = context;
    this.productCategoryList =(ArrayList<ProductCategoryBean>)  productCategoryList;
    this.marketFragment = marketFragment;
    }

@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

    View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.market_fragment_row, parent, false);
    ViewHolder viewHolder = new ViewHolder(v,context);
    return viewHolder;
    }

@Override
public void onBindViewHolder(ViewHolder viewHolder, int position) {

    ProductCategoryBean productCategoryBean =(ProductCategoryBean)productCategoryList.get(position);

    viewHolder.product_category_name_id.setText(productCategoryBean.getUtxt_product_category());
    ProductService productService = new ProductService();
    productDetailList = (ArrayList<ProductBean>)productService.getProductDetailsByCategoryId(productCategoryBean.getPki_product_category_id()+"");
    viewHolder.product_recycle_list.setHasFixedSize(false);
    viewHolder.mLayoutManager = new ChildCustomLinearLayoutManager(context,LinearLayoutManager.HORIZONTAL,false);
    viewHolder.product_recycle_list.setLayoutManager(viewHolder.mLayoutManager);
    mAdapter = new MarketRowRecyclerAdapter(context,productDetailList);
    viewHolder.product_recycle_list.setAdapter(mAdapter);

    }

@Override
public int getItemCount() {
    return productCategoryList.size();
    }

public static class  ViewHolder extends RecyclerView.ViewHolder{

public TextView product_category_name_id;
public RecyclerView product_recycle_list;
public ChildCustomLinearLayoutManager mLayoutManager;
public Context context;

public View view;
public ClipData.Item currentItem;
public ViewHolder(final View itemView,final Context context) {
    super(itemView);
    this.context = context;
    product_category_name_id = (TextView)itemView.findViewById(R.id.product_category_name_id);
    product_recycle_list =(RecyclerView)itemView.findViewById(R.id.product_recycle_list);
    itemView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

        }
    });
}
}
}

父 RecyclerView 适配器的布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="bodhiinfo.abcpappa.activity.MarketFragment">
<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">
    <!-- linear layout for market heading row-->
    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/market_heading_raw"
        android:layout_marginTop="25dp">
        <TextView
            android:id="@+id/product_category_name_id"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/market_heading"
            android:layout_weight="0.7"
            android:layout_gravity="left"
            android:gravity="left"/>
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="View More.."
            android:layout_weight="0.3"
            android:layout_gravity="right"
            android:gravity="right"
            />
    </LinearLayout>
    <android.support.v7.widget.RecyclerView
        android:id="@+id/product_recycle_list"
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

</LinearLayout>
</RelativeLayout>

子 RecyclerView 适配器

 public class MarketRowRecyclerAdapter extends RecyclerView.Adapter<MarketRowRecyclerAdapter.ViewHolder> {

private List<ProductBean> productList;
private Context context;

MarketRowRecyclerAdapter(Context context,List<ProductBean> productList){

   this.productList =(ArrayList<ProductBean>)productList;
   this.context = context;

}


@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View v =  LayoutInflater.from(parent.getContext()).inflate(R.layout.market_product_image_view, parent, false);
    ViewHolder viewHolder = new ViewHolder(v,context);
    return viewHolder;
 }

 @Override
 public void onBindViewHolder(ViewHolder viewHolder, int position) {

    ProductBean productBean=(ProductBean)productList.get(position);
    ImageCacheManager imageCacheManager= ImageCacheManager.INSTANCE;
    ImageLoader imageLoader=imageCacheManager.getImageLoader();
    viewHolder.market_product_image_id.setImageUrl("http://www.ps4home.com/wp-content/uploads/2013/10/Mad-Catz-F.R.E.Q.5-Headset-for-PC-and-Mac-Black.jpg", imageLoader);
    viewHolder.product_text_id.setText(productBean.getTxt_product_name());
    viewHolder.product_actual_price_id.setText("Rs :"+productBean.getTxt_product_actual_price());
    viewHolder.product_actual_price_id.setPaintFlags(viewHolder.product_actual_price_id.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
    viewHolder.product_app_price_id.setText("Rs :" + productBean.getTxt_product_price_in_app());

}

@Override
public int getItemCount() {
    return productList.size();
}

public static class  ViewHolder extends RecyclerView.ViewHolder{

    public TextView product_text_id;
    public TextView product_actual_price_id;
    public TextView product_app_price_id;
    public NetworkImageView market_product_image_id;
    public Context context;

    public View view;
    public ViewHolder(final View itemView,final Context context) {
        super(itemView);
        this.context = context;
        product_text_id = (TextView)itemView.findViewById(R.id.product_text_id);
        product_actual_price_id= (TextView)itemView.findViewById(R.id.product_actual_price_id);
        product_app_price_id= (TextView)itemView.findViewById(R.id.product_app_price_id);
        market_product_image_id = (NetworkImageView)itemView.findViewById(R.id.market_product_image_id);

        itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {

            }
        });
    }
  }
  }

子适配器布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingRight="10dp"
android:paddingLeft="10dp"
tools:context="bodhiinfo.abcpappa.activity.MarketFragment">
    <FrameLayout
        android:id="@+id/market_product1_image_frame_id"
        android:layout_width="150dp"
        android:layout_height="150dp">
        <com.android.volley.toolbox.NetworkImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/market_product_image_id"/>
        <TextView
            android:id="@+id/product_text_id"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textColor="@color/text_light"
            android:layout_gravity="bottom"
            android:text="@string/product_one"
            android:background="@drawable/textbackgrounds"/>
    </FrameLayout>
    <TextView
        android:id="@+id/product_actual_price_id"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textColor="@color/text_dark_black"
        android:text="@string/product_one"
        android:layout_below="@+id/market_product1_image_frame_id"/>
    <TextView
        android:id="@+id/product_app_price_id"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/product_one"
        android:textColor="@color/text_dark_black"
        android:layout_below="@+id/product_actual_price_id"/>
 </LinearLayout>

ChildCustomLinearLayoutManager 与上述问题中 pptang 提供的类相同。 实际上我是android新手,如果你曾经遇到过这种问题,请让我知道我所犯的错误。谢谢大家。

android android-layout android-fragments android-recyclerview
2个回答
3
投票

如果wrap_content并且没有设置明确的最小高度,RecyclerView会根据其子视图调整自身大小。 在您的子 RecyclerView 中,您必须考虑进行如下更改

<android.support.v7.widget.RecyclerView
    android:id="@+id/product_recycle_list"
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

您正在使用水平回收器视图,因此设置

如果您想了解有关此问题的更多信息,请访问 https://code.google.com/p/android/issues/detail?id=74772 它会对你有帮助。


0
投票
<androidx.recyclerview.widget.RecyclerView
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/addUser"
        app:layout_constraintLeft_toLeftOf="parent"

        android:layout_marginTop="20dp"
        android:layout_marginBottom="80dp"
        android:id="@+id/recycleruserDetails"
        app:layout_constraintVertical_bias="0.0"
        android:layout_width="match_parent"
        android:layout_height="0dp" />
© www.soinside.com 2019 - 2024. All rights reserved.