官术网_书友最值得收藏!

Defining and inflating a layout

When using the Android Studio wizard to create a new project, it automatically creates the res/layout/activity_main.xml file (as shown in the following screenshot). It then inflates the XML file in the onCreate() callback with setContentView(R.layout.activity_main).

For this recipe, we will create two, slightly different layouts and switch between them with a button.

Getting ready

Create a new project in Android Studio and call it InflateLayout. Once the project is created, expand the res/layout folder so we can edit the activity_main.xml file.

How to do it...

  1. Edit the res/layout/activity_main.xml file so it includes a button as defined here:
    <Button
        android:id="@+id/buttonLeft"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Left Button"
        android:layout_centerVertical="true"
        android:layout_alignParentLeft="true"
        android:onClick="onClickLeft"/>
  2. Now make a copy of activity_main.xml and call it activity_main2.xml. Change the button so it matches the following:
    <Button
        android:id="@+id/buttonRight"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Right Button"
        android:layout_centerVertical="true"
        android:layout_alignParentRight="true"
        android:onClick="onClickRight"/>
  3. Open MainActivity.java and add the following two methods to handle the button clicks:
    public void onClickLeft(View view) {
        setContentView(R.layout.activity_main2);
    }
    
    public void onClickRight(View view) {
        setContentView(R.layout.activity_main);
    }
  4. Run this application on a device or emulator to see it in action.

How it works...

The key here is the call to setContentView(), which we have come across before in the autogenerated onCreate() code. Just pass a layout ID to setContentView() and it automatically inflates the layout.

This code is meant to make the concept easy to understand but would be overkill for simply changing the property of a Button (in this example, we could just change the alignment on the button click). Inflating the layout is usually needed once, in the onCreate() method, but there are times when you may want to manually inflate a layout, as we did here. (If you were manually handling orientation changes, it would be a good example.)

There's more...

As well as identifying a layout using a resource ID, as we did here, setContentView()can also take a View as an argument, for example:

findViewById(R.id.myView)
setContentView(myView);

See also

  • As mentioned previously, see the Fragment topic, in Chapter 5, Exploring Fragments, AppWidgets, and the System UI, for the alternative method to change the screen layout
主站蜘蛛池模板: 田阳县| 确山县| 紫金县| 新疆| 湖北省| 巴东县| 江西省| 淮北市| 南开区| 澄迈县| 嘉定区| 湄潭县| 泌阳县| 娄烦县| 清新县| 星座| 剑阁县| 肥城市| 陆良县| 平遥县| 三门峡市| 天祝| 阜宁县| 永寿县| 土默特左旗| 吉木萨尔县| 始兴县| 沾益县| 泽库县| 遂溪县| 桂东县| 重庆市| 壤塘县| 鹤庆县| 鄂托克旗| 临安市| 五台县| 行唐县| 富平县| 岐山县| 岑巩县|