Fragment进阶(五)----->监听fragment回退事件
activity_main.xml
<? xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity"> <Button
android:id="@+id/btn_add_frg3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="add frag3" /> <FrameLayout
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="match_parent" /> </LinearLayout>
fragment3.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#0000ff"
android:orientation="vertical"> <TextView
android:id="@+id/fragment3_tv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="25dp"
android:text="这是Fragment 3" /> </LinearLayout>
MainActivity
package com.harvic.fragmentback; import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentTransaction;
import android.view.View;
import android.widget.Button;
import android.widget.Scroller; /**
* 既然清楚了Fragment仅仅是一个控件,而回退事件也仅仅能在Activity中拦截。那我们就能够想办法了。
* 首先,我们能够在Fragment类中咱们自己写一个onBackPressed()方法来处理回调事件。
* 然后。能够利用回调。将要处理回退事件的fragment实例。传给Activity。
* 最后,在拿到fragment实例以后,就能够在Activity的onBackPress
* ()方法中。调用这个fragment实例的onBackPressed()方法了。 这样。我们就在fragment中拦截了回退事件了。 *
*/ public class MainActivity extends FragmentActivity implements
View.OnClickListener, Fragment3.BackHandlerInterface {
private Fragment3 selectedFragment; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); Button btnAddFrag3 = (Button) findViewById(R.id.btn_add_frg3);
btnAddFrag3.setOnClickListener(this);
} @Override
public void onClick(View v) {
int id = v.getId();
switch (id) {
case R.id.btn_add_frg3: {
Fragment3 fragment3 = new Fragment3();
addFragment(fragment3, "fragment3");
}
break;
} } private void addFragment(Fragment fragment, String tag) {
FragmentManager manager = getSupportFragmentManager();
FragmentTransaction transaction = manager.beginTransaction();
transaction.add(R.id.fragment_container, fragment, tag);
transaction.addToBackStack(tag);
transaction.commit();
} /**
* 在activity中获取fragment页面
*/
@Override
public void setSelectedFragment(Fragment3 backHandledFragment) {
this.selectedFragment = backHandledFragment;
} /**
* !selectedFragment.onFragmentBackPressed()返回true(non-Javadoc)
* selectedFragment.onFragmentBackPressed()返回false; 让activity来处理就可以
*/ @Override
public void onBackPressed() {
if (!selectedFragment.onFragmentBackPressed()) {
// 回退
super.onBackPressed();
}
} }
Fragment3
package com.harvic.fragmentback; import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView; public class Fragment3 extends Fragment {
private boolean mHandledPress = false; protected BackHandlerInterface backHandlerInterface;
public interface BackHandlerInterface {
public void setSelectedFragment(Fragment3 backHandledFragment);
} TextView tv; /**
* 事实上在onAttach()回调时就已经把Fragment与Activity绑定在了一起,所以仅仅要生命流程在onAttach()
* 之后的随意一个生命周期
* ,我们都能够通过getActivity来获取Activity的实例,来进行强制转换,所以在这里我们就换个地方,在onCreate()函数中来做:
*/
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (!(getActivity() instanceof BackHandlerInterface)) {
throw new ClassCastException(
"Hosting activity must implement BackHandlerInterface");
} else {
// 强转为接口实例
backHandlerInterface = (BackHandlerInterface) getActivity();
}
} /**
* onCreateView返回一个fragment视图
*/
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment3, container, false);
} /**
* 有关这个设置Fragment3实例的代码,仅仅要在生命周期中Fragment3实例已经产生了都能够设置,即能够放在生命周期在onCreate()
* 后的函数里,即onCreate()、onCreateView()、onActivityCreated()、onStart()。尽管经过我測试。
* 放在这几个函数中的随意一个都是可行的
* ,但onActivityCreated()后才是Activity终于onCreate()运行完。所以放在onActivityCreated
* ()或onStart()中是最保险的。所以这里放在了onStart()中来处理
*/ @Override
public void onStart() {
super.onStart();
backHandlerInterface.setSelectedFragment(this);
} @Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
tv = (TextView) getView().findViewById(R.id.fragment3_tv);
} /**
* 其返回一个布尔值;意思是,假设对返回事件进行了处理就返回TRUE,假设不做处理就返回FALSE,让上层进行处理。
*
* @return
*/
public boolean onFragmentBackPressed() {
if (!mHandledPress) {
tv.setText("Fragment3 \n 捕捉到了回退事件哦! ");
mHandledPress = true;
return true;
}
return false;
}
}
Fragment进阶(五)----->监听fragment回退事件的更多相关文章
- iOS微信浏览器回退不刷新(监听浏览器回退事件)
兼容性:兼容全部ios系统 $(function(){ pushHistory(); }); function pushHistory(){ window.addEventListener(" ...
- Fragment-如何监听fragment中的回退事件与怎样保存fragment状态
一.如何监听Fragment中的回退事件 1.问题阐述 在Activity中监听回退事件是件非常容易的事,因为直接重写onBackPressed()函数就好了,但当大家想要监听Fragment中的回退 ...
- Android中Button的五种监听事件
简单聊一下Android中Button的五种监听事件: 1.在布局文件中为button添加onClick属性,Activity实现其方法2.匿名内部类作为事件监听器类3.内部类作为监听器4.Activ ...
- js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写
js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写 一.总结 一句话总结:滚动事件scroll(),浏览器窗口调整监听resize(),思考好监听对象. 1.滚动事件scroll()的监听对象是 ...
- 从零开始学习Node.js例子五 服务器监听
httpsnifferInvoke.js var http = require('http'); var sniffer = require('./httpsniffer'); var server ...
- 三种方式监听NGUI的事件方法
NGUI研究院之三种方式监听NGUI的事件方法(七) NGUI事件的种类很多,比如点击.双击.拖动.滑动等等,他们处理事件的原理几乎万全一样,本文只用按钮来举例. 1.直接监听事件 把下面脚本直接绑定 ...
- IOS之UI--自定义按钮实现代理监听点击事件
前言: Objective-C提供的按钮监听事件的方法是 不含参数的监听方法 [button实例对象 addTarget:self action:@selector(func) forControlE ...
- Android监听点击事件实现的三种方法
监听点击事件实现的三种方法:1.匿名内部类2.外部类3.直接实现接口 1.匿名内部类: package com.jereh.calculator; import android.content.Con ...
- javascript 原生方法监听DOM结构改变事件
js原生方法监听DOM结构改变事件 document.addEventListener('DOMNodeInserted',function(){alert(1)},false);document.a ...
- WPF之监听组合键事件
private void KeyDown(object sender, KeyEventArgs e) { if (e.Key== Key.Up && Keyboard.Modifie ...
随机推荐
- USB设备请求命令详解
USB设备请求命令 :bmRequestType + bRequest + wValue + wIndex + wLength 编号 值 名称 (0) 0 GET_STATUS:用来返回特定接收者 ...
- pycharm激活2018
因为我的是Windows,所以这篇文章只针对Windows系统. 1.将“0.0.0.0 account.jetbrains.com”中的内容添加到hosts文件中,hosts路径为:C:\Windo ...
- jQuery-鼠标经过显示大图并跟随鼠标效果方法封装
//copyright c by zhangxinxu 2019-1-15 /*由于大图绑定在href属性中,故一般而言,需使用a标签的href指向大图.仅支持png,gif,jpg,bmp四种格式的 ...
- 2018 CCPC 桂林站(upc复现赛)补题
2018 CCPC 桂林站(upc复现赛)补题 G.Greatest Common Divisor(思维) 求相邻数的差值的gcd,对gcd分解素因子,对所有的素因子做一次遍历,找出最小答案. 几个样 ...
- jq ajax请求error: Maximum call stack size exceeded
原因是data中参数iconUrl这个变量未声明导致的.jq在内部循环时报错
- python_字符串常用方法
1.切片就是通过索引(索引:索引:步长)截取字符串的一段,形成新的字符串(原则就是顾头不顾腚). a = 'ABCDEFGHIJK' print(a[0:3]) # print(a[:3]) 从开头开 ...
- Vue如何引入jquery实现平滑滚动到指定位置效果
在以往的做法里首选jquery的animate实现,但是Vue里并没有这个方法.如何在Vue项目中实现点击导航平滑滚动到指定位置,为了这效果我是快要崩溃了,上网查阅了很久发现并没有真正意义上解决这个问 ...
- 九度oj 题目1180:对称矩阵
题目1180:对称矩阵 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3092 解决:1607 题目描述: 输入一个N维矩阵,判断是否对称. 输入: 输入第一行包括一个数:N(1<= ...
- hdu 2433 Travel (最短路树)
One day, Tom traveled to a country named BGM. BGM is a small country, but there are N (N <= 100) ...
- bzoj1052 [HAOI2007]覆盖问题 - 贪心
Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L*L的正方形塑料薄膜将小 ...