Fragment(碎片)的使用(左標題右內容實現)

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>

用於保存標題及內容的Data類:

package com.example.demofragment;

/**
 * @author cjianquan
 *
 */
public final class Data {
	//
	public static final String[] TITLES={
		"線性佈局",
		"表格佈局",
		"幀佈局",
		"相對佈局"
	};
	
	public static final String[] DETAIL= {
		"線性佈局",
		"表格佈局",
		"幀佈局",
		"相對佈局"
	};
	
	
}

列表碎片類ListFragment.java:

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);
		}
		
	}
	
	
}

詳細內容碎片類DetailFragment.java:

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;
		
	}
}

主入口類及用於顯示詳細內容的activity: MainActivity.java

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();
			}
		}
	}

}

AndroidManifest.xml文件內容以下:

<?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>

橫屏時的結果圖:

相關文章
相關標籤/搜索