2017-01-13 3 views
0

Я не могу заставить это работать. Основное приложение функционирует так, как предполагается, но ViewPager в одном из файлов макета вообще не отображает фрагмент. Я проверил код несколько раз, но я не могу найти ошибку. Когда я попытался отладить его, я заметил, что он даже не инициализирует классы фрагментов, которые он должен использовать при выборе вкладки. Мой MainActivity:ViewPager не показывает фрагменты

public class MainActivity extends AppCompatActivity 
    implements NavigationView.OnNavigationItemSelectedListener { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
      this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
    drawer.setDrawerListener(toggle); 
    toggle.syncState(); 

    NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view); 
    navigationView.setNavigationItemSelectedListener(this); 

    new GetData(this).execute(); 

    TabLayout tab_layout = (TabLayout) findViewById(R.id.tab_layout); 
    tab_layout.addTab(tab_layout.newTab().setText("CASUAL")); 
    tab_layout.addTab(tab_layout.newTab().setText("RANKED")); 
    tab_layout.setTabGravity(TabLayout.GRAVITY_FILL); 

    final ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager); 
    PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager(), tab_layout.getTabCount()); 
    viewPager.setAdapter(adapter); 
    tab_layout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { 
     @Override 
     public void onTabSelected(TabLayout.Tab tab) { 
      viewPager.setCurrentItem(tab.getPosition()); 
     } 

     @Override 
     public void onTabUnselected(TabLayout.Tab tab) { 

     } 

     @Override 
     public void onTabReselected(TabLayout.Tab tab) { 

     } 
    }); 

} 

@Override 
public void onBackPressed() { 
    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    if (drawer.isDrawerOpen(GravityCompat.START)) { 
     drawer.closeDrawer(GravityCompat.START); 
    } else { 
     super.onBackPressed(); 
    } 
} 

@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 boolean onOptionsItemSelected(MenuItem item) { 
    // Handle action bar item clicks here. The action bar will 
    // automatically handle clicks on the Home/Up button, so long 
    // as you specify a parent activity in AndroidManifest.xml. 
    int id = item.getItemId(); 

    //noinspection SimplifiableIfStatement 
    if (id == R.id.action_settings) { 
     return true; 
    } 

    return super.onOptionsItemSelected(item); 
} 

@SuppressWarnings("StatementWithEmptyBody") 
@Override 
public boolean onNavigationItemSelected(MenuItem item) { 
    // Handle navigation view item clicks here. 
    int id = item.getItemId(); 

    if (id == R.id.nav_stats) { 
     // Handle the camera action 
    } else if (id == R.id.nav_about) { 

    } 

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    drawer.closeDrawer(GravityCompat.START); 
    return true; 
} 
} 

Мой PagerAdapter:

public class PagerAdapter extends FragmentStatePagerAdapter { 
int mNumOfTabs; 

public PagerAdapter(FragmentManager fm, int NumOfTabs) { 
    super(fm); 
    this.mNumOfTabs = NumOfTabs; 
    } 

@Override 
public Fragment getItem(int position) { 

    switch (position) { 
     case 0: 
      CasualStats tab1 = new CasualStats(); 
      return tab1; 
     case 1: 
      RankedStats tab2 = new RankedStats(); 
      return tab2; 
     default: 
      return null; 
     } 
    } 

@Override 
public int getCount() { 
    return mNumOfTabs; 
    } 
} 

Компоновка с ViewPager:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:orientation="vertical" android:layout_width="match_parent" 
android:layout_height="match_parent"><![CDATA[ 

        android:id="@+id/pager" 
        android:layout_width="match_parent" 
        android:layout_height="fill_parent" 
        android:layout_below="@id/tab_layout"/> 
]]> 

<android.support.design.widget.TabLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_alignParentTop="true" 
    android:layout_alignParentStart="true" 
    android:id="@+id/tab_layout"> 

</android.support.design.widget.TabLayout> 

<view 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    class="android.support.v4.view.ViewPager" 
    android:layout_alignParentStart="true" 
    android:id="@+id/view_pager" 
    android:layout_below="@+id/tab_layout" /> 

</RelativeLayout> 

Классы для закладки фрагментов, которые, как предполагается, будут отображаться в ViewPager только нормальные автоматически создаваемые классы фрагментов Android Studio.

Один из фрагментов:

public class CasualStats extends Fragment{ 
// TODO: Rename parameter arguments, choose names that match 
// the fragment initialization parameters, e.g. ARG_ITEM_NUMBER 
private static final String ARG_PARAM1 = "param1"; 
private static final String ARG_PARAM2 = "param2"; 

// TODO: Rename and change types of parameters 
private String mParam1; 
private String mParam2; 

private OnFragmentInteractionListener mListener; 

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

/** 
* Use this factory method to create a new instance of 
* this fragment using the provided parameters. 
* 
* @param param1 Parameter 1. 
* @param param2 Parameter 2. 
* @return A new instance of fragment CasualStats. 
*/ 
// TODO: Rename and change types and number of parameters 
public static CasualStats newInstance(String param1, String param2) { 
    CasualStats fragment = new CasualStats(); 
    Bundle args = new Bundle(); 
    args.putString(ARG_PARAM1, param1); 
    args.putString(ARG_PARAM2, param2); 
    fragment.setArguments(args); 
    return fragment; 
} 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    if (getArguments() != null) { 
     mParam1 = getArguments().getString(ARG_PARAM1); 
     mParam2 = getArguments().getString(ARG_PARAM2); 
    } 
} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 
    // Inflate the layout for this fragment 
    return inflater.inflate(R.layout.fragment_casual_stats, container, false); 
} 

// TODO: Rename method, update argument and hook method into UI event 
public void onButtonPressed(Uri uri) { 
    if (mListener != null) { 
     mListener.onFragmentInteraction(uri); 
    } 
} 

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

/** 
* This interface must be implemented by activities that contain this 
* fragment to allow an interaction in this fragment to be communicated 
* to the activity and potentially other fragments contained in that 
* activity. 
* <p> 
* See the Android Training lesson <a href= 
* "http://developer.android.com/training/basics/fragments/communicating.html" 
* >Communicating with Other Fragments</a> for more information. 
*/ 
public interface OnFragmentInteractionListener { 
    // TODO: Update argument type and name 
    void onFragmentInteraction(Uri uri); 
} 
} 

XML-:

<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" 
tools:context="com.app.anzel.r6s.CasualStats"> 

<!-- TODO: Update blank fragment layout --> 

<TextView 
    android:text="1st fragment" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_alignParentTop="true" 
    android:layout_alignParentStart="true" 
    android:layout_marginStart="28dp" 
    android:layout_marginTop="22dp" 
    android:id="@+id/textView" 
    android:visibility="visible" /> 
</RelativeLayout> 
+0

попробовать так: 1. создать адаптер для ViewPager. 2. установите адаптер на ваш пейджер. 3. используйте tabLayout.setupWithViewPager (your_viewpager); 4. Убедитесь, что вы используете getSupportFragmentManager или getchildFragmentManager(), если viewpager находится в Activity или внутри другого фрагмента resp. 5. Ваш адаптер должен переопределить общедоступный CharSequence getPageTitle (int position), чтобы предоставить заголовок для каждого фрагмента в макете вкладки. –

+0

Вы пробовали убедиться, что фрагменты действительно не видны? Я имею в виду, что вы, кажется, ничего не вкладываете в текстовое изображение, попробуйте изменить фон или установить какой-либо текст внутри текстового поля только для проверки. –

+0

Изменен цвет фона для фрагмента, но он не отображает его. – Tachanka

ответ

0

У вас не хватает setupWithViewPager, и вам не нужно setOnTabSelectedListener:

tab_layout.setupWithViewPager(viewPager) 

Давайте посмотрим здесь: http://www.androidhive.info/2015/09/android-material-design-working-with-tabs/

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

Последняя, ​​не используйте <view ..class> в XML, создать нормальный вид XML:

<android.support.v4.view.ViewPager 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_alignParentStart="true" 
    android:id="@+id/view_pager" 
    android:layout_below="@+id/tab_layout"/> 
+0

Это просто заставило мои заголовки табуляции исчезнуть, и на просмотрщик все еще не отображаются фрагменты. – Tachanka

+0

Я все еще не могу заставить viewpager отображать фрагменты :( – Tachanka

+0

Какой результат у вас есть? Любые ошибки? –

0

попробовать это:

в макете:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:orientation="vertical" android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<android.support.design.widget.TabLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_alignParentTop="true" 
    android:layout_alignParentStart="true" 
    android:id="@+id/tab_layout"> 

</android.support.design.widget.TabLayout> 

<android.support.v4.view.ViewPager 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_alignParentStart="true" 
    android:id="@+id/view_pager" 
    android:layout_below="@+id/tab_layout" /> 

</RelativeLayout> 

в деятельности:

TabLayout tab_layout = (TabLayout) findViewById(R.id.tab_layout); 
    tab_layout.addTab(tab_layout.newTab().setText("CASUAL")); 
    tab_layout.addTab(tab_layout.newTab().setText("RANKED")); 
    tab_layout.setTabGravity(TabLayout.GRAVITY_FILL); 

    final ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager); 
    PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager(), tab_layout.getTabCount()); 
    viewPager.setAdapter(adapter); 
    viewPager.setOffscreenPageLimit(2); 
    tab_layout.post(new Runnable() { 
    @Override 
    public void run() { 
     tab_layout.setupWithViewPager(viewPager); 
     } 
    }); 
    tab_layout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { 
     @Override 
     public void onTabSelected(TabLayout.Tab tab) { 
      viewPager.setCurrentItem(tab.getPosition()); 
     } 

     @Override 
     public void onTabUnselected(TabLayout.Tab tab) { 

     } 

     @Override 
     public void onTabReselected(TabLayout.Tab tab) { 

     } 
    }); 

PagerAdapter:

public class PagerAdapter extends FragmentStatePagerAdapter { 
int mNumOfTabs; 

// an array of tab titles 
    private String tabTitles[] = new String[]{"CASUAL", "RANKED"}; 

public PagerAdapter(FragmentManager fm, int NumOfTabs) { 
    super(fm); 
    this.mNumOfTabs = NumOfTabs; 
    } 

@Override 
public Fragment getItem(int position) { 

    switch (position) { 
     case 0: 
      CasualStats tab1 = new CasualStats(); 
      return tab1; 
     case 1: 
      RankedStats tab2 = new RankedStats(); 
      return tab2; 
     default: 
      return null; 
     } 
    } 

    @Override 
    public int getCount() { 
     return mNumOfTabs; 
     } 

    @Override 
    public CharSequence getPageTitle(int position) { 
     return tabTitles[position]; 
    } 
} 
+0

Не повезло, такой же результат, как и раньше, viewpager не просматривает ничего. – Tachanka

+0

Добавить 'viewPager.setOffscreenPageLimit (2);' после вызова 'setupWithViewPager' также отлаживает ваш код, если он получает вызов' getItem (int position) ' – rafsanahmad007

+0

Он называет этот метод I c hecked с «Log» также viewPager.setOffscreenPageLimit (2); не помогает :( – Tachanka

0

Я чувствую себя глупо. Проблема была в ViewPager, как я подозревал. После 3-х отладки кода я просто переместил ViewPager из макета с вкладками в другой макет, который в основном соединяет все макеты.

+0

plz check my ответьте, надеюсь, что это поможет. –

0

Нижеприведенный образец кода работает отлично с помощью viewpager и вкладок. Попробуйте.

  1. Компонов деятельности

    <android.support.design.widget.AppBarLayout 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:theme="@style/AppTheme.AppBarOverlay"> 
    
        <android.support.v7.widget.Toolbar 
         android:id="@+id/toolbar" 
         android:layout_width="match_parent" 
         android:layout_height="?attr/actionBarSize" 
         android:background="?attr/colorPrimary" 
         app:popupTheme="@style/AppTheme.PopupOverlay" /> 
    
    </android.support.design.widget.AppBarLayout> 
    
    <android.support.design.widget.TabLayout 
        android:id="@+id/tab_container" 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:layout_marginTop="?attr/actionBarSize" /> 
    
    <include layout="@layout/content_main" /> 
    
    <android.support.design.widget.FloatingActionButton 
        android:id="@+id/fab" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_gravity="bottom|end" 
        android:layout_margin="@dimen/fab_margin" 
        app:srcCompat="@android:drawable/ic_dialog_email" /> 
    

Затем ViewPager расположение контейнера

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/content_main" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_marginTop="?attr/actionBarSize" 
    android:paddingBottom="@dimen/activity_vertical_margin" 
    android:paddingLeft="@dimen/activity_horizontal_margin" 
    android:paddingRight="@dimen/activity_horizontal_margin" 
    android:paddingTop="@dimen/activity_vertical_margin" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" 
    tools:context="com.test.myapplication.MainActivity" 
    tools:showIn="@layout/app_bar_main"> 

    <android.support.v4.view.ViewPager 
     android:id="@+id/page_container" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:background="#FF0000" /> 
</RelativeLayout> 

А вот основная деятельность часть:

package com.test.myapplication; 

import android.os.Bundle; 
import android.support.design.widget.FloatingActionButton; 
import android.support.design.widget.Snackbar; 
import android.support.design.widget.TabLayout; 
import android.support.v4.app.*; 
import android.support.v4.app.Fragment; 
import android.support.v4.view.ViewPager; 
import android.view.View; 
import android.support.design.widget.NavigationView; 
import android.support.v4.view.GravityCompat; 
import android.support.v4.widget.DrawerLayout; 
import android.support.v7.app.ActionBarDrawerToggle; 
import android.support.v7.app.AppCompatActivity; 
import android.support.v7.widget.Toolbar; 
import android.view.Menu; 
import android.view.MenuItem; 

public class MainActivity extends AppCompatActivity 
     implements NavigationView.OnNavigationItemSelectedListener { 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
     Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
     setSupportActionBar(toolbar); 

     FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); 
     fab.setOnClickListener(new View.OnClickListener() { 
      @Override 
      public void onClick(View view) { 
       Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) 
         .setAction("Action", null).show(); 
      } 
     }); 

     ViewPager pager = (ViewPager)findViewById(R.id.page_container); 
     pager.setAdapter(new Adapter(getSupportFragmentManager())); 
     TabLayout tabs = (TabLayout)findViewById(R.id.tab_container); 
     tabs.setupWithViewPager(pager, true); 
     DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
     ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
       this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
     drawer.setDrawerListener(toggle); 
     toggle.syncState(); 

     NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view); 
     navigationView.setNavigationItemSelectedListener(this); 
    } 

    @Override 
    public void onBackPressed() { 
     DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
     if (drawer.isDrawerOpen(GravityCompat.START)) { 
      drawer.closeDrawer(GravityCompat.START); 
     } else { 
      super.onBackPressed(); 
     } 
    } 

    @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 boolean onOptionsItemSelected(MenuItem item) { 
     // Handle action bar item clicks here. The action bar will 
     // automatically handle clicks on the Home/Up button, so long 
     // as you specify a parent activity in AndroidManifest.xml. 
     int id = item.getItemId(); 

     //noinspection SimplifiableIfStatement 
     if (id == R.id.action_settings) { 
      return true; 
     } 

     return super.onOptionsItemSelected(item); 
    } 

    @SuppressWarnings("StatementWithEmptyBody") 
    @Override 
    public boolean onNavigationItemSelected(MenuItem item) { 
     // Handle navigation view item clicks here. 
     int id = item.getItemId(); 

     if (id == R.id.nav_camera) { 
      // Handle the camera action 
     } else if (id == R.id.nav_gallery) { 

     } else if (id == R.id.nav_slideshow) { 

     } else if (id == R.id.nav_manage) { 

     } else if (id == R.id.nav_share) { 

     } else if (id == R.id.nav_send) { 

     } 

     DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
     drawer.closeDrawer(GravityCompat.START); 
     return true; 
    } 


    public static class Adapter extends FragmentStatePagerAdapter { 
     private String[] titles = new String[] {"ONE", "TWO"}; 

     public Adapter(FragmentManager fm) { 
      super(fm); 
     } 

     @Override 
     public Fragment getItem(int position) { 
      switch (position){ 
       case 0: 
        return new com.test.myapplication.Fragment(); 
       case 1: 
        return new Fragment1(); 
      } 
      return null; 
     } 

     @Override 
     public int getCount() { 
      return 2; 
     } 

     @Override 
     public CharSequence getPageTitle(int position) { 
      return titles[position]; 
     } 
    } 
} 
Смежные вопросы