カードビューをrecyclerviewに追加する

oshabz

recyclerviewにcardviewを実装しようとしていますが、cardviewが表示されません。

これが私のコードです

content.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingRight="16dp"
android:paddingLeft="16dp"
android:paddingTop="16dp">


    <android.support.v7.widget.CardView
        android:elevation="3dp"
        android:id="@+id/card"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal">
        <LinearLayout
            android:layout_width="0dp"
            android:layout_weight="4"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <TextView
                android:id="@+id/tvProblems"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentTop="true"
                android:textSize="18dp"
                android:textStyle="bold" />
            <TextView
                android:id="@+id/tvPrice"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentTop="true"
                android:textStyle="bold" />
        </LinearLayout>

        <CheckBox
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/cbProblems"
            android:layout_weight="1" />

        </LinearLayout>

    </android.support.v7.widget.CardView>

MyAdapter.java

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

Context context;
private List<Problems> mDataset;
private static final int TYPE_HEADER = 0;
private static final int TYPE_FOOTER = 1;
private static final int TYPE_ITEM = 2;
private ProblemListener setProblemListener;
CardView cv;
public void setProblemListener(ProblemListener problemListener){
    this.setProblemListener = problemListener;
}
public class ViewHolder extends RecyclerView.ViewHolder{
    public TextView tvProblems, tvPrice;
    public Button btnProblem;
    Button btnSubmitProblem;
    CheckBox cbProblems;
    public ViewHolder(View itemView) {
        super(itemView);
        tvProblems = (TextView) itemView.findViewById(R.id.tvProblems);
        tvPrice = (TextView) itemView.findViewById(R.id.tvPrice);
        btnSubmitProblem = (Button) itemView.findViewById(R.id.btnProblem);
        cbProblems = (CheckBox) itemView.findViewById(R.id.cbProblems);

       overrideFonts(context, tvProblems);
    }
}
private void overrideFonts(final Context context, final View v) {
    try {
        if (v instanceof ViewGroup) {
            ViewGroup vg = (ViewGroup) v;
            for (int i = 0; i < vg.getChildCount(); i++) {
                View child = vg.getChildAt(i);
                overrideFonts(context, child);
            }
        } else if (v instanceof TextView ) {
            ((TextView) v).setTypeface(Typeface.createFromAsset(context.getAssets(), "fonts/RobotoCondensedBold.ttf"));
        }
    } catch (Exception e) {
    }
}

public void add(List<Problems> itemList){
    mDataset = itemList;
    notifyDataSetChanged();
}

public void remove(Problems item){
    int position = mDataset.indexOf(item);
    mDataset.remove(position);
    notifyItemRemoved(position);
}

public MyAdapter(Context con, List<Problems> myDataset){
    mDataset = myDataset;
    this.context = con;
}
@Override
public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {


    View itemView;
    if (viewType == TYPE_ITEM) {
        //Inflating recycle view item layout
        itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.problem_content, parent, false);
        return new ItemViewHolder(itemView);

    } else if (viewType == TYPE_HEADER) {
        //Inflating header view
        itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.problem_recycler_header, parent, false);
        return new HeaderViewHolder(itemView);
    } else if (viewType == TYPE_FOOTER) {
        //Inflating footer view
        itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.problem_recycler_footer, parent, false);
        return new FooterViewHolder(itemView);
    }
    throw new RuntimeException("there is no type that matches the type " + viewType + " + make sure your using types correctly");
}

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

    try {
    if (holder instanceof HeaderViewHolder) {

        HeaderViewHolder headerHolder = (HeaderViewHolder) holder;
        headerHolder.tvHeader.setText("Please kindly ask the mechanic what the problem is and check them to continue");

    } else {
        if (holder instanceof FooterViewHolder) {

            final FooterViewHolder footerHolder = (FooterViewHolder) holder;
            footerHolder.btnSubmitProblem.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                  //  footerHolder.cbProblems.setOnClickListener(null);
                   setProblemListener.onProblemSelected(v, mDataset, position);

                }
            });

        } else if (holder instanceof ItemViewHolder) {
            ItemViewHolder itemView = (ItemViewHolder) holder;
            itemView.tvPrice.setText(mDataset.get(position - 1).getPrice());
            itemView.tvProblems.setText(mDataset.get(position - 1).getProblems());
            itemView.cbProblems.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    mDataset.get(position - 1).setSelected(isChecked);

                }
            });

        }
    }
    } catch (Exception e) {
        e.printStackTrace();
    }
}
@Override
public int getItemCount() {
    return mDataset.size()+2;
}

public int getItemViewType(int position) {

    if (position == 0) {
        return TYPE_HEADER;
    } else if (position == mDataset.size() + 1) {
        return TYPE_FOOTER;
    }
    return TYPE_ITEM;
}

private class HeaderViewHolder extends MyAdapter.ViewHolder {
    TextView tvHeader;

    public HeaderViewHolder(View view) {
        super(view);
        tvHeader = (TextView) view.findViewById(R.id.tvHeader);
        overrideFonts(context, tvHeader);
    }
}

private class FooterViewHolder extends MyAdapter.ViewHolder {
    Button btnSubmitProblem;
    CheckBox cbProblems;


    public FooterViewHolder(View view) {
        super(view);
        btnSubmitProblem = (Button) view.findViewById(R.id.btnProblem);
        cbProblems = (CheckBox) itemView.findViewById(R.id.cbProblems);
    }
}

private class ItemViewHolder extends MyAdapter.ViewHolder {
    TextView tvProblems, tvPrice;

    public ItemViewHolder(View itemView) {
        super(itemView);
        tvProblems = (TextView) itemView.findViewById(R.id.tvProblems);
        tvPrice = (TextView) itemView.findViewById(R.id.tvPrice);
        cv = (CardView)itemView.findViewById(R.id.card);

    }
}

private class CheckboxViewHolder extends MyAdapter.ViewHolder {
    public CheckboxViewHolder(View itemView) {
        super(itemView);
        cbProblems = (CheckBox) itemView.findViewById(R.id.cbProblems);

    }
}
public interface ProblemListener{
    void onProblemSelected(View view, List<Problems> problem, int position);
}

}

recyclerviewのチェックボックスとテキストを膨らませました。カードビューを上げてみましたが、うまくいきませんでした。今必要なのは、recyclerviewの各行をcardviewで区別することです。

Suresh Kumar

LinearLayoutからパディングを削除し、CardViewにマージンを追加してみてください。標高の代わりにcardElevationを使用します。CardViewは、シャドウをレンダリングするためにその周囲にスペースが必要です。

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <android.support.v7.widget.CardView
        app:cardElevation="3dp"
        android:id="@+id/card"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_marginLeft="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginTop="16dp"
        android:layout_marginBottom="3dp">

    </android.support.v7.widget.CardView>
</LinearLayout>

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

Recyclerviewからカードビューを非表示にする方法

分類Dev

recyclerviewからすべてのカードビューを削除してから新しいカードビューを追加-同じカードビューを追加

分類Dev

Android:ビューを削除してrecyclerViewに適切に追加する

分類Dev

カードビューにホバーボタンを追加する方法

分類Dev

カードビューに色付きの境界線を追加する方法は?

分類Dev

カードビューに色付きの境界線を追加する方法は?

分類Dev

アラートビューにカスタムビューを追加する

分類Dev

既存のピッカービューに列を追加する方法

分類Dev

recyclerview OnActivityResultで特定のアイテム(カードビュー)を更新する方法

分類Dev

RecyclerViewのビューを現在のアイテムにのみ動的に追加する

分類Dev

UIPageViewControllerにカスタムビューを追加する

分類Dev

AndroidのカスタムビューにViewPagerを追加する

分類Dev

カードビューにレイアウトを追加するにはどうすればよいですか?

分類Dev

Xamarinを使用してキーボードの上にカスタムビューを追加する

分類Dev

ASP.NETMVCビューにフィールドを追加する

分類Dev

ビューASP.NETMVCにフィールドを追加する

分類Dev

Android:RecyclerViewにビューを追加するときの奇妙な反応

分類Dev

RecyclerViewに動的にビューを追加します

分類Dev

ナビゲーションメニュー項目にカスタムフィールドを追加する

分類Dev

RecyclerViewパターンでカードにボタンを追加する

分類Dev

カスタムビューにバインドビューを使用する方法

分類Dev

カードビューをクリックしたときにrecyclerviewから次のアクティビティにデータを転送する方法

分類Dev

テーブルビューにビューを追加する

分類Dev

Express / ejsにビューを追加する

分類Dev

ビューに形状を追加する方法

分類Dev

RalativeLayoutに動的ビューを追加する

分類Dev

UITableViewControllerにビューを追加する

分類Dev

動的にビューを追加するandroid

分類Dev

ビューにscrollviewを追加する

Related 関連記事

  1. 1

    Recyclerviewからカードビューを非表示にする方法

  2. 2

    recyclerviewからすべてのカードビューを削除してから新しいカードビューを追加-同じカードビューを追加

  3. 3

    Android:ビューを削除してrecyclerViewに適切に追加する

  4. 4

    カードビューにホバーボタンを追加する方法

  5. 5

    カードビューに色付きの境界線を追加する方法は?

  6. 6

    カードビューに色付きの境界線を追加する方法は?

  7. 7

    アラートビューにカスタムビューを追加する

  8. 8

    既存のピッカービューに列を追加する方法

  9. 9

    recyclerview OnActivityResultで特定のアイテム(カードビュー)を更新する方法

  10. 10

    RecyclerViewのビューを現在のアイテムにのみ動的に追加する

  11. 11

    UIPageViewControllerにカスタムビューを追加する

  12. 12

    AndroidのカスタムビューにViewPagerを追加する

  13. 13

    カードビューにレイアウトを追加するにはどうすればよいですか?

  14. 14

    Xamarinを使用してキーボードの上にカスタムビューを追加する

  15. 15

    ASP.NETMVCビューにフィールドを追加する

  16. 16

    ビューASP.NETMVCにフィールドを追加する

  17. 17

    Android:RecyclerViewにビューを追加するときの奇妙な反応

  18. 18

    RecyclerViewに動的にビューを追加します

  19. 19

    ナビゲーションメニュー項目にカスタムフィールドを追加する

  20. 20

    RecyclerViewパターンでカードにボタンを追加する

  21. 21

    カスタムビューにバインドビューを使用する方法

  22. 22

    カードビューをクリックしたときにrecyclerviewから次のアクティビティにデータを転送する方法

  23. 23

    テーブルビューにビューを追加する

  24. 24

    Express / ejsにビューを追加する

  25. 25

    ビューに形状を追加する方法

  26. 26

    RalativeLayoutに動的ビューを追加する

  27. 27

    UITableViewControllerにビューを追加する

  28. 28

    動的にビューを追加するandroid

  29. 29

    ビューにscrollviewを追加する

ホットタグ

アーカイブ