2012-01-14 70 views
10

我在tab控制器内部有一些意图,对于其中的一个我有一个编辑文本,我需要确定它何时具有焦点以及何时失去焦点。 我已经映射了大部分事件,如焦点侦听器,OnEditorActionListener等,现在我唯一的问题仍然是,当我有焦点软键盘出现,我想要关闭它:1)完成按钮,而不是通过手机上的后退按钮(禁用后退按钮以在键盘可见时关闭键盘) 2)在键盘可见时检测后退按钮事件,以便我可以将焦点传递给其他控件。在Android键盘上检测返回事件

我尝试了多种方式,但没有成功,像onBackPressed,onConfigurationChanged(在清单中添加hiddenKeyboard),key_down对活动等,但没有成功。

有没有人成功了?实际上,我希望当键盘可见时,按下手机,我的编辑文本失去焦点(otherControl.requestFocus - >这是一个相对布局)。

+0

告诉我你尝试过什么到目前为止 – confucius 2012-01-14 09:44:21

+0

1.这个 txtSearchBar .setOnEditorActionListener(new EditText.OnEditorActionListener() \t {\t \t public boolean onEditorAction(T extView V,INT actionId,KeyEvent的事件) \t { \t如果(event.getKeyCode()== KEYCODE_BACK) \t { \t \t layoutFocus.requestFocus(); \t \t \t \t} \t return false; \t} \t}); 2.方法2 onBackPressed,layoutFocus.requestFocus(); 3。添加hiddenKeyboard清单中的这项活动,并把 \t @覆盖 \t公共无效onConfigurationChanged(配置NEWCONFIG) – Catalin 2012-01-14 09:49:54

+0

,因为我不能回答我的问题,如果我有100个多点的声誉:) – Catalin 2012-01-14 09:54:31

回答

2

这里是

@Override 
public boolean dispatchKeyEvent(KeyEvent event) { 
     if(event.getKeyCode() == KeyEvent.KEYCODE_BACK) 
    { //do you back event work here 
      }  
    return super.dispatchKeyEvent(event); 
} 
+2

感谢您的代码,但它是不是很遗憾工作:(用你的方法时,软键盘已经隐藏了返回键只被困(我按完成按钮后),然后它超出了计划。当键盘显示和我按回,它执行的键盘隐藏,但通过这种方法不走。我在Android 2.2和2.3的测试是 – Catalin 2012-01-14 18:57:40

+0

因为当u按下背部和键盘了,只有键盘活动听的是和它回到过去,你可以听回来的事件当且仅当用户按下回你的活动,在这种情况下,键盘活动听这回事件.. – AAnkit 2012-01-15 07:19:14

+0

任何方式跟踪从键盘活动的回来吗?或者任何方法来禁用后退按钮的工作,而键盘是吗?喜欢的东西继承编辑文本和改变一些事情?这可能吗? – Catalin 2012-01-15 10:42:09

9

老话题,但这里是预期的答案

@Override 
public boolean onKeyPreIme(int keyCode, KeyEvent event) { 
    if (event.getAction() == KeyEvent.ACTION_UP && keyCode == KeyEvent.KEYCODE_BACK) { 
     Toast.makeText(getContext(), "BACK", Toast.LENGTH_SHORT).show(); 
     return true; 
    } 
    return super.onKeyPreIme(keyCode, event); 
} 

你应该把这个在覆盖的EditText一类(级MyEditText扩展的EditText ...)

3

以下是捕获后退按键事件的方法:1.覆盖editText视图以覆盖onKeyPreIme

package com.test.test; 
import android.content.Context; 
import android.util.AttributeSet; 
import android.view.KeyEvent; 
import android.widget.EditText; 

/** 
* Created by sumit.saurabh on 11/10/16. 
*/ 

public class ChatEditText extends EditText 
{ 
    /* Must use this constructor in order for the layout files to instantiate the class properly */ 
    public ChatEditText(Context context, AttributeSet attrs) 
    { 
     super(context, attrs); 
     // TODO Auto-generated constructor stub 
    } 

    private KeyImeChange keyImeChangeListener; 

    public void setKeyImeChangeListener(KeyImeChange listener) 
    { 
     keyImeChangeListener = listener; 
    } 

    public interface KeyImeChange 
    { 
     public void onKeyIme(int keyCode, KeyEvent event); 
    } 

    @Override 
    public boolean onKeyPreIme(int keyCode, KeyEvent event) 
    { 
     if (keyImeChangeListener != null) 
     { 
      keyImeChangeListener.onKeyIme(keyCode, event); 
     } 
     return false; 
    } 
} 

2.在XML ChatEditText

<com.test.test.ChatEditText 
    android:id = "@+id/messageEditText" 
    android:layout_width = "match_parent" 
    android:layout_height = "wrap_content" 
    android:layout_gravity = "bottom" 
    android:layout_marginLeft = "12dp" 
    android:layout_marginRight = "30dp" 
    android:background = "@null" 
    android:hint = "Type your message" 
    android:inputType = "textMultiLine" 
    android:singleLine = "false" 
    android:textColorHint = "#c4c0bd" 
    android:textSize = "18sp"/> 

3.然后从任何地方像这样附加一个监听器:

private ChatEditText messageEditText; 
    messageEditText = 
     (ChatEditText) findViewById(R.id.messageEditText); 
messageEditText.setKeyImeChangeListener(new ChatEditText.KeyImeChange(){ 
    @Override 
    public void onKeyIme(int keyCode, KeyEvent event) 
    { 
     if (KeyEvent.KEYCODE_BACK == event.getKeyCode()) 
     { 
      // do something 
     } 
    }});