ViewPager + Fragment Fragment內跳轉

本文介绍了一种使用ViewPager和FragmentPagerAdapter实现动态切换Fragment的方法。通过维护Fragment实例的栈,可以轻松地管理页面间的导航和回退操作。文章还详细解释了如何通过覆写方法来更新Fragment的内容,并提供了关键代码示例。

viewpager 設置FragmentPagerAdapter。

public class ViewPagerAdapter extends FragmentPagerAdapter {


private BaseFragment mFragmentAtPos0, mFragmentAtPos1; // Fragment at index
// 0
private MyStack stackat0;
private MyStack stackat1;
private final FragmentManager mFragmentManager;


private static final int NUM_OF_ITEMS = 4; // No of ViewPager items


public ViewPagerAdapter(FragmentManager fm) {
super(fm);
mFragmentManager = fm;
stackat0 = new MyStack();
stackat1 = new MyStack();
}


@Override
public Fragment getItem(int position) {
if (position == 0) {
if (mFragmentAtPos0 == null) {
mFragmentAtPos0 = Mainfragment.newInstance();
stackat0.push(mFragmentAtPos0);
}
return mFragmentAtPos0;
} else if (position == 1) {
if (mFragmentAtPos1 == null) {
mFragmentAtPos1 = ArticleListForscFragment.newInstance();
stackat1.push(mFragmentAtPos1);
}
return mFragmentAtPos1;
} else if (position == 2) {
return NSfragment.newInstance();
}
return new Settingfragment();
}


@Override
public int getCount() {
return NUM_OF_ITEMS;
}


@Override
public int getItemPosition(Object object) {

//POSITION_NONE當adapter獲取此值時,得到無次位置的fragment則會自動刷新
if (object instanceof Mainfragment) {
return POSITION_NONE;
} else if (object instanceof ChilditemFragment) {
return POSITION_NONE;
} else if (object instanceof ArticleListFragment) {
return POSITION_NONE;
} else if (object instanceof MsgContentFragment) {
return POSITION_NONE;
} else if (object instanceof NSlanmuFragment) {
return POSITION_NONE;
} else if (object instanceof NStitlefragment) {
return POSITION_NONE;
} else if (object instanceof NScontentfragment) {
return POSITION_NONE;
} else if (object instanceof ArticleListForscFragment) {
return POSITION_NONE;
} else if (object instanceof MsgContentForscFragment) {
return POSITION_NONE;
}
return POSITION_UNCHANGED;
}

//ViewPager內的一個fragment跳轉到另一個fragment
public void AddStackAt0(BaseFragment old, BaseFragment nf) {
stackat0.push(nf);
mFragmentManager.beginTransaction().remove(mFragmentAtPos0).commit();
mFragmentAtPos0 = nf;
notifyDataSetChanged();
}


public void AddStackAt1(BaseFragment old, BaseFragment nf) {
stackat1.push(nf);
mFragmentManager.beginTransaction().remove(mFragmentAtPos1).commit();
mFragmentAtPos1 = nf;
notifyDataSetChanged();
}

//處理fragment的返回
public void RemoveStackAt0() {
mFragmentManager.beginTransaction().remove(mFragmentAtPos0).commit();
stackat0.pop();
if (stackat0.getTop() instanceof Mainfragment) {
mFragmentAtPos0 = Mainfragment.newInstance();
} else if (stackat0.getTop() instanceof ChilditemFragment) {
mFragmentAtPos0 = ChilditemFragment.newInstance();
} else if (stackat0.getTop() instanceof ArticleListFragment) {
mFragmentAtPos0 = ArticleListFragment.newInstance();
} else if (stackat0.getTop() instanceof NSlanmuFragment) {
mFragmentAtPos0 = NSlanmuFragment.newInstance();
} else if (stackat0.getTop() instanceof NStitlefragment) {
mFragmentAtPos0 = NStitlefragment.newInstance();
}
notifyDataSetChanged();
}


public void RemoveStackAt1() {
mFragmentManager.beginTransaction().remove(mFragmentAtPos1).commit();
stackat1.pop();
if (stackat1.getTop() instanceof ArticleListForscFragment) {
mFragmentAtPos1 = ArticleListForscFragment.newInstance();
}
notifyDataSetChanged();
}


public boolean Canback(int index) {
switch (index) {
case 0:
return stackat0.hasNext();


case 1:
return stackat1.hasNext();


}
return false;
}


public void Back(int index) {
switch (index) {
case 0:
RemoveStackAt0();
break;
case 1:
RemoveStackAt1();
break;
default:
break;
}
}


}

其中Stack為棧,保存position0,1,2,3的頁面緩存棧

public class MyStack {
private List<BaseFragment> mylist;
public MyStack()
{
mylist=new ArrayList<BaseFragment>();
}
public void push(BaseFragment push)
{
mylist.add(push);
}
public int getsize(){
return mylist.size();
}
public boolean isempty(){
return mylist.isEmpty();
}
public BaseFragment pop(){
BaseFragment b=mylist.get(mylist.size()-1);
mylist.remove(mylist.size()-1);
System.out.println("after pop size"+mylist.size());
return b;
}
public Boolean hasNext(){
if(mylist.size()>1){
return true;
}
return false;
}
public BaseFragment getTop(){
System.out.println("after gettop size"+mylist.size());
return mylist.get(mylist.size()-1);
}
}

在每一個Fragment當中

@Override
public void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
LayoutInflater inflater = getActivity().getLayoutInflater();
nscview = inflater.inflate(R.layout.fragment_nscontent,
(ViewGroup) getActivity().findViewById(R.id.main_ViewPager),
false);

//false為重點,必須為false或null

}

public View onCreateView(LayoutInflater inflater,
@Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
// TODO Auto-generated method stub

               /*以下判斷必須,不添加則會產生(28637): java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first.異常*/
ViewGroup p = (ViewGroup) nscview.getParent();
if (p != null) {
p.removeAllViewsInLayout();
Log.v("swc", "NScontent-->移除已存在的View");
}
System.out.println("NScontent fragment getview");
return nscview;
}

考虑可再生能源出力不确定性的商业园区用户需求响应策略(Matlab代码实现)内容概要:本文围绕“考虑可再生能源出力不确定性的商业园区用户需求响应策略”展开,结合Matlab代码实现,研究在可再生能源(如风电、光伏)出力具有不确定性的背景下,商业园区如何制定有效的需求响应策略以优化能源调度和提升系统经济性。文中可能涉及不确定性建模(如场景生成与缩减)、优化模型构建(如随机规划、鲁棒优化)以及需求响应机制设计(如价格型、激励型),并通过Matlab仿真验证所提策略的有效性。此外,文档还列举了大量相关的电力系统、综合能源系统优化调度案例与代码资源,涵盖微电网调度、储能配置、负荷预测等多个方向,形成一个完整的科研支持体系。; 适合人群:具备一定电力系统、优化理论和Matlab编程基础的研究生、科研人员及从事能源系统规划与运行的工程技术人员。; 使用场景及目标:①学习如何建模可再生能源的不确定性并应用于需求响应优化;②掌握使用Matlab进行商业园区能源系统仿真与优化调度的方法;③复现论文结果或开展相关课题研究,提升科研效率与创新能力。; 阅读建议:建议结合文中提供的Matlab代码实例,逐步理解模型构建与求解过程,重点关注不确定性处理方法与需求响应机制的设计逻辑,同时可参考文档中列出的其他资源进行扩展学习与交叉验证。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值