Android learning route (22nd) uses Fragment to build a dynamic UI-to build a flexible UI

Source: Internet
Author: User

Android learning route (22nd) uses Fragment to build a dynamic UI-to build a flexible UI

Position first. Next Translation: p

When designing your application to support a wide range of screen sizes, you can reuse your fragments in different layout deployments to optimize the user experience based on the available screen space.

For example, on a handset device it might be appropriate to display just one fragment at a time for a single-pane user interface. conversely, you may want to set fragments side-by-side on a tablet which has a wider screen size to display more information to the user.

Figure 1. two fragments, displayed in different deployments for the same activity on different screen sizes. on a large screen, both fragments fit side by side, but on a handset device, only one fragment fits at a time so the fragments must replace each other as the user navigates.

TheFragmentManagerClass provides methods that allow you to add, remove, and replace fragments to an activity at runtime in order to create a dynamic experience.

Add a Fragment to an Activity at Runtime

Rather than defining the fragments for an activity in the layout file-as shown in the previous lesson with Element-you can add a fragment to the activity during the activity runtime. This is necessary if you plan to change fragments during the life of the activity.

To perform a transaction such as add or remove a fragment, you must useFragmentManagerTo createFragmentTransaction, Which provides APIs to add, remove, replace, and perform other fragment transactions.

If your activity allows the fragments to be removed and replaced, you should add the initial fragment (s) to the activity during the activity'sonCreate()Method.

An important rule when dealing with fragments-especially those that you add at runtime-is that the fragment must have a containerViewIn the layout in which the fragment's layout will reside.

The following layout is an alternative to the layout shown in the previous lesson that shows only one fragment at a time. In order to replace one fragment with another, the activity's layout provided des an emptyFrameLayoutThat acts as the fragment container.

Notice that the filename is the same as the layout file in the previous lesson, but the layout directory doesNotHavelargeQualifier, so this layout is used when the device screen is smallerLargeBecause the screen does not fit both fragments at the same time.

res/layout/news_articles.xml:

<frameLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:id="@+id/fragment_container"    android:layout_width="match_parent"    android:layout_height="match_parent" />

Inside your activity, callgetSupportFragmentManager()To getFragmentManagerUsing the Support Library APIs. Then callbeginTransaction()To createFragmentTransactionAnd calladd()To add a fragment.

You can perform multiple fragment transaction for the activity using the sameFragmentTransaction. When you're ready to make the changes, you must callcommit().

For example, here's how to add a fragment to the previous layout:

import android.os.Bundle;import android.support.v4.app.FragmentActivity;public class MainActivity extends FragmentActivity {    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.news_articles);        // Check that the activity is using the layout version with        // the fragment_container FrameLayout        if (findViewById(R.id.fragment_container) != null) {            // However, if we're being restored from a previous state,            // then we don't need to do anything and should return or else            // we could end up with overlapping fragments.            if (savedInstanceState != null) {                return;            }            // Create a new Fragment to be placed in the activity layout            HeadlinesFragment firstFragment = new HeadlinesFragment();                        // In case this activity was started with special instructions from an            // Intent, pass the Intent's extras to the fragment as arguments            firstFragment.setArguments(getIntent().getExtras());                        // Add the fragment to the 'fragment_container' FrameLayout            getSupportFragmentManager().beginTransaction()                    .add(R.id.fragment_container, firstFragment).commit();        }    }}

Because the fragment has been added toFrameLayoutContainer at runtime-instead of defining it in the activity's layout with Element-the activity can remove the fragment and replace it with a different one.

Replace One Fragment with Another

The procedure to replace a fragment is similar to adding one, but requiresreplace()Method insteadadd().

Keep in mind that when you perform fragment transactions, such as replace or remove one, it's often appropriate to allow the user to navigate backward and "undo" the change. to allow the user to navigate backward through the fragment transactions, you must calladdToBackStack()Before you commitFragmentTransaction.

Note:When you remove or replace a fragment and add the transaction to the back stack, the fragment that is removed is stopped (not destroyed ). if the user navigates back to restore the fragment, it restarts. if youDo notAdd the transaction to the back stack, then the fragment is destroyed when removed or replaced.

Example of replacing one fragment with another:

// Create fragment and give it an argument specifying the article it should showArticleFragment newFragment = new ArticleFragment();Bundle args = new Bundle();args.putInt(ArticleFragment.ARG_POSITION, position);newFragment.setArguments(args);FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();// Replace whatever is in the fragment_container view with this fragment,// and add the transaction to the back stack so the user can navigate backtransaction.replace(R.id.fragment_container, newFragment);transaction.addToBackStack(null);// Commit the transactiontransaction.commit();

TheaddToBackStack()Method takes an optional string parameter that specifies a unique name for the transaction. The name isn't needed unless you plan to perform advanced fragment operations usingFragmentManager.BackStackEntryAPIs.


Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.