我有一个全屏模式的活动。活动中有一个带有 4 个选项卡的 ActionBar。我的问题是我想在活动顶部“模拟”我自己的状态栏。但我无法在状态栏上方添加视图。
当我将自定义视图设置为 ActionBar(并设置 .setDisplayShowHomeEnabled(true) )时,它基本上可以工作 - 自定义视图位于 ActionBar-Tabs 上方。但是在这个解决方案上,我无法控制自定义视图的高度 - 它总是静态相同的高度。
你有什么想法来解决这个问题吗?
非常感谢和最好的问候托比
我有一个全屏模式的活动。活动中有一个带有 4 个选项卡的 ActionBar。我的问题是我想在活动顶部“模拟”我自己的状态栏。但我无法在状态栏上方添加视图。
当我将自定义视图设置为 ActionBar(并设置 .setDisplayShowHomeEnabled(true) )时,它基本上可以工作 - 自定义视图位于 ActionBar-Tabs 上方。但是在这个解决方案上,我无法控制自定义视图的高度 - 它总是静态相同的高度。
你有什么想法来解决这个问题吗?
非常感谢和最好的问候托比
如果你愿意,你可以这样做,避免操作栏
而不是使用 action bar 创建一个线性或相对布局,就像你有你的 action bar 一样。
给布局一个与操作栏完全相同的固定高度。您可以从 zip 中的模板中找到不同场景的操作栏的确切高度。http://developer.android.com/downloads/design/Android_Design_Downloads_20130814.zip
然后使用带有片段的 Tabhost 来显示选项卡,因为 tabhost 可以放置在您可以随意使用它们的任何地方。
如果您想继续这种方式,请告诉我,我将帮助您使用 tabhost 代码来显示选项卡。
这是带有片段的 TAbhost 示例代码
1.>将此添加到您的xml
<TabHost
android:id="@android:id/tabhost"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TabWidget
android:id="@android:id/tabs"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="56dp"
android:layout_weight="0"
android:background="@null"
/>
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_weight="0"/>
<FrameLayout
android:id="@+android:id/realtabcontent"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"/>
</LinearLayout>
您还可以用 viewpager 替换第二个 framelayout 以提供可滑动的选项卡,如果您打算这样做,请不要更改 id 只需将 FrameLayout 标签替换为 viewpager
2.> 将此代码放入您的活动中
mTabHost = (TabHost) findViewById(android.R.id.tabhost);
mTabHost.setup();
mTabManager = new TabManager(this, mTabHost, R.id.realtabcontent);
mTabManager.addTab(
mTabHost.newTabSpec("fragment1").setIndicator("Fragment1"), FragmentOne.class,
null);
mTabManager.addTab(
mTabHost.newTabSpec("fragment2").setIndicator("Fragment2"),
FragmentTwo.class, null);
if (savedInstanceState != null) {
mTabHost.setCurrentTabByTag(savedInstanceState.getString("tab"));
}
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putString("tab", mTabHost.getCurrentTabTag());
}
/**
* This is a helper class that implements a generic mechanism for
* associating fragments with the tabs in a tab host. It relies on a trick.
* Normally a tab host has a simple API for supplying a View or Intent that
* each tab will show. This is not sufficient for switching between
* fragments. So instead we make the content part of the tab host 0dp high
* (it is not shown) and the TabManager supplies its own dummy view to show
* as the tab content. It listens to changes in tabs, and takes care of
* switch to the correct fragment shown in a separate content area whenever
* the selected tab changes.
*/
public static class TabManager implements TabHost.OnTabChangeListener {
private final FragmentActivity mActivity;
private final TabHost mTabHost;
private final int mContainerId;
private final HashMap<String, TabInfo> mTabs = new HashMap<String, TabInfo>();
TabInfo mLastTab;
static final class TabInfo {
private final String tag;
private final Class<?> clss;
private final Bundle args;
private Fragment fragment;
TabInfo(String _tag, Class<?> _class, Bundle _args) {
tag = _tag;
clss = _class;
args = _args;
}
}
static class DummyTabFactory implements TabHost.TabContentFactory {
private final Context mContext;
public DummyTabFactory(Context context) {
mContext = context;
}
@Override
public View createTabContent(String tag) {
View v = new View(mContext);
v.setMinimumWidth(0);
v.setMinimumHeight(0);
return v;
}
}
public TabManager(FragmentActivity activity, TabHost tabHost,
int containerId) {
mActivity = activity;
mTabHost = tabHost;
mContainerId = containerId;
mTabHost.setOnTabChangedListener(this);
}
public void addTab(TabHost.TabSpec tabSpec, Class<?> clss, Bundle args) {
tabSpec.setContent(new DummyTabFactory(mActivity));
String tag = tabSpec.getTag();
TabInfo info = new TabInfo(tag, clss, args);
// 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.
info.fragment = mActivity.getSupportFragmentManager()
.findFragmentByTag(tag);
if (info.fragment != null && !info.fragment.isDetached()) {
FragmentTransaction ft = mActivity.getSupportFragmentManager()
.beginTransaction();
ft.detach(info.fragment);
ft.commit();
}
mTabs.put(tag, info);
mTabHost.addTab(tabSpec);
}
@Override
public void onTabChanged(String tabId) {
TabInfo newTab = mTabs.get(tabId);
if (mLastTab != newTab) {
FragmentTransaction ft = mActivity.getSupportFragmentManager()
.beginTransaction();
if (mLastTab != null) {
if (mLastTab.fragment != null) {
ft.detach(mLastTab.fragment);
}
}
if (newTab != null) {
if (newTab.fragment == null) {
newTab.fragment = Fragment.instantiate(mActivity,
newTab.clss.getName(), newTab.args);
ft.add(mContainerId, newTab.fragment, newTab.tag);
} else {
ft.attach(newTab.fragment);
}
}
mLastTab = newTab;
ft.commit();
mActivity.getFragmentManager().executePendingTransactions();
}
}
这是一个运行代码,除了 addTab 方法中的 Fragments 之外,您无需更改任何内容,将您的 Fragments 放在那里。
对于您调用的每个 Fragment 方法 addTab 。