Измените фрагмент на setOnItemClickListener на ListView с CardView - PullRequest
0 голосов
/ 29 декабря 2018

У меня есть ListView, который использует CardView для раздувания своего макета.Когда пользователь нажимает на первый элемент в ListView, это должно изменить фрагмент.Однако я не уверен, как это сделать.Я попытался изменить Фрагмент в классе адаптера (CustomAdapter.java), и это не сработало.Я также пытался сделать это во фрагменте, в котором находится ListView, но он тоже не работал (приложение не зависало при нажатии на один из элементов - ничего не происходило):

listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {

            Fragment fragment = null;

            switch (position) {

                case 0:
                    fragment = new DesignsWorkshopFragment();

                    break;

            }

            if (fragment != null) {

                FragmentTransaction ft = getFragmentManager().beginTransaction();

                ft.replace(R.id.content_frame, fragment);

                ft.addToBackStack(null);

                ft.commit();
            }

        }
    });

SuppliersFragment.java:

public class SuppliersFragment extends Fragment {

CustomAdapter adapter;
ListView lv;


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


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_suppliers, container, false);

    lv = view.findViewById(R.id.lvFragmentSuppliers);

    adapter = new CustomAdapter(getContext(), getData());
    lv.setAdapter(adapter);

    lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {

            Fragment fragment = null;

            switch (position) {

                case 0:
                    fragment = new DesignsWorkshopFragment();

                    break;

            }

            if (fragment != null) {

                FragmentTransaction ft = getFragmentManager().beginTransaction();

                ft.replace(R.id.content_frame, fragment);

                ft.addToBackStack(null);

                ft.commit();
            }

        }
    });

    return view;
}

private ArrayList getData() {

    ArrayList<SuppliersCardview> suppliersCardview = new ArrayList<>();

    SuppliersCardview s = new SuppliersCardview();
    s.setThumbnail(R.drawable.designs_workshop_logo);
    s.setName("Designs Workshop");
    suppliersCardview.add(s);

    s = new SuppliersCardview();
    s.setThumbnail(R.drawable.organic_clothing_logo);
    s.setName("Organic Clothing Industries");
    suppliersCardview.add(s);

    s = new SuppliersCardview();
    s.setThumbnail(R.drawable.suns_sewing_ltd);
    s.setName("Sun's Sewing Ltd");
    suppliersCardview.add(s);

    return suppliersCardview;
}}

CustomAdapter.java:

public class CustomAdapter extends BaseAdapter {
Context c;
ArrayList<SuppliersCardview> suppliersCardview;

public CustomAdapter(Context c, ArrayList<SuppliersCardview> suppliersCardview) {
    this.c = c;
    this.suppliersCardview = suppliersCardview;
}

@Override
public int getCount() {
    return suppliersCardview.size();
}

@Override
public Object getItem(int position) {
    return suppliersCardview.get(position);
}

@Override
public long getItemId(int position) {

    return position;
}

@Override
public View getView(final int position, View convertView, final ViewGroup parent) {

    if (convertView == null) {
        convertView = LayoutInflater.from(c).inflate(R.layout.cardview_layout, parent, false);
    }

    final SuppliersCardview s = (SuppliersCardview) this.getItem(position);

    ImageView imageView = convertView.findViewById(R.id.ivSupplierLogo);
    TextView textView = convertView.findViewById(R.id.tvSupplierName);

    imageView.setImageResource(s.getThumbnail());
    textView.setText(s.getName());

    convertView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            //Attempted to change fragment here in a switch statement

        }
    });

    return convertView;
}

SuppliersCardview.java:

public class SuppliersCardview {

private String name;
private int thumbnail;

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public int getThumbnail() {
    return thumbnail;
}

public void setThumbnail(int thumbnail) {
    this.thumbnail = thumbnail;
}}

SuppliersFragment XML:

<FrameLayout 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"
tools:context="com.miguelpeachey.marketplacesimulator.Fragments.SuppliersFragment">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/tvBrowseSuppliersHeader"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#bfbdbd"
        android:fontFamily="@font/nunito_sans"
        android:paddingBottom="5dp"
        android:paddingStart="10dp"
        android:paddingTop="10dp"
        android:text="Browse Suppliers"
        android:textSize="25sp" />

    <ListView
       android:layout_marginLeft="40dp"
        android:layout_marginRight="40dp"
        android:id="@+id/lvFragmentSuppliers"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:divider="@color/colorTransparent"
        android:dividerHeight="20dip"/>

</LinearLayout>

CardView XML:

<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/tools"
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/cardView"
android:layout_width="match_parent"
android:layout_height="200dp"
android:layout_margin="40dp"
android:orientation="vertical"
app:cardPreventCornerOverlap="false"
app:ignore="NamespaceTypo"
card_view:cardBackgroundColor="#cccbcb"
card_view:cardCornerRadius="15dp"
card_view:cardElevation="5dp">

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_gravity="center"
    android:orientation="vertical">

    <ImageView
        android:id="@+id/ivSupplierLogo"
        android:layout_width="150dp"
        android:layout_height="120dp"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="10dp"
        android:src="@drawable/ic_launcher_background" />

    <TextView
        android:id="@+id/tvSupplierName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/ivSupplierLogo"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="10dp"
        android:fontFamily="@font/brawler"
        android:text="Supplier"
        android:textColor="#232323"
        android:textSize="22sp" />


</RelativeLayout>

Итак, как я могу заменить / изменить фрагменты при щелчке элемента ListView, который использует CardView в качестве макета?Решения других людей мне не помогли.

Я использовал этот веб-сайт в качестве учебного пособия для создания CardView и раздувания макета ListView (часть кода приведена на веб-сайте).

Ответы [ 3 ]

0 голосов
/ 29 декабря 2018

Добавление и замена фрагмента выполняется внутри действия. Вам нужно уведомить свое действие о щелчке элемента в представлении ListView. Это можно сделать с помощью интерфейсов.

создать один интерфейс:

public interface ClickListener{
  public void onClick();
   }

Реализуйте этот интерфейс в своей деятельности. И когда вы создаете фрагмент, передайте «this» в качестве ссылки внутри конструктора фрагмента. Вот как:

  fragment = new DesignsWorkshopFragment(this);

Внутри фрагмента вам нужно создать интерфейсссылка.

private ClickListener clickListener ;

Внутренний фрагмент инициализирует этот интерфейс ссылки

DesignsWorkshopFragment(ClickListener clickListener){
this.clickListener = clickListener;
}

Теперь сделайте то же самое при создании адаптера.

adapter = new CustomAdapter(getContext(), getData(),clickListener);

Внутри адаптера создайте иинициализировать ссылку на интерфейс.

 private ClickListener clickListener ;

 public CustomAdapter(Context c, ArrayList<SuppliersCardview> suppliersCardview,
                       ClickListener clickListener ) {
  this.c = c;
  this.suppliersCardview = suppliersCardview;
  this.clickListener = clickListener;
  }

и всякий раз, когда происходит щелчок.просто вызовите метод интерфейса.

convertView.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
       clickListener.onClick();
    }
});

это даст обратный вызов внутри реализации interfcae вашей деятельности.Здесь

public void onClick(){
 //write your code for adding or replacing fragment.
}
0 голосов
/ 29 декабря 2018

Мне удалось заставить это работать, просто удалив

convertView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

        }
    });

в моем CustomAdapter.java классе.

0 голосов
/ 29 декабря 2018

Теперь у вас есть объект фрагмента, вам нужно использовать менеджер фрагментов и заменить существующий фрагмент фрагментом, который вы хотите показать.

DesignsWorkshopFragment fragment2=new DesignsWorkshopFragment();
FragmentManager fragmentManager=getActivity().getFragmentManager();
FragmentTransaction fragmentTransaction=fragmentManager.beginTransaction();
fragmentTransaction.replace(R.id.content_main,fragment2,"tag");
fragmentTransaction.addToBackStack(null);
fragmentTransaction.commit();

Только создание экземпляра вашего фрагмента не будет отображать его в действии.

...