2017-02-21 3 views
-1

Я использую фрагмент, где я использую GridView для генерации некоторых категорий. Когда пользователь выбирает категорию i, я заменяю предыдущий фрагмент новым фрагментом, который используется для получения сведений о категории. Но когда я вернусь к предыдущему фрагменту, где отображаются категории, я хочу сделать выбранную категорию, на которую пользователь нажал ранее. Я попытался использовать селектор, но он не работает для меня. Вот мой код.Как сделать TextView выбранным в GridView на основе щелкнутой позиции?

Вот мой файл XML макет

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:paddingTop="20dp" 
    > 
    <GridView 
     android:id="@+id/hindernisTypGridView" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:numColumns="auto_fit" 
     android:columnWidth="190dp" 
     android:verticalSpacing="20dp" 
     android:layout_below="@+id/topBar" 
     android:horizontalSpacing="5dp" 
     android:paddingLeft="32dp" 
     android:paddingRight="32dp" 
     /> 
</LinearLayout> 

Вот мой заказ XML для GridView

<?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:orientation="vertical" 
    android:layout_width="190dp" 
    android:layout_height="180dp" 
    android:padding="2dp" 
    tools:ignore="MissingPrefix" 
    > 
    <TextView 
     android:textColor="@color/redText" 
     android:textSize="37.14sp" 
     android:layout_gravity="center_horizontal" 
     android:gravity="center_vertical" 
     android:textAlignment="center" 
     android:layout_width="match_parent" 
     android:layout_height="180dp" 
     android:text="OBW" 
     android:id="@+id/hindernisTypTextView" 
     fontPath="DBSansRegular.otf" 
     android:textAppearance="@style/DBSansRegular" 
     android:background="@drawable/grid_view_item_selector" 
     /> 
</RelativeLayout> 

Вот мой селектор

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:drawable="@color/redText" android:state_pressed="true"/> 
</selector> 

Вот фрагмент, который используется для показать категории

import android.app.Activity; 
import android.app.Fragment; 
import android.app.FragmentManager; 
import android.app.FragmentTransaction; 
import android.content.Context; 
import android.os.Bundle; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.AdapterView; 
import android.widget.ArrayAdapter; 
import android.widget.GridView; 
import android.widget.Toast; 

import com.example.anikdey.railwayapp.R; 
import com.example.anikdey.railwayapp.adapters.HindernisTypGridViewAdapter; 
import com.example.anikdey.railwayapp.models.HindernisTyp; 



public class HindernisTypFragment extends Fragment { 

    private GridView projectListGridView; 
    private View view; 

    private HindernisTyp hindernisTyp; 
    private HindernisTypGridViewAdapter hindernisTypGridViewAdapter; 
    private OnHindernisTypSelectedListener hindernisTypSelectedListener; 


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

     view = inflater.inflate(R.layout.kategorie_wahlen_grid_view, container, false); 
     projectListGridView = (GridView) view.findViewById(R.id.kategoryWahlenGridView); 
     hindernisTyp = new HindernisTyp(); 
     hindernisTypGridViewAdapter = new HindernisTypGridViewAdapter(getActivity().getApplicationContext(), hindernisTyp.getHindernisTyps()); 
     projectListGridView.setAdapter(hindernisTypGridViewAdapter); 
     projectListGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() { 
      @Override 
      public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
       view.setSelected(true); 
       hindernisTypSelectedListener.setHindernisTyp(hindernisTyp.getHindernisTyps().get(position).getHindernisTypName()); 
       FragmentManager fragmentManager = getActivity().getFragmentManager(); 
       FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction(); 
       fragmentTransaction.replace(R.id.fragment_container, new DetailsFragment(),"DetailsFragment"); 
       fragmentTransaction.addToBackStack("df"); 
       fragmentTransaction.commit(); 
      } 
     }); 
     return view; 
    } 


} 

Адаптер я использовал для отображения категорий в GridView

import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.ImageView; 
import android.widget.TextView; 

import com.example.anikdey.railwayapp.R; 
import com.example.anikdey.railwayapp.models.HindernisTyp; 

import java.util.ArrayList; 
import java.util.List; 


public class HindernisTypGridViewAdapter extends BaseAdapter { 

    private Context context; 
    private List<HindernisTyp> hindernisTyps = new ArrayList<HindernisTyp>(); 

    public HindernisTypGridViewAdapter(Context context, List<HindernisTyp> hindernisTyps){ 
     this.context = context; 
     this.hindernisTyps = hindernisTyps; 
    } 

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

    @Override 
    public Object getItem(int position) { 
     return null; 
    } 

    @Override 
    public long getItemId(int position) { 
     return 0; 
    } 

    private static final class ViewHolder { 
     private TextView hindernisTypTextView; 
    } 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 
     ViewHolder holder; 
     if(convertView == null) { 
      LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
      convertView = inflater.inflate(R.layout.hindernis_typ_grid_view_custom_layout, null, true); 
      holder = new ViewHolder(); 
      holder.hindernisTypTextView = (TextView) convertView.findViewById(R.id.hindernisTypTextView); 
      convertView.setTag(holder); 
     } else { 
      holder = (ViewHolder) convertView.getTag(); 
     } 
     holder.hindernisTypTextView.setText(hindernisTyps.get(position).getHindernisTypName()); 

     return convertView; 
    } 
} 
+0

вы можете использовать «Наблюдатель Pattern» для достижения своей цели, записать позицию в фрагменте в ответ на позицию в GridView , и в методе жизненного цикла фрагмента возобновить выбранное состояние –

ответ

0

Когда пользователь собирается детали фрагментировать отправить эту выбранную категорию в основной деятельности или общего предпочтения или постоянной, но не старайтесь полагаться на onSaveInstanceState()

Теперь, когда вы возвращаетесь к фрагменту из заднего стека, он не воссоздает фрагмент, а повторно использует тот же экземпляр и начинается с onCreateView() в жизненном цикле фрагмента, см. Фрагмент Lifecycle.

Теперь запустите форму onCreateView() Так добавить boolean isRestoredFromBackstack фрагментировать и следовать код ниже:

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

@Override 
public void onResume() 
{ 
    super.onResume(); 
    if(mIsRestoredFromBackstack) 
    { 
     // The fragment restored from backstack, 
     // get selected state and set category selected again! 
    } 
} 

@Override 
public void onDestroyView() 
{ 
    super.onDestroyView(); 
    mIsRestoredFromBackstack = true; 
} 

ИЛИ

есть еще одно простое решение .... зависит от ситуации

просто используйте add() не replace()

Fragment fragment=new DestinationFragment(); 
FragmentManager fragmentManager = getFragmentManager(); 
android.app.FragmentTransaction ft=fragmentManager.beginTransaction(); 
ft.add(R.id.content_frame, fragment); 
ft.hide(SourceFragment.this); 
ft.addToBackStack(SourceFragment.class.getName()); 
ft.commit(); 
0

Вот как я решил свою проблему. Перед запуском нового фрагмента я сохраняю позицию в переменной с именем previousPosition, которая была инициализирована с отрицательным значением -1. Затем я передаю предыдущее положение в адаптере. Код приведен ниже.

Обновленный фрагмент класса

package com.example.anikdey.railwayapp.fragments; 

import android.app.Activity; 
import android.app.Fragment; 
import android.app.FragmentManager; 
import android.app.FragmentTransaction; 
import android.content.Context; 
import android.os.Bundle; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.AdapterView; 
import android.widget.ArrayAdapter; 
import android.widget.GridView; 
import android.widget.Toast; 

import com.example.anikdey.railwayapp.R; 
import com.example.anikdey.railwayapp.adapters.HindernisTypGridViewAdapter; 
import com.example.anikdey.railwayapp.models.HindernisTyp; 


public class HindernisTypFragment extends Fragment { 

    private GridView projectListGridView; 
    private View view; 

    private HindernisTyp hindernisTyp; 
    private HindernisTypGridViewAdapter hindernisTypGridViewAdapter; 
    private OnHindernisTypSelectedListener hindernisTypSelectedListener; 

    private int previousPosition = -1; 

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

     view = inflater.inflate(R.layout.kategorie_wahlen_grid_view, container, false); 
     projectListGridView = (GridView) view.findViewById(R.id.kategoryWahlenGridView); 

     hindernisTyp = new HindernisTyp(); 
     hindernisTypGridViewAdapter = new HindernisTypGridViewAdapter(getActivity().getApplicationContext(), hindernisTyp.getHindernisTyps(), previousPosition); 
     projectListGridView.setAdapter(hindernisTypGridViewAdapter); 

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

       hindernisTypSelectedListener.setHindernisTyp(hindernisTyp.getHindernisTyps().get(position).getHindernisTypName()); 
       hindernisTypSelectedListener.enableCancelButton(true); 
       previousPosition = position; 
       FragmentManager fragmentManager = getActivity().getFragmentManager(); 
       FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction(); 
       fragmentTransaction.replace(R.id.fragment_container, new DetailsFragment(),"DetailsFragment"); 
       fragmentTransaction.addToBackStack("df"); 
       fragmentTransaction.commit(); 
      } 
     }); 
     return view; 
    } 

    @Override 
    public void onAttach(Activity activity) { 
     super.onAttach(activity); 
     try { 
      hindernisTypSelectedListener = (OnHindernisTypSelectedListener) activity; 
     } catch (ClassCastException e) { 

     } 
    } 

    public interface OnHindernisTypSelectedListener { 
     public void setHindernisTyp(String hindernisTyp); 
     public void enableCancelButton(boolean state); 

    } 

} 

Вот дополненная класс адаптера

package com.example.anikdey.railwayapp.adapters; 

import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.ImageView; 
import android.widget.TextView; 

import com.example.anikdey.railwayapp.R; 
import com.example.anikdey.railwayapp.models.HindernisTyp; 

import java.util.ArrayList; 
import java.util.List; 


public class HindernisTypGridViewAdapter extends BaseAdapter { 

    private Context context; 
    private int previousPosition; 
    private List<HindernisTyp> hindernisTyps = new ArrayList<HindernisTyp>(); 

    public HindernisTypGridViewAdapter(Context context, List<HindernisTyp> hindernisTyps, int previousPosition){ 
     this.context = context; 
     this.hindernisTyps = hindernisTyps; 
     this.previousPosition = previousPosition; 

    } 

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

    @Override 
    public Object getItem(int position) { 
     return null; 
    } 

    @Override 
    public long getItemId(int position) { 
     return 0; 
    } 

    private static final class ViewHolder { 
     private TextView hindernisTypTextView; 
    } 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 
     ViewHolder holder; 
     if(convertView == null) { 
      LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
      convertView = inflater.inflate(R.layout.hindernis_typ_grid_view_custom_layout, null, true); 
      holder = new ViewHolder(); 
      holder.hindernisTypTextView = (TextView) convertView.findViewById(R.id.hindernisTypTextView); 
      convertView.setTag(holder); 
     } else { 
      holder = (ViewHolder) convertView.getTag(); 
     } 

     if(position == previousPosition) { 
      holder.hindernisTypTextView.setBackgroundColor(context.getResources().getColor(R.color.redText)); 
      holder.hindernisTypTextView.setTextColor(context.getResources().getColor(R.color.whiteText)); 
      holder.hindernisTypTextView.setText(hindernisTyps.get(position).getHindernisTypName()); 
     } else { 
      holder.hindernisTypTextView.setText(hindernisTyps.get(position).getHindernisTypName()); 
     } 

     return convertView; 
    } 
} 
Смежные вопросы