Замена фрагмента в ViewPager показывает пустой экран?

У меня много проблем с тем, чтобы Фрагменты работали с Tabs / Swiping. У меня есть одна активность и два фрагмента, один из которых имеет ListView. Я хочу, когда я прокручиваю фрагмент 1 в фрагмент с помощью ListView, чтобы обновить ListView или, если возможно, воссоздать второй фрагмент ….

Сейчас я пытаюсь использовать FragmentTransaction.replace () следующим образом:

public void onTabSelected(Tab arg0, android.app.FragmentTransaction arg1) { // TODO Auto-generated method stub Fragment frag = new FragmentTwo(); FragmentTransaction trans = getSupportFragmentManager().beginTransaction(); if (arg0.getPosition() == 1) { trans.replace(R.id.pager, frag); trans.addToBackStack(null); trans.commit(); } } 

Поэтому я подумал, что когда я перейду на вкладку 2, которая является таковой с ListView, она заменит ее на новую, которую она создает. На самом деле происходит то, что когда я прокручиваю вкладку 2, она воссоздает фрагмент с помощью ListView (я знаю, потому что у меня есть диалог в onCreateView, который отображается на экране), но затем фрагмент / вкладка пуст / черный. Что я делаю не так? Где происходит этот фрагмент, который создан?

Я не знаю, подходит ли код фрагментов, но, пожалуйста, дайте мне знать, если я должен опубликовать его, и я могу это сделать. Это мой класс PagerAdapter.

 public class TabsPagerAdapter extends FragmentPagerAdapter { public TabsPagerAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int index) { switch (index) { case 0: return new FragmentOne(); case 1: return new FragmentTwo(); case 2: return new FragmentThree(); } return null; } @Override public int getCount() { // get item count - equal to number of tabs return 3; } } 

Спасибо за любую помощь! Я действительно вытягиваю свои волосы из-за этого 🙁

Редактировать:

Когда вы перебираете вкладку 1 на вкладку 2, вкладка 2 показывает мой диалог, а затем загружает вкладку, но если я вернусь к вкладке 1, все ее черные … и если я снова перейду на вкладку 2, она снова создаст и покажет Мой диалог, а затем черный цвет …

Изменить: (добавление кода фрагмента списка)

Открытый класс FragmentTwo расширяет фрагмент {

 // Progress Dialog private ProgressDialog pDialog; // Creating JSON Parser object JSONParser_Helpers2 jParser = new JSONParser_Helpers2(); ArrayList<HashMap<String, String>> tripList; // url to get all products list private static String url_all_trips = "http://10.0.2.2/android_connect/get_all_trips.php"; // JSON Node names private static final String TAG_SUCCESS = "success"; private static final String TAG_TRIPS = "trips"; private static final String TAG_TRIPID = "tripid"; private static final String TAG_TRIPNAME = "tripName"; private static final String TAG_UID = "uid32"; // products JSONArray JSONArray trips = null; View rootView; Button btnRefresh; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { //View rootView = inflater.inflate(R.layout.fragment_one, container, false); rootView = inflater.inflate(R.layout.fragment_two, container, false); btnRefresh = (Button) rootView.findViewById(R.id.refresh); // Hashmap for ListView tripList = new ArrayList<HashMap<String, String>>(); // Loading products in Background Thread new LoadAllProducts().execute(); // Get listview ListView lv = (ListView) rootView.findViewById(R.id.list); // on seleting single product // launching Edit Product Screen lv.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { //getting values from selected ListItem String tripid = ((TextView) view.findViewById(R.id.pid)).getText().toString(); //starting new intent Intent in = new Intent(getActivity(), EditTrip_Activity.class); //sending pid to next activity in.putExtra(TAG_TRIPID, tripid); //starting new activity and expecting some response back startActivityForResult(in, 100); } }); return rootView; } /** * Background Async Task to Load all product by making HTTP Request * */ class LoadAllProducts extends AsyncTask<String, String, String> { ListView lv = (ListView) rootView.findViewById(R.id.list); /** * Before starting background thread Show Progress Dialog * */ @Override protected void onPreExecute() { super.onPreExecute(); pDialog = new ProgressDialog(getActivity()); pDialog.setMessage("Loading your trips. Please wait..."); pDialog.setIndeterminate(false); pDialog.setCancelable(false); pDialog.show(); } /** * getting All products from url * */ protected String doInBackground(String... args) { // Building Parameters List<NameValuePair> params = new ArrayList<NameValuePair>(); // getting JSON string from URL JSONObject json = jParser.makeHttpRequest(url_all_trips, "GET", params); // Check your log cat for JSON response Log.d("All Trips: ", json.toString()); try { // Checking for SUCCESS TAG int success = json.getInt(TAG_SUCCESS); if (success == 1) { // products found // Getting Array of Products trips = json.getJSONArray(TAG_TRIPS); // looping through All Products for (int i = 0; i < trips.length(); i++) { JSONObject c = trips.getJSONObject(i); // Storing each json item in variable String tripid = c.getString(TAG_TRIPID); String tripname = c.getString(TAG_TRIPNAME); String userId = c.getString("uid"); // creating new HashMap DatabaseHandler_Helpers db = new DatabaseHandler_Helpers(getActivity()); HashMap<String, String> map = new HashMap<String, String>(); if (userId.equals(db.getUserDetails().get("uid"))) { // adding each child node to HashMap key => value map.put(TAG_TRIPID, tripid); map.put(TAG_TRIPNAME, tripname); // adding HashList to ArrayList tripList.add(map); } //else { //map.put(TAG_TRIPID, ""); //map.put(TAG_TRIPNAME, "You have no tracked trips."); //tripList.add(map); //} } } else { // no products found // Launch Add New product Activity Intent i = new Intent(getActivity(), NewTrip_Activity.class); // Closing all previous activities i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); startActivity(i); } } catch (JSONException e) { e.printStackTrace(); } return null; } /** * After completing background task Dismiss the progress dialog * **/ protected void onPostExecute(String file_url) { // dismiss the dialog after getting all products pDialog.dismiss(); // updating UI from Background Thread ((Activity) getActivity()).runOnUiThread(new Runnable() { public void run() { /** * Updating parsed JSON data into ListView * */ ListAdapter adapter = new SimpleAdapter( getActivity(), tripList, R.layout.list_item, new String[] { TAG_TRIPID, TAG_TRIPNAME}, new int[] { R.id.pid, R.id.name }); // updating listview ((ListView) lv.findViewById(R.id.list)).setAdapter(adapter); } }); } } 

}

Попробуйте расширить FragmentStatePagerAdapter вместо FragmentPagerAdapter.

Вот мой код для фрагментов, и он отлично работает для меня:

 //Adapter public class AllPagesAdapter extends FragmentStatePagerAdapter { public AllPagesAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int index) { switch (index) { case 0: return new Android(); case 1: return new CoreJava(); case 2: return new J2EE(); case 3: return new Database(); case 4: return new WebServices(); } return null; } @Override public int getCount() { return 5; } } //For example, this is one fragment: public class Database extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View databaseview = inflater.inflate(R.layout.database, container, false); return databaseview; } } //My MainActivity public class AllActivities extends FragmentActivity implements ActionBar.TabListener { public ViewPager viewPager; private AllPagesAdapter mAdapter; private ActionBar actionBar; private String [] tabs = {"Android","CoreJava","J2EE","Database","Web Services"}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //Initializing all stuff viewPager = (ViewPager)findViewById(R.id.pager); actionBar = getActionBar(); mAdapter = new AllPagesAdapter(getSupportFragmentManager()); viewPager.setAdapter(mAdapter); actionBar.setHomeButtonEnabled(true); actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS); //Add the tabs here for(String tab_name:tabs){ actionBar.addTab(actionBar.newTab().setText(tab_name).setTabListener(this)); } viewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener(){ @Override public void onPageSelected(int position){ //on Page change, that particular page should be selected actionBar.setSelectedNavigationItem(position); } @Override public void onPageScrolled(int arg0,float arg1,int arg2){ } @Override public void onPageScrollStateChanged(int position){ } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public void onTabSelected(Tab tab, FragmentTransaction fragmentTransaction) { viewPager.setCurrentItem(tab.getPosition()); } @Override public void onTabUnselected(Tab tab, FragmentTransaction fragmentTransaction) { } @Override public void onTabReselected(Tab tab, FragmentTransaction fragmentTransaction) { viewPager.setCurrentItem(tab.getPosition()); } } 

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

Надеюсь это поможет..:)

Мои дочерние фрагменты находятся в ViewPager. Я просто заменил адаптер ViewPage на FragmentStatePagerAdapter вместо FragmentPagerAdapter

Детский фрагмент ….

 mViewPager.setAdapter(new SearchOriginTabsPagerAdapter(getFragmentManager())); 

Адаптер …

 public class SearchOriginTabsPagerAdapter extends FragmentStatePagerAdapter { public SearchOriginTabsPagerAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int index) { switch (index) { case 0: return new NearbyFragment(); case 1: return new RecentOriginFragment(); } return null; } @Override public int getCount() { // get item count - equal to number of tabs return 2; } } 

Хорошо .. Вот что ..

Я действительно не использовал ваш код, но использовал аналогичную концепцию. Это будет полное решение.

// Это отправная точка приложения. У него много фрагментов, и я использую свой собственный json для получения данных.

 public class AllActivities extends FragmentActivity implements ActionBar.TabListener { public ViewPager viewPager; private AllPagesAdapter mAdapter; private ActionBar actionBar; private String [] tabs = {"Android","CoreJava","J2EE","Database","Web Services"}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //Initializing all stuff viewPager = (ViewPager)findViewById(R.id.pager); actionBar = getActionBar(); mAdapter = new AllPagesAdapter(getSupportFragmentManager()); viewPager.setAdapter(mAdapter); actionBar.setHomeButtonEnabled(true); actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS); //Add the tabs here for(String tab_name:tabs){ actionBar.addTab(actionBar.newTab().setText(tab_name).setTabListener(this)); } viewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener(){ @Override public void onPageSelected(int position){ //on Page change, that particular page should be selected actionBar.setSelectedNavigationItem(position); } @Override public void onPageScrolled(int arg0,float arg1,int arg2){ } @Override public void onPageScrollStateChanged(int position){ } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public void onTabSelected(Tab tab, FragmentTransaction fragmentTransaction) { viewPager.setCurrentItem(tab.getPosition()); } @Override public void onTabUnselected(Tab tab, FragmentTransaction fragmentTransaction) { } @Override public void onTabReselected(Tab tab, FragmentTransaction fragmentTransaction) { viewPager.setCurrentItem(tab.getPosition()); } } //This is one of the fragment and assume that Expandablelistview is your list view.. In both the cases, i am setting the adapter in the onActivityCreated() method. public class Android extends android.support.v4.app.Fragment { ExpandableListAdapter listAdapter; // private ExpandableListView expListView; List<String> listDataHeader; HashMap<String, List<String>> listDataChild; ListView lv1; private static final String QUESTION = "question"; private static final String ANSWERS = "answer"; // ArrayList<HashMap<String, String>> jsonlist = new ArrayList<HashMap<String, String>>(); @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View mikeview = inflater.inflate(R.layout.androidlayout, container, false); return mikeview; } @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); ExpandableListView expListView = null; try{ expListView = (ExpandableListView) getActivity().findViewById(R.id.androidExpandableList); } catch (Exception e){ e.printStackTrace(); } new Thread(){ @Override public void run(){ } }.start(); try { setParent(); prepareChild(); } catch (Exception e) { e.printStackTrace(); } ExpandableListAdapter listAdapter = new ExpandableListAdapter(getActivity(), listDataHeader, listDataChild); expListView.setAdapter(listAdapter); // Listview on child click listener expListView.setOnChildClickListener(new ExpandableListView.OnChildClickListener() { @Override public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int childPosition, long id) { /*Toast.makeText( getActivity(), listDataHeader.get(groupPosition) + " : " + listDataChild.get( listDataHeader.get(groupPosition)).get( childPosition), Toast.LENGTH_SHORT) .show();*/ return true; } }); // Listview Group expanded listener expListView.setOnGroupExpandListener(new ExpandableListView.OnGroupExpandListener() { @Override public void onGroupExpand(int groupPosition) { /* Toast.makeText(getActivity(), listDataHeader.get(groupPosition) + " Expanded", Toast.LENGTH_SHORT).show();*/ } }); // Listview Group collasped listener expListView.setOnGroupCollapseListener(new ExpandableListView.OnGroupCollapseListener() { @Override public void onGroupCollapse(int groupPosition) { /*Toast.makeText(getActivity(), listDataHeader.get(groupPosition) + " Collapsed", Toast.LENGTH_SHORT).show();*/ } }); } public void setParent(){ listDataHeader = new ArrayList<String>(); try{ JSONObject json = new JSONObject(loadJSONFromAsset()); JSONArray array = json.getJSONArray("androidquestion"); for(int my =0;my<array.length();my++){ JSONObject c = array.getJSONObject(my); String topics = c.getString(QUESTION); listDataHeader.add(topics); } } catch (JSONException e) { e.printStackTrace(); } } public void prepareChild() throws JSONException { listDataChild = new HashMap<String, List<String>>(); try{ JSONObject json = new JSONObject(loadJSONFromAsset()); JSONArray array = json.getJSONArray("androidquestion"); for(int mz = 0;mz<array.length();mz++){ ArrayList<String> child = new ArrayList<String>(); JSONObject d = array.getJSONObject(mz); String ans = d.getString(ANSWERS); child = new ArrayList<String>(); child.add(ans); int position = mz ; listDataChild.put(listDataHeader.get( position),child); } } catch(JSONException e) { e.printStackTrace(); } } public String loadJSONFromAsset() { String json = null; try { InputStream is = getActivity().getAssets().open("android.json"); int size = is.available(); byte[] buffer = new byte[size]; is.read(buffer); is.close(); json = new String(buffer, "UTF-8"); } catch (IOException ex) { ex.printStackTrace(); return null; } return json; } } //This is the adapter. public class AllPagesAdapter extends FragmentStatePagerAdapter { public AllPagesAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int index) { switch (index) { case 0: return new Android(); case 1: return new CoreJava(); case 2: return new J2EE(); case 3: return new Database(); case 4: return new WebServices(); } return null; } @Override public int getCount() { return 5; } } //This is the adapter for my expandable list view.. in your case, your can just use the listadapter or any other adapter you want to use. This is just an optional part. public class ExpandableListAdapter extends BaseExpandableListAdapter { private Context _context; private List<String> _listDataHeader; // header titles // child data in format of header title, child title private HashMap<String, List<String>> _listDataChild; public ExpandableListAdapter(Context context, List<String> listDataHeader, HashMap<String, List<String>> listChildData) { this._context = context; this._listDataHeader = listDataHeader; this._listDataChild = listChildData; } @Override public Object getChild(int groupPosition, int childPosititon) { return this._listDataChild.get(this._listDataHeader.get(groupPosition)) .get(childPosititon); } @Override public long getChildId(int groupPosition, int childPosition) { return childPosition; } @Override public View getChildView(int groupPosition, final int childPosition, boolean isLastChild, View convertView, ViewGroup parent) { final String childText = (String) getChild(groupPosition, childPosition); if (convertView == null) { LayoutInflater inflater = (LayoutInflater) this._context .getSystemService(Context.LAYOUT_INFLATER_SERVICE); convertView = inflater.inflate(R.layout.newlistitems,null); } TextView txtListChild = (TextView) convertView .findViewById(R.id.newlistviewitems); txtListChild.setText(childText); return convertView; } @Override public int getChildrenCount(int groupPosition) { return this._listDataChild.get(this._listDataHeader.get(groupPosition)) .size(); } @Override public Object getGroup(int groupPosition) { return this._listDataHeader.get(groupPosition); } @Override public int getGroupCount() { return this._listDataHeader.size(); } @Override public long getGroupId(int groupPosition) { return groupPosition; } @Override public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) { String headerTitle = (String) getGroup(groupPosition); if (convertView == null) { LayoutInflater myInflater = (LayoutInflater) this._context .getSystemService(Context.LAYOUT_INFLATER_SERVICE); convertView = myInflater.inflate(R.layout.newlistgroup, null); } TextView lblListHeader = (TextView) convertView .findViewById(R.id.newlistviewgroup); lblListHeader.setTypeface(null, Typeface.BOLD); lblListHeader.setText(headerTitle); return convertView; } @Override public boolean hasStableIds() { return false; } @Override public boolean isChildSelectable(int groupPosition, int childPosition) { return true; } } 
Intereting Posts
Ошибка в полноэкранном фрагменте Android Как сохранить только первый добавленный фрагмент в фоновом стеке (перекрытие фрагментов)? Как найти имя пакета, которое было удалено при использовании Intent.ACTION_PACKAGE_REMOVED Может ли кто-нибудь объяснить, как TrafficStats работает с вашей магией в ОС Android? Служба Android onCreate вызывается несколько раз, не вызывая onDestroy Match_parent не работает для панели инструментов с макетом внутри Как правильно восстановить состояние представления после поворота Как точно настроить clientIds и аудиторию для аутентификации конечных точек Google Cloud для Android-приложения Прикрепить исходники для студийной библиотеки Android Заказ Linearlayout отменен на некоторых устройствах Что касается ошибки режима GPU при запуске виртуального устройства Android Что вызывает Google AdMob для утечки ServiceConnection? Как обменивать элементы ListView с анимацией? Нужна помощь для отображения текста сообщения с изображениями в виде списка Отслеживать пиксельные движения по пикселям в Android