开始其他活动时如何保留Tabhost

问题描述 投票:0回答:3

TabHost 有问题...

我的 TabBarActivity 类流程为:

公共类 TabBarActivity 扩展 TabActivity 实现 OnTabChangeListener{

/*
 * (non-Javadoc)
 * 
 * @see android.app.ActivityGroup#onCreate(android.os.Bundle)
 */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);

    setContentView(R.layout.layout_tab);

    TabHost tabHost = (TabHost) findViewById(android.R.id.tabhost);

    TabSpec mTab1 = tabHost.newTabSpec("tab1");
    TabSpec mTab2 = tabHost.newTabSpec("tab2");

    mTab1.setIndicator("TAB1").setContent(
            new Intent(this, TAB1.class));
    mTab2.setIndicator("TAB2").setContent(
            new Intent(this, TAB2.class));

    /** Add tabSpec to the TabHost to display. */
    tabHost.addTab(mTab1);
    tabHost.addTab(mTab2);


}

我在 TAB1.java 类中有 ListView(例如联系人姓名)

假设: 我有一个屏幕布局,底部有 2 个选项卡 ( TAB1, TAB2 )。当我点击 TAB1 时,我有一个联系人名单,如果我点击 itemList。 ItemList 的详细信息屏幕将打开。在“DetailScreen”布局中,我想将 (TAB1, TAB2) tabhost 保留在底部屏幕上。

现在,当我运行应用程序并单击 itemList 时。我没有在每个项目列表的 DetailScreen 中保留 tabhost ( TAB1, TAB2 )...

启动项目列表的Activity时如何保持它(例如:DetailScreen.java)

谢谢你


@所有: 感谢您的反馈,但您似乎不明白我的问题。

我的问题: 详细说明我的项目: 1-我有一些课程: + TabBarActivity.java(源代码流程如上,首页,底部布局有 2 个选项卡 Tab1,Tab2 ....运行应用程序时默认为 Tab1) + Tab1.java(重要:在这个类中,我有列表视图(例如手机上的 youtube),当我单击列表上的一个项目时 -> 打开列表中每个项目的详细信息屏幕...确定) + Tab2.java(做点什么...)

2 - 当我运行应用程序时,您会在底部看到 2 Tab 布局和默认的 startActivity Tab1.java -> 然后在此屏幕中显示列表视图... 当单击列表中的一项时 -> 打开该项目的详细信息屏幕 (StartActivity DetailItem.java) -> 但是底部的 2 个选项卡将消失....

我不知道为什么????

请帮助我:((

android android-tabhost
3个回答
0
投票

你必须使用 TabGroupActivity 类,

您还必须实施更多 Tab1Activity 类和 Tab2Activity 类 从 TabGroupActivity

扩展而来

你将分别调用 startChildActivity(TAB1.class) 和 startChildActivity(TAB2.class) 的地方, 这样,无论您是在 TAB1 还是 TAB2 中,您都可以选择选项卡。

您可以在线实现 TabGroupActivity 类示例,

最近我有一个类似的项目,就是这样说的。


0
投票

您可以使用此自定义类实现此目的:

import java.util.ArrayList;

import android.app.Activity;
import android.app.ActivityGroup;
import android.app.LocalActivityManager;

import android.content.Intent;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.Window;

/*
 * The purpose of this Activity is to manage the activities in a tab.
 * Note: Child Activities can handle Key Presses before they are seen here.
 * @author Eric Harlow
 */
public class TabGroupActivity 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);
          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));
      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();
      }
  }
}

像这样使用:

在包含选项卡的主类中:

public class MainActivity extends TabGroupActivity {

}

在您的 onItemClickListener 中,您可以像这样开始活动:

startChildActivity("CollectionList", new Intent(this,CollectionMenu.class));

当您在 CollectionMenu(扩展 TabGroupActivity)中时,您可以像下面的代码一样启动您的子活动:

Intent previewMessage = new Intent(getParent(), DetailScreen.class);
TabGroupActivity parentActivity = (TabGroupActivity)getParent();
parentActivity.startChildActivity("DetailScreen", previewMessage);

这应该有效。如果您有任何问题,请问!


0
投票

使用方法:

在某些选项卡的一个选项卡中,例如 4 个选项卡,每个选项卡都扩展了

TabActivity
,在女巫中,您使用方法
startChildActivity
开始您的真正活动。

代码

public class Tab_BookCityActivity extends TabGroupActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    startChildActivity("BookCityActivity", new Intent(this, BookCityActivity.class));

    }
}
© www.soinside.com 2019 - 2024. All rights reserved.