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

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
主站蜘蛛池模板: 清水县| 杨浦区| 家居| 龙州县| 缙云县| 德令哈市| 和静县| 河西区| 金昌市| 新泰市| 施秉县| 遂川县| 定州市| 雅江县| 伊吾县| 洛浦县| 阿克陶县| 乐都县| 桂林市| 柳江县| 通化市| 岳阳县| 壶关县| 普兰店市| 义马市| 南宁市| 江永县| 衡东县| 黎平县| 盐边县| 芷江| 桃园县| 云林县| 西昌市| 五华县| 石首市| 阳泉市| 桂平市| 红安县| 鄂尔多斯市| 开原市|