FrameLayout和Fragment处理Android应用UI布局实例

作者:xyz_lmn 时间:2021-07-05 15:27:09 

将Fragment与Layout结合使用,一般都是主Activity以frame填充Activity的方式交互管理Fragment :

1.由于用到getSupportFragmentManager()之类,所以主Activity的extends需为FragmentActivity:


 public class MainActivity extends FragmentActivity{
   ..........
 }

2.主Activity的layout(xml文件)中建立多个Frame并定义其Android:id="@+id/XXX"
3.主Activity内操作函数中,由查找id来对这些FrameLayout进行Activity填充:
   添加语句如下


   getSupportFragmentManager().beginTransaction().add(R.id.fragment_container2,new NullFrag()).commit();


   取得支持Fragment管理()->开始交易()->添加(frame的id , Fragment).交付(); 
   替换语句如下
   getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container2,new NullFrag()).commit();
   取得支持Fragment管理()->开始交易()->替代(frame的id , Fragment).交付();
例:


    public void click_btn_flag02(View view){
         getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container2,new MidFrag()).commit();
    }


注:函数参数要用View

下面我们来看实例:

FrameLayout和Fragment处理Android应用UI布局实例
效果图的左边是一个列表,右边是列表item的详情。
先看一下布局文件(layout):


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal" android:layout_width="match_parent"
android:layout_height="match_parent">
<fragment
 class="com.fragment.main.TitlesFragment"
 android:id="@+id/titles" android:layout_weight="1"
 android:layout_width="0px" android:layout_height="match_parent" />
<FrameLayout android:id="@+id/details" android:layout_weight="1"
 android:layout_width="0px" android:layout_height="match_parent"
 android:background="?android:attr/detailsElementBackground" />
</LinearLayout>

        布局文件中使用了fragment标签和FrameLayout标签。Android Fragment使用 中介绍了2中嵌入Fragment的方法,这个实例中都用到,从布局文件看到有了fragment标签,这是一种使用方法,FrameLayout标签将会成为第二种加载fragment的载体view。
        看一下程序实现(com.fragment.main.TitlesFragment):


public class TitlesFragment extends ListFragment {

int mCurCheckPosition = 0;
int mShownCheckPosition = -1;

@Override
public void onActivityCreated(Bundle savedInstanceState) {
 super.onActivityCreated(savedInstanceState);

setListAdapter(new ArrayAdapter<String>(getActivity(),
   android.R.layout.simple_list_item_activated_1,
   Shakespeare.TITLES)); //使用静态数组填充列表
 if (savedInstanceState != null) {
  mCurCheckPosition = savedInstanceState.getInt("curChoice", 0);
  mShownCheckPosition = savedInstanceState.getInt("shownChoice", -1);
 }
  getListView().setChoiceMode(ListView.CHOICE_MODE_SINGLE);
  showDetails(mCurCheckPosition);
}

@Override
public void onSaveInstanceState(Bundle outState) {
 super.onSaveInstanceState(outState);

outState.putInt("curChoice", mCurCheckPosition);
 outState.putInt("shownChoice", mShownCheckPosition);
}

@Override
public void onListItemClick(ListView l, View v, int position, long id) {
 showDetails(position);
}

/**
 *显示listview item 详情
 */
void showDetails(int index) {
 mCurCheckPosition = index;
  getListView().setItemChecked(index, true);

if (mShownCheckPosition != mCurCheckPosition) {

DetailsFragment df = DetailsFragment.newInstance(index);
   FragmentTransaction ft = getFragmentManager()
     .beginTransaction();
   ft.replace(R.id.details, df);
   ft.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_FADE);
   ft.commit();
   mShownCheckPosition = index;
  }  
}

}

TitlesFragment
TitlesFragment继承自Fragment的子类ListFragment,使用了一个静态数组填充列表,重写了onListItemClick方法,showDetails方法展示ListView item的详情。


DetailsFragment df = DetailsFragment.newInstance(index);//获取详情Fragment的实例
FragmentTransaction ft = getFragmentManager().beginTransaction();//获取FragmentTransaction 实例
ft.replace(R.id.details, df); //使用DetailsFragment 的实例
ft.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_FADE);
ft.commit();//提交

看一下DetailsFragment :


public class DetailsFragment extends Fragment {

/**  * Create a new instance of DetailsFragment, initialized to  * show the text at 'index'.  */
public static DetailsFragment newInstance(int index) {
 DetailsFragment f = new DetailsFragment();
 // Supply index input as an argument.  
 Bundle args = new Bundle();
 args.putInt("index", index);
 f.setArguments(args);
 return f;
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
  Bundle savedInstanceState) {
 if (container == null) {    
  return null;
 }
 ScrollView scroller = new ScrollView(getActivity());
 TextView text = new TextView(getActivity());

int padding = (int) TypedValue.applyDimension(
   TypedValue.COMPLEX_UNIT_DIP, 4, getActivity().getResources()
     .getDisplayMetrics());
 text.setPadding(padding, padding, padding, padding);
 scroller.addView(text);
 text.setText(Shakespeare.DIALOGUE[getArguments().getInt("index", 0)]);
 return scroller;
}
}

 
DetailsFragment 中使用newInstance(int index)方法产生DetailsFragment 实例并接受整型参数,重载了onCreateView方法创建view。

标签:FrameLayout,Fragment
0
投稿

猜你喜欢

  • springboot自定义异常视图过程解析

    2023-06-29 09:44:36
  • java通过PDF模板填写PDF表单

    2022-05-28 16:37:48
  • .NET的深复制方法(以C#语言为例)

    2022-07-18 00:17:05
  • Android选择图片或拍照图片上传到服务器

    2022-12-15 01:48:41
  • Java中的static关键字你了解多少

    2022-05-21 11:25:51
  • Java实现替换PDF中的字体功能

    2023-10-04 13:24:17
  • Scala异常处理的方法深入分析

    2022-01-09 19:50:35
  • Android Build Variants 为项目设置变种版本的方法

    2023-04-26 10:29:07
  • Java和C#输入输出流的方法(详解)

    2022-06-24 09:21:02
  • c# socket编程udp客户端实现代码分享

    2023-06-16 05:03:31
  • C#实现汉字转换为拼音缩写的代码

    2021-11-21 04:04:51
  • C#使用Aspose.Cells创建和读取Excel文件

    2022-11-24 17:47:23
  • java中mybatis和hibernate的用法总结

    2022-08-23 07:24:38
  • 浅谈C#中的for循环与foreach循环

    2021-08-23 03:27:38
  • Maven项目修改JDK版本全过程

    2021-07-19 12:13:29
  • Mybatis TypeHandler接口及继承关系示例解析

    2021-11-19 03:33:34
  • Unity shader实现消融效果

    2023-03-06 01:06:44
  • Java并发问题之乐观锁与悲观锁

    2022-07-13 19:59:05
  • 基于java查找并打印输出字符串中字符出现次数

    2022-07-28 19:45:47
  • 基于NET Core 的Nuget包制作、发布和运用流程解析(完整过程)

    2022-03-10 01:09:29
  • asp之家 软件编程 m.aspxhome.com