res/layout/activity_main.xml的內容:html
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="horizontal" > <fragment class="com.example.demofragment.ListFragment" android:id="@+id/titles" android:layout_weight="1" android:layout_width="0px" android:layout_height="match_parent"/> </LinearLayout>
res/layout-land/activity_main.xml的內容:java
<?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="horizontal" > <fragment class="com.example.demofragment.ListFragment" android:id="@+id/titles" android:layout_weight="1" android:layout_width="0px" android:layout_height="match_parent"/> <FrameLayout android:id="@+id/detail" android:layout_weight="2" android:layout_width="0px" android:layout_height="match_parent"/> </LinearLayout>
package com.example.demofragment; /** * @author cjianquan * */ public final class Data { // public static final String[] TITLES={ "線性佈局", "表格佈局", "幀佈局", "相對佈局" }; public static final String[] DETAIL= { "線性佈局", "表格佈局", "幀佈局", "相對佈局" }; }
package com.example.demofragment; import android.app.FragmentTransaction; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.ArrayAdapter; import android.widget.ListView; public class ListFragment extends android.app.ListFragment { boolean dualPane; int curCheckPosition =0 ; public void onActivityCreated(Bundle savedInstanceState){ super.onActivityCreated(savedInstanceState); //爲列表設置適配器 setListAdapter(new ArrayAdapter<String>(getActivity(),android.R.layout.simple_list_item_checked,Data.TITLES)); //獲取佈局文件中添加的FragmentLayout幀佈局管理器 View detailFrame = getActivity().findViewById(R.id.detail); //判斷是否在一屏上同時顯示列表和詳細內容 dualPane = detailFrame != null && detailFrame.getVisibility() == View.VISIBLE; if(savedInstanceState!=null){ //更新當前選擇的索引位置 curCheckPosition = savedInstanceState.getInt("curChoice", 0); } if(dualPane){ //若是在一屏上同時顯示列表和詳細內容 //設置列表爲單選模式 getListView().setChoiceMode(ListView.CHOICE_MODE_SINGLE); //顯示詳細內容 showDetails(curCheckPosition); } } //保存當前選中的列表項的索引值 public void onSaveInstanceSate(Bundle outState){ super.onSaveInstanceState(outState); outState.putInt("curChoice", curCheckPosition); } public void onListItemClick(ListView l,View v,int position,long id){ showDetails(position);//調用showDetails方法顯示 詳細內容 } void showDetails(int index){ //更新保存當前索引位置的變量的值爲當前選中值 curCheckPosition = index; if(dualPane){//當在一屏上同時顯示列表和詳細內容時 //設置選中列表爲選中狀態 getListView().setItemChecked(index, true); //獲取 用於顯示詳細內容的fragment DetailFragment details = (DetailFragment)getFragmentManager().findFragmentById(R.id.detail); if(details == null || details.getShownIndex() != index){ //建立一個新的DetailFragment實例用於顯示當前選擇項對應的詳細內容 details = DetailFragment.newInstance(index); //要在activity中管理fragment,須要使用FragmentManager FragmentTransaction ft = getFragmentManager().beginTransaction(); //替換原來顯示的詳細內容 ft.replace(R.id.detail, details); //設置轉換效果 ft.setTransitionStyle(FragmentTransaction.TRANSIT_FRAGMENT_FADE); ft.commit(); } }else{//在一屏上只能顯示列表或詳細內容的一個內容時 //使用一個新的activity顯示詳細內容 Intent intent = new Intent(getActivity(),MainActivity.DetailActivity.class); intent.putExtra("index",index); startActivity(intent); } } }
package com.example.demofragment; import android.app.Fragment; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ScrollView; import android.widget.TextView; public class DetailFragment extends Fragment { public static DetailFragment newInstance(int index){ DetailFragment f = new DetailFragment(); Bundle bundle = new Bundle(); bundle.putInt("index", index); f.setArguments(bundle); return f; } public int getShownIndex(){ return getArguments().getInt("index",0); } public View onCreateView(LayoutInflater inflater,ViewGroup container,Bundle savedInstanceSate){ if(container == null){ return null; } ScrollView scroller = new ScrollView(getActivity()); TextView text = new TextView(getActivity()); text.setPadding(10, 10, 10, 10); text.setTextSize(30); scroller.addView(text); text.setText(Data.DETAIL[getShownIndex()]); return scroller; } }
package com.example.demofragment; import android.os.Bundle; import android.app.Activity; import android.content.res.Configuration; import android.view.Menu; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } public static class DetailActivity extends Activity { protected void onCreate(Bundle savedInstanceState){ super.onCreate(savedInstanceState); //判斷是否爲橫屏,若是爲橫屏,則結束當前Activity,準備使用Fragment顯示詳細內容 if(getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE){ finish(); return; } if(savedInstanceState == null){ DetailFragment details = new DetailFragment(); details.setArguments(getIntent().getExtras()); getFragmentManager().beginTransaction().add(android.R.id.content, details).commit(); } } } }
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.demofragment" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="14" android:targetSdkVersion="19" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.demofragment.MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <span style="color:#ff0000;"><activity android:name="com.example.demofragment.MainActivity$DetailActivity" android:label="詳細內容"/></span> </application> </manifest>