今天看到一篇好文章

https://www.2cto.com/kf/201609/545979.html

转载过来记录一下,往后需要的时候可以随时查看;

接下来进入正题:

动态fragment的使用

对于动态的使用fragment,就是简单的底部多个按钮,然后多个fragment进行切换,这个应该很简单,平时都在用。

MainActivity:

/**
* 主布局
* @author Rine
* @version 1.0, 2015-12-1
*/
public class MainActivity extends FragmentActivity{
MainDB mdata = new MainDB(); /**
* 定义结束时间
*/
private long exitTime = 0; /**
* 定义FragmentTabHost对象
*/
private FragmentTabHost mTabHost; /**
* 定义一个布局
*/
private LayoutInflater layoutInflater; /**
* 定义数组来存放Fragment界面
*/
private Class fragmentArray[] = mdata.fragmentArray; /**
* 定义数组来存放按钮图片
*/
private int mImageViewArray[] = mdata.ImageViewArray; /**
* Tab选项卡的文字
*/
private String mTextviewArray[] = mdata.TextviewArray; @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// CloudOnlyDB dbHelper;
// dbHelper = new CloudOnlyDB(MainActivity.this);
// HomeData home = new HomeData(MainActivity.this);
initView( );
} /**
* 初始化组件
*/
private void initView (){
/**
* 实例化布局对象
*/
layoutInflater = LayoutInflater.from(this); /**
* 实例化TabHost对象,得到TabHost
*/
mTabHost = (FragmentTabHost)findViewById(android.R.id.tabhost);
mTabHost.setup(this, getSupportFragmentManager(), R.id.container); //加载内容 /**
* 得到fragment的个数
*/
int count = fragmentArray.length; for(int i = 0; i < count; i++){
TabSpec tabSpec = mTabHost.newTabSpec(mTextviewArray[i]).setIndicator(getTabItemView(i)); //为每一个Tab按钮设置图标、文字和内容
mTabHost.addTab(tabSpec, fragmentArray[i], null); //将Tab按钮添加进Tab选项卡中
} } /**
* 给Tab按钮设置图标和文字
*/
private View getTabItemView(int index){
View view = layoutInflater.inflate(R.layout.main_tab_view, null); ImageView imageView = (ImageView) view.findViewById(R.id.imageview);
imageView.setImageResource(mImageViewArray[index]);
TextView textView = (TextView) view.findViewById(R.id.textview);
textView.setText(mTextviewArray[index]);
return view;
} /**
* 2次退出效果
*/
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
exit(); //按返回键,true则退出
return false;
}
return super.onKeyDown(keyCode, event);
} public void exit() { //按返回退出
if ((System.currentTimeMillis() - exitTime) > 2000) {
Toast.makeText(getApplicationContext(), "再按一次退出程序",
Toast.LENGTH_SHORT).show();
exitTime = System.currentTimeMillis();
} else { //退出
finish();
System.exit(0);
} } }

MainAcitivity 中的MainDB

/**
* 存放主布局数据
* @author Rine
* @version 1.0, 2015-12-1
*/
public class MainDB {
/**
* 定义数组来存放Fragment界面
*/
public Class fragmentArray[] = {one.class,two.class,three.class};
/**
* 定义数组来存放按钮图片
*/
public int ImageViewArray[] = {R.drawable.home,R.drawable.ccarticle,
R.drawable.ccone};
/**
* Tab选项卡的文字
*/
public String TextviewArray[] = {"one","twom","three"};
}

MainActivity 相应的布局:

<!--?xml version="1.0" encoding="utf-8"?-->
<!-- Rine -->
<!-- 功能:主布局 --> <linearlayout android:layout_height="fill_parent" android:layout_width="fill_parent" android:orientation="vertical" xmlns:android="https://schemas.android.com/apk/res/android"> <framelayout android:id="@+id/container" android:layout_height="0dp" android:layout_weight="1" android:layout_width="fill_parent"> <framelayout android:id="@android:id/tabcontent" android:layout_height="0dp" android:layout_weight="0" android:layout_width="0dp">
</framelayout></android.support.v4.app.fragmenttabhost> </framelayout></linearlayout>

相应的style:

<style name="homework_tab_item" type="text/css"><item name="android:layout_width">0dp</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_weight">1</item>
<item name="android:button">@null</item>
<item name="android:gravity">center</item>
<item name="android:textColor">@color/homework_tab_item_text_color</item></style>

相应的 color:

<!--?xml version="1.0" encoding="utf-8"?-->
<selector xmlns:android="https://schemas.android.com/apk/res/android"> <item android:color="#000000" android:state_checked="true">
<item android:color="#757575"> </item></item></selector>

fragment嵌套fragment

这就是简单动态fragment的应该。这也是其中的一种方法。

然后就是在其fragment中再嵌套多个fragment,我采用的是利用单选按钮来实现,当然单选按钮外面还要包一层RadioGroup。

Activity:

/**
* fragment嵌套fragment
* @author Rine
* @version 1.0, 2015-12-1
*/
public class two extends Fragment implements OnClickListener
{
/**
* 定义一个布局
*/
private LayoutInflater inflater;
// private View rootView;// 缓存Fragment view
private Context mainActivity;
private TwoToOne twoToOne;
private TwoToTwo twoToTwo;
/**
* one、two RadioGroup 控件
*/
private RadioGroup twoGroup;
protected RadioButton twoOne, twoTwo; /**
* 加载页面
*/
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
mainActivity = getActivity();
inflater = LayoutInflater.from(getActivity());
// 初始化控件和声明事件
// rootView = inflater.inflate(R.layout.two, null);
twoGroup = (RadioGroup) getActivity().findViewById(R.id.two_group);
twoOne = (RadioButton) getActivity().findViewById(R.id.two_one);
twoTwo = (RadioButton) getActivity().findViewById(R.id.two_two);
//控件颜色
twoOne.setTextColor(getResources().getColor(R.color.red));
twoTwo.setTextColor(getResources().getColor(R.color.black));
twoOne.setOnClickListener(this);
twoTwo.setOnClickListener(this); setDefaultFragment();
}
/**
* 设置默认的Fragment
*/
private void setDefaultFragment()
{
FragmentManager fm = getFragmentManager();
FragmentTransaction transaction = fm.beginTransaction();
twoToOne = new TwoToOne();
transaction.add(R.id.framelayout, twoToOne).commit();
} @Override
public void onClick(View v) {
FragmentManager fm = getFragmentManager();
// 开启Fragment事务
FragmentTransaction transaction = fm.beginTransaction(); switch (v.getId())
{
case R.id.two_one:
if (twoToOne == null)
{
twoToOne = new TwoToOne();
}
// 使用当前Fragment的布局替代id_content的控件
transaction.replace(R.id.framelayout, twoToOne);
//控件颜色
twoOne.setTextColor(getResources().getColor(R.color.red));
twoTwo.setTextColor(getResources().getColor(R.color.black));
break;
case R.id.two_two:
if (twoToTwo == null)
{
twoToTwo = new TwoToTwo();
}
transaction.replace(R.id.framelayout, twoToTwo);
//控件颜色
twoOne.setTextColor(getResources().getColor(R.color.black));
twoTwo.setTextColor(getResources().getColor(R.color.red));
break;
}
// transaction.addToBackStack();
// 事务提交
transaction.commit();
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
return inflater.inflate(R.layout.two, null); } }

其对应的布局:

<!--?xml version="1.0" encoding="utf-8"?-->
<linearlayout android:layout_height="match_parent" android:layout_width="match_parent" android:orientation="vertical" xmlns:android="https://schemas.android.com/apk/res/android">
<relativelayout android:background="@color/white" android:layout_height="@dimen/height_title" android:layout_width="match_parent">
<linearlayout android:id="@+id/layout_brck" android:layout_height="match_parent" android:layout_marginleft="@dimen/margin_15dp" android:layout_width="wrap_content" android:orientation="horizontal"> </linearlayout>
<radiogroup android:gravity="center" android:id="@+id/two_group" android:layout_centerinparent="true" android:layout_height="wrap_content" android:layout_width="wrap_content" android:orientation="horizontal"> <radiobutton android:background="@null" android:checked="true" android:id="@+id/two_one" android:layout_marginright="@dimen/margin_20dp" android:text="one" android:textcolor="@color/black" android:textsize="@dimen/title_textsize_22sp" style="@style/homework_tab_item"> <radiobutton android:background="@null" android:id="@+id/two_two" android:layout_margin="5dp" android:layout_marginleft="@dimen/margin_20dp" android:text="two" android:textcolor="@color/black" android:textsize="@dimen/title_textsize_22sp" style="@style/homework_tab_item">
</radiobutton></radiobutton></radiogroup> <view android:background="@color/br_title_color" android:layout_alignparentbottom="true" android:layout_height="0.1dp" android:layout_width="match_parent">
</view></relativelayout> <framelayout android:id="@+id/framelayout" android:layout_height="0dp" android:layout_weight="1" android:layout_width="match_parent">
</framelayout> </linearlayout>

OK。大体就是这样了。示例图如下:

关于Fragment里面嵌套fragment的更多相关文章

  1. Fragment里面嵌套Fragment的问题

    最近两天做项目时,要在fragment里面嵌套Fragment,最开始使用Fragment的hide,show等方法一直失败,,如图,message是一个fragment,在里面又有两个子fragme ...

  2. 关于TabLayout与ViewPager在Fragment中嵌套Fragment使用或配合使用的思考

    注意: 因为继承的是Fragment,所以getSupportFragmentManager()与getFragmentManager()方法无法使用,这里需要用到getChildFragmentMa ...

  3. Android 中关于Fragment嵌套Fragment的问题

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/5802146.html 问题描述: 在项目中Activity A中嵌套Fragment B,Fragment ...

  4. android fragment嵌套fragment出现的问题:no activity

    package com.example.fragmentNavigation2.fragment; import android.content.Context; import android.os. ...

  5. 嵌套fragment时必须要重写 onDetach()

    /**     * 嵌套fragment时必须要重写 onDetach()如下     */ @Override public void onDetach() { super.onDetach(); ...

  6. fragment中嵌套viewpager,vierpager中有多个fragment,不显示 .

    fragment中嵌套viewpager,vierpager中有多个fragment,不显示 ... 现在好多应用流行一种布局.底部几个工具栏选项,上面也有类似tab的选项. 底部用RadioGrou ...

  7. Fragment嵌套Fragment时候。子类fragment调用父容器Fragment方法

    业务场景:有的时候我们的页面可能是Activity 嵌套多个Fragment ..其中某个Fragment 又嵌套多个Fragment. 其中某个子Fragment  定义为  NewsFragmen ...

  8. Android FragmentActivity 嵌套 Fragment 调用startActivityForResult返回的requestCode错误

    Android FragmentActivity 嵌套 Fragment 调用startActivityForResult返回的requestCode错误 此时,要在调用startActivityFo ...

  9. Android流行界面结构——Fragment通过ViewPager(带指示器)嵌套Fragment结构的创建方法详解

    原创文章,转载请注明出处http://www.cnblogs.com/baipengzhan/p/6287213.html 当前Android流行界面结构的一种——Fragment通过ViewPage ...

随机推荐

  1. Java基础面试知识点总结

    微信公众号[程序员江湖] 作者黄小斜,斜杠青年,某985硕士,阿里 Java 研发工程师,于 2018 年秋招拿到 BAT 头条.网易.滴滴等 8 个大厂 offer,目前致力于分享这几年的学习经验. ...

  2. c#发送邮件,可发送多个附件

    1:创建SendMail类 2:调用方法 SendMail send = new SendMail("123456@qq.com", "123456@163.com&qu ...

  3. .NET Core:依赖注入

      在Startup的ConfigureServices方法中加入需要依赖注入的东西. 每次从容器 中获取的时候都是一个新的实例:services.AddTransient<ITransient ...

  4. 软件开发架构介绍||OSI七层协议之物理层、数据链路层、网络层、传输层(mac地址、ip协议、断开协议、tcp协议之三次握手四次挥手)

    一.网络编程 软件开发架构 C/S架构 C:客户端 想体验服务的时候才会去找服务端体验服务 S:服务端   24小时不间断的提供服务,即时监听,随时待命 B/S架构 B:浏览器    想体验服务的时候 ...

  5. 【原】无脑操作:TypeScript环境搭建

    概述:本文描述TypeScript环境搭建,以及基于VSCode的自动编译设置和调试设置.网络上很多相应文章的方式过时了或者无法试验成功. ------------------------------ ...

  6. python3 生成器初识 NLP第五条

    话不多说,先把第五条抄一遍: 五,沟通的意义在于对方的回应 沟通没有对与错,只有“有效果”或者“没有效果”之分. 自己说得多“对”没有意义,对方收到你想表达的讯息才是沟通的意义. 因此自己说什么不重要 ...

  7. c++ 之模板进阶

    c++中的多态主要体现在模板与继承上. 继承可以理解为有相互关系的不同数据结构的集合. 而模板则是完全独立的数据结构,彼此无需依赖 在函数中使用模板, 可以根据函数传入的参数自动推导类型,从而省略到很 ...

  8. 终于等到你:CYQ.Data V5系列 (ORM数据层,支持.NET Core)最新版本开源了

    前言: 不要问我框架为什么从收费授权转到免费开源,人生没有那么多为什么,这些年我开源的东西并不少,虽然这个是最核心的,看淡了就也没什么了. 群里的网友:太平说: 记得一年前你开源另一个项目的时候我就说 ...

  9. break、continue以及return的区别

    break.continue以及return的区别如下: 1.break break用于完全结束一个循环,跳出循环体,不再执行下面的代码.对于多层循环嵌套,如果break语句出现在嵌套循环中的内循环时 ...

  10. 微软跨平台ORM框架之EFCore — 约定与属性映射

    EFCore中的约定简单来说就是规则,CodeFirst基于模型的约定来映射表结构.除此之外还有Fluent API.Data Annotations(数据注释) 可以帮助我们进一步配置模型. 按照这 ...