我已经使用Android一段时间了,但片段对我来说有点新鲜(因为它们可能对大多数人来说都是如此)。无论如何,我有以下代码,它工作正常。我有三个片段,每个片段一个。我想知道每次切换标签时是否正常调用onCreateView,这样做是否有意义?每次选项卡更改时,是不是都有办法不重绘片段?
我正在从一个有3个活动的应用程序中转换它,每个选项卡中有一个,每次选项卡更改时重新创建视图似乎都是浪费,以前在选项卡之间存在视图就好了变更...
BTW,此代码借鉴于:http://thepseudocoder.wordpress.com/2011/10/04/android-tabs-the-fragment-way/
public class Tabs extends FragmentActivity implements
TabHost.OnTabChangeListener {
final String MAP_TAB = "Map";
final String IMAGES_TAB = "Images";
final String SETTINGS_TAB = "Settings";
TabHost mTabHost;
HashMap<String, TabInfo> mapTabInfo = new HashMap<String, TabInfo>();
TabInfo mLastTab = null;
private class TabInfo {
private String tag;
private Class clss;
private Bundle args;
private Fragment fragment;
TabInfo(String tag, Class clazz, Bundle args) {
this.tag = tag;
this.clss = clazz;
this.args = args;
}
}
class TabFactory implements TabContentFactory {
private final Context mContext;
public TabFactory(Context context) {
mContext = context;
}
public View createTabContent(String tag) {
View v = new View(mContext);
v.setMinimumWidth(0);
v.setMinimumHeight(0);
return v;
}
}
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.main);
initialiseTabHost(savedInstanceState);
if (savedInstanceState != null)
mTabHost.setCurrentTabByTag(savedInstanceState.getString("tab")); //set the tab as per the saved state
}
protected void onSaveInstanceState(Bundle outState) {
outState.putString("tab", mTabHost.getCurrentTabTag()); //save the tab selected
super.onSaveInstanceState(outState);
}
private void initialiseTabHost(Bundle args) {
mTabHost = (TabHost)findViewById(android.R.id.tabhost);
mTabHost.setup();
TabInfo tabInfo;
Tabs.addTab(this,
mTabHost,
mTabHost.newTabSpec(MAP_TAB).setIndicator(
MAP_TAB,
getResources().getDrawable(R.drawable.ic_tab_map_states)),
( tabInfo = new TabInfo(MAP_TAB, HMapFragment_NEW.class, args)));
mapTabInfo.put(tabInfo.tag, tabInfo);
Tabs.addTab(this,
mTabHost,
mTabHost.newTabSpec(IMAGES_TAB).setIndicator(
IMAGES_TAB,
getResources().getDrawable(R.drawable.ic_tab_gallery_states)),
( tabInfo = new TabInfo(IMAGES_TAB, ImageGridFragment.class, args)));
mapTabInfo.put(tabInfo.tag, tabInfo);
Tabs.addTab(this,
mTabHost,
mTabHost.newTabSpec(SETTINGS_TAB).setIndicator(
SETTINGS_TAB,
getResources().getDrawable(R.drawable.ic_tab_settings_states)),
( tabInfo = new TabInfo(SETTINGS_TAB, SettingsFragment.class, args)));
mapTabInfo.put(tabInfo.tag, tabInfo);
// Default to first tab
this.onTabChanged(MAP_TAB);
mTabHost.setOnTabChangedListener(this);
}
private static void addTab(Tabs activity, TabHost tabHost, TabHost.TabSpec tabSpec, TabInfo tabInfo) {
// Attach a Tab view factory to the spec
tabSpec.setContent(activity.new TabFactory(activity));
String tag = tabSpec.getTag();
// Check to see if we already have a fragment for this tab, probably
// from a previously saved state. If so, deactivate it, because our
// initial state is that a tab isn't shown.
tabInfo.fragment = activity.getSupportFragmentManager().findFragmentByTag(tag);
if (tabInfo.fragment != null && !tabInfo.fragment.isDetached()) {
FragmentTransaction ft = activity.getSupportFragmentManager().beginTransaction();
ft.detach(tabInfo.fragment);
ft.commit();
activity.getSupportFragmentManager().executePendingTransactions();
}
tabHost.addTab(tabSpec);
}
public void onTabChanged(String tag) {
TabInfo newTab = this.mapTabInfo.get(tag);
// if they've clicked to change tabs
if (mLastTab != newTab) {
FragmentTransaction ft = this.getSupportFragmentManager().beginTransaction();
if (mLastTab != null)
if (mLastTab.fragment != null) ft.detach(mLastTab.fragment);
if (newTab != null) {
if (newTab.fragment == null) {
newTab.fragment = Fragment.instantiate(this, newTab.clss.getName(), newTab.args);
ft.add(R.id.realtabcontent, newTab.fragment, newTab.tag);
} else ft.attach(newTab.fragment);
}
mLastTab = newTab;
ft.commit();
this.getSupportFragmentManager().executePendingTransactions();
}
}
}
答案 0 :(得分:24)
有3种方法可以从视图中删除片段:
hide
函数)detach
函数)remove
函数)如果您隐藏,视图会被隐藏,但仍然在布局中并且应该保持不变。如果分离它,视图将被拆除,但片段仍由FragmentManager管理(例如,将在配置更改时重新创建)。如果您删除,它将完全从FragmentManager中删除,并且不再管理其状态。