读书人

使用Fragment实现动态格局

发布时间: 2013-10-02 13:10:38 作者: rapoo

使用Fragment实现动态布局

接着Fragment的简单使用一文继续探讨Fragment的使用,本文主要介绍使用Fragment实现动态UI布局,包括动态添加、替换、移除某个Fragment,至于Fragment之间的交互,后面在讨论。

MainActivity:

package com.home.testfragment;import android.os.Bundle;import android.support.v4.app.FragmentActivity;import android.support.v4.app.FragmentTransaction;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;public class MainActivity extends FragmentActivity implements OnClickListener {private Button addFirstFragmentBtn;private Button replaceFirstFragmentBtn;private Button removeFirstFragmentBtn;private FirstFragment firstFragment;@Overrideprotected void onCreate(Bundle arg0) {super.onCreate(arg0);setContentView(R.layout.main);addFirstFragmentBtn = (Button) findViewById(R.id.main_btn_add);replaceFirstFragmentBtn = (Button) findViewById(R.id.main_btn_replace);removeFirstFragmentBtn = (Button) findViewById(R.id.main_btn_remove);addFirstFragmentBtn.setOnClickListener(this);replaceFirstFragmentBtn.setOnClickListener(this);removeFirstFragmentBtn.setOnClickListener(this);addFirstFragmentBtn.setEnabled(true);removeFirstFragmentBtn.setEnabled(false);}@Overridepublic void onClick(View v) {if (v == addFirstFragmentBtn) {addFirstFragmentBtn.setEnabled(false);removeFirstFragmentBtn.setEnabled(true);if (findViewById(R.id.main_container) != null) {firstFragment = new FirstFragment();FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();transaction.add(R.id.main_container, firstFragment);// 把当前Fragment添加至回退栈,通过返回键返回时可以导航到上一个Fragment状态transaction.addToBackStack(null);// 提交transaction.commit();}}if (v == replaceFirstFragmentBtn) {addFirstFragmentBtn.setEnabled(true);removeFirstFragmentBtn.setEnabled(false);SecondFragment secondFragment = new SecondFragment();FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();transaction.replace(R.id.main_container, secondFragment);transaction.addToBackStack(null);transaction.commit();}if (v == removeFirstFragmentBtn) {addFirstFragmentBtn.setEnabled(true);removeFirstFragmentBtn.setEnabled(false);FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();transaction.remove(firstFragment);// 如果移除的时候也添加到回退栈,表示当前Fragment只是被停止而没有被摧毁,返回时它将恢复;// 那么如果不添加到回退栈则表示完全摧毁// transaction.addToBackStack(null);transaction.commit();}}}

FirstFragment:

package com.home.testfragment;import android.os.Bundle;import android.support.v4.app.Fragment;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;public class FirstFragment extends Fragment {@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_first, container, false);}}

SecondFragment:

package com.home.testfragment;import android.os.Bundle;import android.support.v4.app.Fragment;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;public class SecondFragment extends Fragment{@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_second, container, false);}}

main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent" >    <FrameLayout        android:id="@+id/main_container"        android:layout_width="match_parent"        android:layout_height="wrap_content" />    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_alignParentBottom="true"        android:orientation="horizontal" >        <Button            android:id="@+id/main_btn_add"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:text="添加" />        <Button            android:id="@+id/main_btn_replace"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:text="替换" />        <Button            android:id="@+id/main_btn_remove"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:text="移除" />    </LinearLayout></RelativeLayout>


fragment_first.xml:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical" >    <TextView        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:text="MyFirstFragment"        android:textSize="20sp" /></LinearLayout>

fragment_second.xml:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical" >    <TextView        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="MySecondFragment"        android:textSize="20sp" /></LinearLayout>






读书人网 >移动开发

热点推荐