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

 更新时间:2016年02月25日 11:28:13   作者:xyz_lmn  
这篇文章主要介绍了FrameLayout和Fragment处理Android应用UI布局实例,安卓3.0以后Fragment的出现为多尺寸屏幕的适配带来了方便,需要的朋友可以参考下

将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

下面我们来看实例:

2016225112753148.gif (800×600)
效果图的左边是一个列表,右边是列表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。

相关文章

  • Android即时通讯设计(腾讯IM接入和WebSocket接入)

    Android即时通讯设计(腾讯IM接入和WebSocket接入)

    本文主要介绍了Android即时通讯设计(腾讯IM接入和WebSocket接入),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Android中的存储详解

    Android中的存储详解

    大家好,本篇文章主要讲的是Android中的存储详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2022-01-01
  • 修改Android App样式风格的方法

    修改Android App样式风格的方法

    本文讲的是如何修改Android App样式风格的方法,具体可以看下面的代码
    2013-11-11
  • Android canvas drawBitmap方法详解及实例

    Android canvas drawBitmap方法详解及实例

    这篇文章主要介绍了 Android canvas drawBitmap方法详解及实例的相关资料,需要的朋友可以参考下
    2017-01-01
  • 解决webview内的iframe中的事件不可用的问题

    解决webview内的iframe中的事件不可用的问题

    这篇文章主要介绍了解决webview内的iframe中的事件不可用的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • 简单实现Android数独游戏

    简单实现Android数独游戏

    这篇文章主要教大家如何简单实现Android数独游戏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • Android XML数据解析简单示例

    Android XML数据解析简单示例

    这篇文章主要介绍了Android XML数据解析简单示例,本文直接给出了实现代码,需要的朋友可以参考下
    2014-10-10
  • Android图片加载框架Coil的详细使用总结

    Android图片加载框架Coil的详细使用总结

    Coil是Android上的一个全新的图片加载框架,它的全名叫做coroutine image loader,即协程图片加载库,下面这篇文章主要给大家介绍了关于Android图片加载框架Coil详细使用的相关资料,需要的朋友可以参考下
    2022-07-07
  • Android RecyclerView使用方法解析

    Android RecyclerView使用方法解析

    这篇文章主要为大家详细解析了Android RecyclerView使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • Android网络通信基础类源码分析讲解

    Android网络通信基础类源码分析讲解

    这篇文章主要介绍了Android网络通信基础类源码,包括了Handler、Looper、Thread的分析讲解,对日常开发学习很有帮助,需要的朋友可以参考下
    2024-05-05

最新评论