我该怎么做呢?
当前解决方案
我启动了一个透明的活动,它捕获后退按钮事件,将其转发到我的服务并在关闭自身之后。但是这个活动将在当前运行的活动中可见,因此这不是一个非常好的解决方案。
已看到的解决方案
我看到过一个应用程序,在没有捕获后退按钮事件的活动的情况下捕获了后退按钮事件 - 如果我显示当前运行的活动,则来自此应用程序的内容为空。
问题
这可以怎样做到呢?我阅读了很多帖子说这是不可能的,但我可以看到有一些应用程序以某种方式实现了这一点...
我认为我找到了它的工作原理...不要在你的覆盖视图中使用WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE
,并且覆盖你视图的dispatchKeyEvent
:
@Override
public boolean dispatchKeyEvent(KeyEvent event)
{
if (event.getKeyCode() == KeyEvent.KEYCODE_BACK)
{
// handle back press
// if (event.getAction() == KeyEvent.ACTION_DOWN)
return true;
}
return super.dispatchKeyEvent(event);
}
public class MyFooterService extends Service{
View myview;
WindowManager wm;
FrameLayout wrapper;
public MyFooterService() {
}
@Override
public void onCreate() {
Log.d(TAG, "onCreate called");
LayoutInflater li = (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
wm = (WindowManager) getSystemService(WINDOW_SERVICE);
final WindowManager.LayoutParams params = new WindowManager.LayoutParams(
WindowManager.LayoutParams.MATCH_PARENT,
90, //height of ur layout
WindowManager.LayoutParams.TYPE_PHONE,
0,
PixelFormat.TRANSLUCENT);
params.gravity = Gravity.BOTTOM ;
params.x = 0;
params.y = 0;
wrapper = new FrameLayout(this) {
@Override
public boolean dispatchKeyEvent(KeyEvent event) {
if (event.getKeyCode()==KeyEvent.KEYCODE_BACK) {
// handle the back button code;
return true;
}
return super.dispatchKeyEvent(event);
}
//if pressed home key,
public void onCloseSystemDialogs(String reason) {
//The Code Want to Perform.
System.out.println("System dialog " + reason);
if (reason.equals("homekey")) {
// handle home button
}
}
};
myview = li.inflate(R.layout.my_footer, wrapper); // here set into your own layout
wm.addView(myview, params);
}
}
view.setFocusableInTouchMode(true);
view.setOnKeyListener(new View.OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
if(keyCode == KeyEvent.KEYCODE_BACK) {
stopSelf();
return true;
}
return false;
}
});
编辑,我没有使用好的Stack Overflow账户
您可以捕捉返回按钮的点击事件。为此,您需要创建您的OverlayView的容器类。例如:创建类Overlay扩展某些ViewGroup类。然后,在该类中,填充您的xml布局并将其添加到Overlay.class ViewGroup中。然后在Overlay.class中覆盖dispatchKeyEvent(KeyEvent event)方法。就这样!
class Overlay extends FrameLayout{
public Overlay(@NonNull Context context) {
super(new ContextThemeWrapper(context, R.style.AppTheme));
initView();
}
private void initView() {
//inflate your xml here
//than do: this.addView(<inflated view>);
//And in the end add your Overlay to WindowManager (in Service class of course).
}
@Override
public boolean dispatchKeyEvent(KeyEvent event) {
if (event.getKeyCode() == KeyEvent.KEYCODE_BACK) {
//do staff here
// and return True!
return true;
}
return super.dispatchKeyEvent(event);
}
}
WindowManager.LayoutParams.TYPE_SYSTEM_ERROR
作为我的覆盖层类型,以及WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN | WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | WindowManager.LayoutParams.FLAG_WATCH_OUTSIDE_TOUCH
作为标志...这对于类似侧边栏的应用程序效果很好... - prom85