android ui布局实例,Android_FrameLayout和Fragment处理Android应用UI布局实例,将Fragment与Layout结合使用,一 - phpStudy...

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

将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

下面我们来看实例:

效果图的左边是一个列表,右边是列表item的详情。

先看一下布局文件(layout):

android:orientation="horizontal" android:layout_width="match_parent"

android:layout_height="match_parent">

class="com.fragment.main.TitlesFragment"

android:id="@+id/titles" android:layout_weight="1"

android:layout_width="0px" android:layout_height="match_parent" />

android:layout_width="0px" android:layout_height="match_parent"

android:background="?android:attr/detailsElementBackground" />

布局文件中使用了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(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。相关阅读:

jQuery实现折线图的方法

Android添加图片到ListView或者RecyclerView显示

Win10 PC系统地图定位不准的原因以及解决办法

jQuery中iframe的操作(点击按钮新增窗口)

C#中常见的系统内置委托用法详解

HTML5在canvas中绘制复杂形状附效果截图

推荐10个提供免费PHP脚本下载的网站

Replace关键字的妙用查询是否包含某个特定字符串

jQuery实现的倒计时效果实例小结

全面解析Bootstrap中Carousel轮播的使用方法

21天学习android开发教程之SQLite分页读取

JQuery通过AJAX从后台获取信息显示在表格上并支持行选中

Win7 32位中audiodg进程CPU占用率过高问题解决方法

Android编程使用自定义shape实现shadow阴影效果的方法

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值