2013-03-09 2 views
0

Я учусь создавать приложение на Android, и у меня есть проблема с функциональностью фрагмента.Android Fragment View не может выбрать макет

Я создал новую черную активность с использованием затмения и выбрав тип навигации «Прокрутить виды + название полосы».

Я побежал и он полностью работоспособен отображения Раздел 1, Раздел 2, Раздел 3. То, что я хотел сделать, это выбрать другой макет для каждой секции, так что я отлажены кода таким образом:

package fr.mpsn.networkclient; 

import android.R.layout; 
import android.os.Bundle; 
import android.support.v4.app.Fragment; 
import android.support.v4.app.FragmentActivity; 
import android.support.v4.app.FragmentManager; 
import android.support.v4.app.FragmentPagerAdapter; 
import android.support.v4.app.NavUtils; 
import android.support.v4.view.ViewPager; 
import android.util.Log; 
import android.view.Gravity; 
import android.view.LayoutInflater; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.TextView; 

public class HomeActivity extends FragmentActivity { 

    /** 
    * The {@link android.support.v4.view.PagerAdapter} that will provide 
    * fragments for each of the sections. We use a 
    * {@link android.support.v4.app.FragmentPagerAdapter} derivative, which 
    * will keep every loaded fragment in memory. If this becomes too memory 
    * intensive, it may be best to switch to a 
    * {@link android.support.v4.app.FragmentStatePagerAdapter}. 
    */ 
    SectionsPagerAdapter mSectionsPagerAdapter; 

    /** 
    * The {@link ViewPager} that will host the section contents. 
    */ 
    ViewPager mViewPager; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_home); 

     // Create the adapter that will return a fragment for each of the three 
     // primary sections of the app. 
     mSectionsPagerAdapter = new SectionsPagerAdapter(
       getSupportFragmentManager()); 

     // Set up the ViewPager with the sections adapter. 
     mViewPager = (ViewPager) findViewById(R.id.pager); 
     mViewPager.setAdapter(mSectionsPagerAdapter); 

    } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.activity_home, menu); 
     return true; 
    } 

    /** 
    * A {@link FragmentPagerAdapter} that returns a fragment corresponding to 
    * one of the sections/tabs/pages. 
    */ 
    public class SectionsPagerAdapter extends FragmentPagerAdapter { 

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

     @Override 
     public Fragment getItem(int position) { 
      // getItem is called to instantiate the fragment for the given page. 
      // Return a DummySectionFragment (defined as a static inner class 
      // below) with the page number as its lone argument. 
      Log.i("info", ""+position); 
      Fragment fragment = new DummySectionFragment("view_publishmessage"); 
      switch (position) { 
      case 0: 
       fragment =null; 
       fragment = new DummySectionFragment("view_publishmessage"); 
      case 1: 
       fragment =null; 
       fragment = new DummySectionFragment("view_timeline"); 
      case 2: 
       fragment =null; 
       fragment = new DummySectionFragment("view_profile"); 
      } 

      Bundle args = new Bundle(); 
      args.putInt(DummySectionFragment.ARG_SECTION_NUMBER, position + 1); 
      fragment.setArguments(args); 
      return fragment; 
     } 

     @Override 
     public int getCount() { 
      // Show 3 total pages. 
      return 3; 
     } 

     @Override 
     public CharSequence getPageTitle(int position) { 
      switch (position) { 
      case 0: 
       return "Nouvelle publication".toUpperCase(); 
      case 1: 
       return "Timeline".toUpperCase(); 
      case 2: 
       return "Profil".toUpperCase(); 
      } 
      return null; 
     } 
    } 

    /** 
    * A dummy fragment representing a section of the app, but that simply 
    * displays dummy text. 
    */ 
    public static class DummySectionFragment extends Fragment { 
     /** 
     * The fragment argument representing the section number for this 
     * fragment. 
     */ 
     public static final String ARG_SECTION_NUMBER = "section_number"; 
     public final String fragmentLayoutName; 

     public DummySectionFragment(String fragmentLayoutName) { 
      this.fragmentLayoutName = fragmentLayoutName; 
     } 

     @Override 
     public View onCreateView(LayoutInflater inflater, ViewGroup container, 
       Bundle savedInstanceState) { 
      // Create a new TextView and set its text to the fragment's section 
      // number argument value. 

      return inflater.inflate(
        this.getResources().getIdentifier(this.fragmentLayoutName, 
          "layout", "fr.mpsn.networkclient"), null); 
     } 
    } 

} 

Проблема в том, что вся разная секция использует макет профиля профиля, даже если случай правильно разобран ...

У вас есть идея, как я могу улучшить этот код, чтобы он работал лучше?

ответ

1

Вы не пропустили какое-то заявление break в своем switch? без него, кода перейти к следующему случаю:

switch(cond) { 
case A: 
    print("hello!"); 
    //break; 
case B: 
    print("hello again!"); 
    //break; 
} 
=> 
hello! 
hello again! 

Кроме того, лучше использовать пустой конструктор для фрагмента, в противном случае вы будете иметь проблемы, когда фрагмент будет создан заново (после изменения конфигурации для пример).
См Do fragments really need an empty constructor?

Вы можете использовать Fragment.setArguments() и Fragment.getArguments() передать свой fragmentLayoutName.

+0

Ха-ха, какой позор .... Спасибо nicopico! –

+0

Я создал новую версию этого кода немного лучше, я поделюсь им как ответом здесь, как только смогу ответить (низкие лимиты репутации), надеюсь, что это поможет людям, столкнувшимся с этой проблемой –

+0

Если nicopico исправил вашу проблему, вы должны принять его ответ. Кроме того, в новом ADT (21.1) ничего, кроме пустого конструктора, приводит к ошибке lint, и код не будет компилироваться. – Matt