2016-08-14 6 views
0

Ich entschuldige mich im Voraus, wenn diese Frage nicht so interessant ist, wie andere vielleicht erwarten. Erstens gibt es nicht viele Antworten auf Fragen zur neuesten Version von Android Studio (Version 2.1.2). Ich habe auch bemerkt, dass Leute selten die von der IDE bereitgestellten Vorlagen verwenden (ich glaube, dass sie dort den Entwicklungsprozess beschleunigen).Tabbed Activity Vorlage Android 2.1.2

Wie ändere ich den Code für die Vorlage "Tabbed Activity"? Ich starre derzeit auf den Code, der von der IDE für die Vorlage generiert wird. Ich habe keine Ahnung, wie ich es modifizieren kann, um die Fragmente für die drei Abschnitte, die es standardmäßig hat, einzuschließen. Ich habe den Code durchgesehen und die Struktur und die Teile teilweise verstanden, aber das ist völlig anders als die offiziellen Dokumente, die den Leuten sagen, dass sie es von Grund auf neu machen sollen.

Ich habe ein Fragment erstellt und hoffe, zwei weitere zu erstellen. Wie platziere ich sie mithilfe der Vorlage in den Tabs?

Kann mich bitte jemand durchsetzen und mich auch auf nützliche Materialien in dieser Hinsicht verweisen?

Ok von der aktuellen Struktur kann ich sehen, dass in der .java-Datei gibt es Code für die Aktivität und das Standard-Fragment (als Platzhalterfragment genannt). Ich habe versucht, das Standardfragment durch eines meiner Fragmente zu ersetzen, indem ich es in onCreateView() aufgerufen habe. Die Sache ist, wie füge ich andere Fragmente hinzu. Der Template-Code:

.java-Datei

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

Es ist diese .java-Datei, die ich dort zu denken hat, ist nur ein Fragment XML-Layout, aber es scheint, dass ein Trick, es über die zu replizieren verwendet wird drei Tabs (zusammen mit der TextView-Komponente). Meine Frage ist diese, ich habe meine eigenen Fragmente erstellt (mit ihren eigenen Verhaltensweisen), wie mache ich sie Teil der TabbedActivity? In welchem ​​Teil seines Codes lege ich es nieder? Auch wenn es nicht zu viel Mühe macht, kann jemand erklären, was eigentlich im Code los ist (ich meine den Bereich, in dem ein Fragment dreimal erscheint).

Das XML-Layout für die Aktivität selbst ist unten angegeben.

<?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

"Wie ändere ich den Code für die Tabbed Activity Vorlage?" - Da die Vorlagen je nach Android Studio-Version variieren, bearbeiten Sie Ihre Frage so, dass sie den Code enthält, der Sie verwirrt, indem Sie speziell auf das hinweisen, was Sie nicht verstehen. Auf diese Weise wird diese Frage heute und in Zukunft für Sie und andere von Nutzen sein. Außerdem haben nur wenige Leute den Code für diese Vorlage gespeichert. – CommonsWare

+0

Sie haben kein Codebeispiel hinzugefügt! Ich schlage vor, Sie lesen [Wie stelle ich eine gute Frage?] (Http://stackoverflow.com/help/how-to-ask). –

+0

@CommonsWare danke. Ich werde den Code einfügen und ausführlich erklären. Lass mich meinen Beitrag ändern. – user3650467

Antwort

0

Ich hoffe, dass dies jemand anderen hilft (da diese Frage ein Jahr alt ist, ich wette, Sie haben es bereits herausgefunden). Es ist eigentlich nicht so schwer. Die Vorlage ist zunächst überwältigend, aber mit ausreichender Aufmerksamkeit kann man sie verstehen. Wie auch immer, hier geht es:

Das erste, was ich ist dieses Stück Code bemerkt:

@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; 
} 

Wenn Sie die Rückkehr unter getCount ändern() auf, sagen wir, 2; und löschen Sie die Fall 2: unter getPageTitle (int Position), zeigt die Aktivität nur zwei Registerkarten.

Die Objekte erhalten in dieser Reihenfolge genannt: Erstens, SectionsPageAdapter in onCreate instanziiert get(). Dies endet mit dem Aufruf dieser Methode:

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

Wie Sie sehen können, das fragt PlaceholderFragment für eine neue Instanz für jede Registerkarte, die Sie festgelegt haben. Keine Notwendigkeit, hier etwas zu ändern.gehen wir nun zu PlaceholderFragment.newInstance (int 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; 
    } 

Also, es scheint, als ob es ein Argument (sectionNumber) definiert, setzt es und gibt das Fragment. Auch hier muss nichts geändert werden. Dann sieht es so aus, als ob es von der einzigen Methode abhängt, die wir noch nicht untersucht haben: onCreateView (Layout Inflatter inframe, ViewGroup container, Bundle savedInstanceState). Und es macht Sinn, da es das Bündel-Argument als Argument nimmt. Werfen wir einen Blick auf:

@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; 
    } 

Der Inhalt jedes Fragments sind hier definiert. Es wäre also sinnvoll, hier Änderungen vorzunehmen.

Dies ist ein Beispiel dafür, wie ich es für mein Projekt geändert:

@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; 
    } 

ich ein neues Layout für jede Registerkarte erstellt.