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 个选项卡将消失....
我不知道为什么????
请帮助我:((
你必须使用 TabGroupActivity 类,
您还必须实施更多 Tab1Activity 类和 Tab2Activity 类 从 TabGroupActivity
扩展而来你将分别调用 startChildActivity(TAB1.class) 和 startChildActivity(TAB2.class) 的地方, 这样,无论您是在 TAB1 还是 TAB2 中,您都可以选择选项卡。
您可以在线实现 TabGroupActivity 类示例,
最近我有一个类似的项目,就是这样说的。
您可以使用此自定义类实现此目的:
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);
这应该有效。如果您有任何问题,请问!
使用方法:
在某些选项卡的一个选项卡中,例如 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));
}
}