2016-08-14 3 views
0

Я заранее извиняюсь, если этот вопрос НЕ интересен, как другие могут ожидать. Во-первых, не так много ответов на вопросы о самой последней версии Android Studio (то есть версии 2.1.2). Также я заметил, что люди редко используют шаблоны, предоставленные IDE (я считаю, что там ускоряется процесс разработки).Tabbed Activity template Android 2.1.2

Как мне изменить код шаблона вкладок? В настоящее время я смотрю на код, созданный IDE для шаблона. Я не знаю, как модифицировать его, чтобы включить фрагменты для трех разделов, которые он имеет по умолчанию. Я перешел кодекс и в какой-то степени понимаю структуру и то, что делают части, но она делает это таким образом, который полностью отличается от того, как официальные документы говорят людям делать это с нуля.

Я создал один фрагмент и надеюсь создать еще два. Как разместить их внутри вкладок с помощью шаблона?

Может ли кто-то просить меня, а также направлять меня к полезным материалам в этом отношении?

ОК из текущей структуры, я вижу, что в файле .java есть код для Activity и по умолчанию Fragment (называемый фрагментом-заполнителем). Я попытался заменить фрагмент по умолчанию одним из своих фрагментов, вызвав его в onCreateView(). Дело в том, как добавить другие фрагменты. Код шаблона:

.java файл

package name; 
public class myUI extends AppCompatActivity { 

/** 
* The {@link android.support.v4.view.PagerAdapter} that will provide 
* fragments for each of the sections. We use a 
* {@link 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}. 
*/ 
private SectionsPagerAdapter mSectionsPagerAdapter; 

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

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

    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 
    // Create the adapter that will return a fragment for each of the three 
    // primary sections of the activity. 
    mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); 

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

    TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs); 
    tabLayout.setupWithViewPager(mViewPager); 

    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(); 
     } 
    }); 

} 


@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.menu_my_UI, 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); 
} 

/** 
* A placeholder fragment containing a simple view. 
*/ 
public static class PlaceholderFragment extends Fragment { 
    /** 
    * The fragment argument representing the section number for this 
    * fragment. 
    */ 
    private static final String ARG_SECTION_NUMBER = "section_number"; 

    public PlaceholderFragment() { 
    } 

    /** 
    * Returns a new instance of this fragment for the given section 
    * number. 
    */ 
    public static PlaceholderFragment newInstance(int sectionNumber) { 
     PlaceholderFragment fragment = new PlaceholderFragment(); 
     Bundle args = new Bundle(); 
     args.putInt(ARG_SECTION_NUMBER, sectionNumber); 
     fragment.setArguments(args); 
     return fragment; 
    } 

    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
          Bundle savedInstanceState) { 
     View rootView = inflater.inflate(R.layout.fragment_my_UI, container, false); 
     TextView textView = (TextView) rootView.findViewById(R.id.section_label); 
     textView.setText(getString(R.string.section_format, getArguments().getInt(ARG_SECTION_NUMBER))); 
     return rootView; 
    } 
} 

/** 
* 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 PlaceholderFragment (defined as a static inner class below). 
     return PlaceholderFragment.newInstance(position + 1); 
    } 

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

    @Override 
    public CharSequence getPageTitle(int position) { 
     switch (position) { 
      case 0: 
       return "SECTION 1"; 
      case 1: 
       return "SECTION 2"; 
      case 2: 
       return "SECTION 3"; 
     } 
     return null; 
    } 
} 
} 

Именно этот .java файл, который имеет меня думать, есть только один фрагмент XML макет, но представляется, что трюк используется для репликации его поперек три вкладки (вместе с компонентом TextView в нем). Мой вопрос в том, что у меня есть собственные Фрагменты, созданные (с их собственным поведением), как я могу сделать их частью TabbedActivity? В какой части его кода я его поместил? Кроме того, если не сложно, может кто-то объяснить, что на самом деле происходит в коде (я имею в виду область, где один фрагмент появляется три раза)?

Формат XML для самой активности приведен ниже.

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 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/main_content" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:fitsSystemWindows="true" 
tools:context="com.myProject.myProject.MyUI"> 

<android.support.design.widget.AppBarLayout 
    android:id="@+id/appbar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:paddingTop="@dimen/appbar_padding_top" 
    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:layout_scrollFlags="scroll|enterAlways" 
     app:popupTheme="@style/AppTheme.PopupOverlay"> 

    </android.support.v7.widget.Toolbar> 

    <android.support.design.widget.TabLayout 
     android:id="@+id/tabs" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" /> 

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

<android.support.v4.view.ViewPager 
    android:id="@+id/container" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="end|bottom" 
    android:layout_margin="@dimen/fab_margin" 
    android:src="@android:drawable/ic_dialog_email" /> 

</android.support.design.widget.CoordinatorLayout> 
+0

«Как изменить код шаблона с вкладкой?» - поскольку шаблоны отличаются версией Android Studio, пожалуйста, отредактируйте свой вопрос, чтобы включить код, который вас смущает, указывая конкретно, что вы не понимаете. Таким образом, этот вопрос принесет пользу и другим, и вам, и сегодня, и в будущем. Кроме того, у немногих людей есть код для запоминания этого шаблона. – CommonsWare

+0

Вы не указали код! Я предлагаю вам прочитать [Как задать хороший вопрос?] (Http://stackoverflow.com/help/how-to-ask). –

+0

@CommonsWare спасибо. Я вставлю код и объясню подробно. Позвольте мне изменить свой пост. – user3650467

ответ

0

Я надеюсь, что это поможет кому-то еще (так как этот вопрос один год, я готов поспорить, вы уже поняли это). На самом деле это не так сложно. Сначала шаблон является подавляющим, но с достаточным вниманием вы можете это понять. Во всяком случае, здесь идет:

Первое, что я заметил, этот кусок кода:

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

@Override 
public CharSequence getPageTitle(int position) { 
    switch (position) { 
     case 0: 
      return "SECTION 1"; 
     case 1: 
      return "SECTION 2"; 
     case 2: 
      return "SECTION 3"; 
    } 
    return null; 
} 

Если изменить возвращение под GetCount(), скажем, 2; и удалите случай 2: под getPageTitle (int position), активность показывает только две вкладки.

Объектами дозвонились в следующем порядке: Во-первых, SectionsPageAdapter получить экземпляр в OnCreate(). Это заканчивается вызовом этого метода:

@Override 
    public Fragment getItem(int position) { 
     // getItem is called to instantiate the fragment for the given page. 
     // Return a PlaceholderFragment (defined as a static inner class below). 
     return PlaceholderFragment.newInstance(position + 1); 
    } 

Как вы можете видеть, это спрашивает PlaceholderFragment для нового экземпляра для каждой вкладки вы указали. Здесь ничего не нужно менять.Теперь давайте перейдем к PlaceholderFragment.newInstance (интермедиат sectionNumber) ...

/** 
    * Returns a new instance of this fragment for the given section 
    * number. 
    */ 
    public static PlaceholderFragment newInstance(int sectionNumber) { 
     PlaceholderFragment fragment = new PlaceholderFragment(); 
     Bundle args = new Bundle(); 
     args.putInt(ARG_SECTION_NUMBER, sectionNumber); 
     fragment.setArguments(args); 
     return fragment; 
    } 

Таким образом, кажется, что он определяет аргумент (sectionNumber), устанавливает его и возвращает фрагмент. Не нужно ничего менять и здесь. Тогда похоже, что это зависит от единственного метода, который мы еще не рассмотрели: onCreateView (надувной элемент LayoutInflater, контейнер ViewGroup, пакетное хранилищеInstanceState). И это имеет смысл, поскольку в качестве аргумента он принимает аргумент Bundle. Давайте посмотрим:

@Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
          Bundle savedInstanceState) { 
     View rootView = inflater.inflate(R.layout.fragment_main, container, false); 
     TextView textView = (TextView) rootView.findViewById(R.id.section_label); 
     textView.setText(getString(R.string.section_format, getArguments().getInt(ARG_SECTION_NUMBER))); 
     return rootView; 
    } 

Содержание каждого фрагмента определено здесь. Таким образом, было бы целесообразно внести здесь свои изменения.

Это пример того, как я изменил его для моего проекта:

@Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
          Bundle savedInstanceState) { 
     View rootView; 
     TextView textView; 
     switch (getArguments().getInt(ARG_SECTION_NUMBER)) { 
      case 1: 
       rootView = inflater.inflate(R.layout.fragment_infraestructuras, container, false); 
       textView = (TextView) rootView.findViewById(R.id.section_label1); 
       textView.setText("Infraestructuras"); 
       return rootView; 
      case 2: 
       rootView = inflater.inflate(R.layout.fragment_incidentes, container, false); 
       textView = (TextView) rootView.findViewById(R.id.section_label2); 
       textView.setText("Incidentes"); 
       return rootView; 
     } 
     return null; 
    } 

Я создал новый макет для каждой вкладки.

Смежные вопросы