0

我的应用程序由 TabHost 和 ActivityGroup 组成,其中包含嵌套的活动。当 ActivityGroup 的 Activity 被创建或恢复时,软键盘立即显示。我只需要在 EditText 上单击它才能显示它。我的 ActivityGroup 课程:

public class LoginTabGroup  extends ActivityGroup {

private ArrayList<String> mIdList;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (mIdList == null) mIdList = new ArrayList<String>();
    }

/**
* This is called when a child activity of this one calls its finish method.
* This implementation calls {@link LocalActivityManager#destroyActivity} on the child activity
* and starts the previous activity.
* If the last child activity just called finish(),this activity (the parent),
* calls finish to finish the entire group.
*/
@Override
public void finishFromChild(Activity child) {
LocalActivityManager manager = getLocalActivityManager();
int index = mIdList.size()-1;

if (index < 1) {
finish();
return;
}

manager.destroyActivity(mIdList.get(index), true);
mIdList.remove(index);
index--;
String lastId = mIdList.get(index);
Intent lastIntent = manager.getActivity(lastId).getIntent();

Window newWindow = manager.startActivity(lastId, lastIntent);
newWindow.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
Log.i("ActivityGroup","finishFromChild method");
setContentView(newWindow.getDecorView());
}

/**
* Starts an Activity as a child Activity to this.
* @param Id Unique identifier of the activity to be started.
* @param intent The Intent describing the activity to be started.
* @throws android.content.ActivityNotFoundException.
*/
public void startChildActivity(String Id, Intent intent) 
{
    Window window = getLocalActivityManager().startActivity(Id,intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP));
    window.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
    Log.i("ActivityGroup","startActivity method");
    if (window != null) {
    mIdList.add(Id);
    setContentView(window.getDecorView());
    }
}

/**
* The primary purpose is to prevent systems before android.os.Build.VERSION_CODES.ECLAIR
* from calling their default KeyEvent.KEYCODE_BACK during onKeyDown.
*/
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK) {
    //preventing default implementation previous to android.os.Build.VERSION_CODES.ECLAIR
    return true;
    }
    return super.onKeyDown(keyCode, event);
}

/**
* Overrides the default implementation for KeyEvent.KEYCODE_BACK
* so that all systems call onBackPressed().
*/
@Override
public boolean onKeyUp(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK) {
    onBackPressed();
    return true;
    }
    return super.onKeyUp(keyCode, event);
}

/**
* If a Child Activity handles KeyEvent.KEYCODE_BACK.
* Simply override and add this method.
*/
    @Override
    public void onBackPressed () {
    int length = mIdList.size();
    if ( length > 1) {
    Activity current = getLocalActivityManager().getActivity(mIdList.get(length-1));
    current.finish();
    }
}
}

我试着这样做newWindow.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);

在创建新窗口时,但它没有帮助。方法如

 InputMethodManager imm = (InputMethodManager)getSystemService(
              Context.INPUT_METHOD_SERVICE);
    imm.toggleSoftInput(InputMethodManager.HIDE_IMPLICIT_ONLY, 0);

在嵌套的活动中正常工作,但在活动创建或恢复键盘显示然后立即隐藏。由于键盘闪烁,我认为这不是一个好的解决方案。我还尝试在 AndroidManifest 中添加

 android:windowSoftInputMode="stateAlwaysHidden" 
         android:configChanges="keyboardHidden|orientation"

都在嵌套的活动、活动组中。但结果还是一样。我该如何解决这个问题?

4

3 回答 3

0

我用 hack 来解决这个问题。在 ActivityGroup 的班级和我放的子活动中

        InputMethodManager imm = (InputMethodManager)getSystemService(
                  Context.INPUT_METHOD_SERVICE);
        imm.toggleSoftInput(InputMethodManager.HIDE_IMPLICIT_ONLY, 0); 

在 onCreate() 和 onResume() 方法之前。如果知道的人告诉我更有效的解决方案,我将不胜感激。

于 2013-03-15T13:10:12.197 回答
0

ActivityGroup 使用是非常糟糕和缓慢的解决方案。我决定在标签中使用带有嵌套片段的 FragmentActivities。然而,有时在 Activity 启动时会显示软键盘。我在没有图像的选项卡之一中将文本设置为中心。我猜,它叫软键盘显示。我的修复(在 TabActivity 类中):

 final View view = tabHost.getTabWidget().getChildTabViewAt(1);
       if ( view != null ) {
         //  view.getLayoutParams().height *= 0.66;
           InputMethodManager imm2 = (InputMethodManager)getSystemService(
                  Context.INPUT_METHOD_SERVICE);
           imm2.toggleSoftInput(InputMethodManager.HIDE_IMPLICIT_ONLY, 0);
           //  get title text view
           final View textView = view.findViewById(android.R.id.title);
           if ( textView instanceof TextView ) {
               // just in case check the type

               // center text
               ((TextView) textView).setGravity(Gravity.CENTER);
               // wrap text
               ((TextView) textView).setSingleLine(false);
               // explicitly set layout parameters
               textView.getLayoutParams().height = ViewGroup.LayoutParams.FILL_PARENT;
               textView.getLayoutParams().width = ViewGroup.LayoutParams.WRAP_CONTENT;
           }
       }
于 2013-04-22T13:02:10.560 回答
0

发生这种情况是因为布局中的 edittexts 是可聚焦的元素,如果没有其他元素请求它,则请求焦点在启动上。解决方案很简单:在所有布局文件中,在容器布局中将 focusable 和 focusableInTouchMode 设置为 true,这样它就会首先请求焦点,而编辑文本不会被聚焦。然后你可以删除你的隐含隐藏)

android:focusable="true"
android:focusableInTouchMode="true"
于 2013-02-22T09:32:36.843 回答