2

我想创建一个 android 应用程序,它有 3 个滑动标签面板,每个都有 5 个按钮(保存、新建、删除、退出..)。

我想要的完全如下: 图片

我创建了滑动选项卡面板。对于 5 个按钮,我添加了拆分操作栏。但它作为正常的拆分操作栏工作。我的 AndroidManifest.xml 是:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.belsoft.myapplication">

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:uiOptions="splitActionBarWhenNarrow"
    android:theme="@style/AppTheme">
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:theme="@style/AppTheme.NoActionBar">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>

我哪里错了?

4

1 回答 1

5

实施splitActionBar

只需像这样添加android:uiOptions="splitActionBarWhenNarrow"到您的activity标签AndroidManifest.xml...

`<activity
    android:name=".MainActivity"
    android:uiOptions="splitActionBarWhenNarrow">`<br>

你可以在这里这里阅读更多

注意:它仅适用于屏幕宽度为400dp.

要创建自定义底部工具栏:

如果您想为所有设备设置它,请Creating custom bottom toolbar在此处查看我的答案(查找以 开头的帖子):

创建自定义底部工具栏

我已经创建了一个简单的应用程序,它应该向您展示如何开始

创建自定义视图组

这是我的activity_main.xml布局文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="0dp"
    tools:context="com.example.piotr.myapplication.MainActivity">

    <LinearLayout
        android:id="@+id/show_pdf"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:background="@color/primary_material_light"
        android:orientation="horizontal">

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_cut_mtrl_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_copy_mtrl_am_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_selectall_mtrl_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_paste_mtrl_am_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_share_mtrl_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_selectall_mtrl_alpha"/>

        <ImageButton
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@drawable/abc_ic_menu_moreoverflow_mtrl_alpha"/>
    </LinearLayout>

    <EditText
        android:id="@+id/editText"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="75dp"
        android:ems="10"
        android:inputType="textPersonName"
        android:text="Name"/>
</RelativeLayout>

如您所见,我的父母ViewGroupRelativeLayout,它只允许我在屏幕底部创建一个视图。

请注意,我将布局填充设置为零(我认为:这里没有必要将布局边距设置为零,效果相同)。如果您更改它,工具栏将不会使用全宽,也不会粘在屏幕底部。

然后我添加了一个带有硬编码高度的线性布局,即:

          android:layout_height="40dp"

我想要它,我的底部工具栏将占用完整的可用宽度,因此我将其设置为match_parent.

接下来,我添加了一些ImageButton带有来自 Android 库的图像的视图。

你有两种可能:

  • 如果您真的想要像上面示例中那样的工具栏,只需在每个ImageButton视图中删除此行:

          android:layout_weight="1"
    

删除权重和一些按钮后,您将获得与预期非常相似的视图:

  • 如果您想获取整个宽度并使每个按钮在您的项目中使用相同大小,weight就像在这个我的例子中一样。

现在让我们转到我的AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest package="com.example.piotr.myapplication"
          xmlns:android="http://schemas.android.com/apk/res/android">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity
            android:name=".MainActivity"
            android:windowSoftInputMode="stateVisible|adjustResize">
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>

                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
    </application>
</manifest>

在我添加的那个文件中,你只能看到一行:

         android:windowSoftInputMode="stateVisible|adjustResize">

确保设备键盘不会隐藏我的自定义底部工具栏。

来自:如何将底部菜单添加到 Android 活动

如果您有任何问题,请随时提问。

希望有帮助

于 2015-12-31T12:23:15.927 回答