简体   繁体   English

如何在Android中正确设置自定义操作栏

[英]how to set custom Action Bar properly in Android

I have created a custom action bar in my android app. 我在我的android应用中创建了一个自定义操作栏。 Unfortunately the height and width is not set properly in my custom layout. 不幸的是,高度和宽度在我的自定义布局中设置不正确。 After I run the app there remains a blank space left and right at the custom action bar as well as a heights problem. 运行该应用程序后,自定义操作栏的左侧和右侧还有一个空白区域,以及一个高度问题。 How can I solve this ? 我该如何解决?

Custom action bar 自定义操作栏

<?xml version="1.0" encoding="utf-8"?>
    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#3A86CF"
        android:orientation="horizontal"
        android:layout_gravity="fill_horizontal">

        <ImageView
            android:id="@+id/imgLeftMenu"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_gravity="left|center_vertical|center_horizontal"
            android:layout_weight="1"
            android:src="@drawable/menu_left" />

        <TextView
            android:layout_width="200dp"
            android:layout_height="30dp"
            android:layout_weight="1"
            android:id="@+id/txtTitle"
            android:gravity="center_vertical|center_horizontal"
            android:text="All Post"
            android:textColor="@android:color/white" />

        <ImageView
            android:id="@+id/imgSearch"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@android:drawable/ic_menu_search" />

        <ImageView
            android:id="@+id/imgAdd"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:src="@android:drawable/ic_menu_add" />

    </LinearLayout>

Activity code 活动代码

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.all_post);
        CustomActionBar();

    }

    public void CustomActionBar()
    {
        android.support.v7.app.ActionBar actionBar = getSupportActionBar();
        actionBar.setDisplayOptions( android.support.v7.app.ActionBar.DISPLAY_SHOW_CUSTOM);

        // Do any other config to the action bar
        getSupportActionBar().setDisplayShowTitleEnabled(false);
        getSupportActionBar().setDisplayShowHomeEnabled(false);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);

        // set custom view
        View actionBarView = getLayoutInflater().inflate(
                R.layout.custom_action_bar, null);

        View btnMenuLeft= actionBarView.findViewById(R.id.imgLeftMenu);
        btnMenuLeft.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                            }
        });


        View textView_Title= actionBarView.findViewById(R.id.txtTitle);

        View btnMenuShare= actionBarView.findViewById(R.id.imgSearch);
        View btnMenuAdd= actionBarView.findViewById(R.id.imgAdd);
        android.support.v7.app.ActionBar.LayoutParams params = new android.support.v7.app.ActionBar.LayoutParams(
                android.support.v7.app.ActionBar.LayoutParams.MATCH_PARENT,android.support.v7.app.ActionBar.LayoutParams.MATCH_PARENT);
        actionBar.setCustomView(actionBarView, params);

        // Hide the home icon
        actionBar.setIcon(android.R.color.transparent);
        actionBar.setLogo(android.R.color.transparent);
    }

style.xml style.xml

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="android:height">5dp</item>
    </style>
</resources>

put below code in your style.xml 将以下代码放在您的style.xml中

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light">
    <item name="actionBarStyle">@style/MyActionBar</item>
    <item name="android:actionBarStyle">@style/MyActionBar</item>
    <!-- Customize your theme here. -->
</style>



<!-- ActionBar styles -->
<style name="MyActionBar" parent="@style/Widget.AppCompat.Light.ActionBar.Solid.Inverse">
    <item name="android:background">@color/actionbar_bg</item>
    <item name="background">@color/actionbar_bg</item>
    <item name="android:homeAsUpIndicator">@drawable/ic_backarrow</item>
    <item name="homeAsUpIndicator">@drawable/ic_backarrow</item>
</style>

Use "@style/AppTheme" in manifest 在清单中使用“ @ style / AppTheme”

Custom layout 自定义布局

<?xml version="1.0" encoding="utf-8"?>

<TextView
    android:id="@+id/cal_tvActionbarTitle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:textColor="@color/white"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:textStyle="bold" />

Write below code in your java class for actionbar 在Java类中为ActionBar编写以下代码

/**
 * Method to change ActionBar Title
 */
public void setMainScreenActionBar(String p_title)
{

    LayoutInflater m_inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    ActionBar m_actionBar = getSupportActionBar();
    View m_viewActionBar = m_inflater.inflate(R.layout.custom_actionbar_title_layout, null);
    ActionBar.LayoutParams m_params = new ActionBar.LayoutParams(ActionBar.LayoutParams.WRAP_CONTENT, ActionBar.LayoutParams.MATCH_PARENT, Gravity.CENTER);
    TextView m_tvTitle = (TextView) m_viewActionBar.findViewById(R.id.cal_tvActionbarTitle);
    m_tvTitle.setText(p_title);
    m_actionBar.setCustomView(m_viewActionBar, m_params);
    m_actionBar.setDisplayShowCustomEnabled(true);
    m_actionBar.setDisplayShowTitleEnabled(false);
    m_actionBar.setDisplayHomeAsUpEnabled(true);
    m_actionBar.setHomeButtonEnabled(true);

}

put below code in your style.xml 将以下代码放在您的style.xml中

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">Light">
    <item name="actionBarStyle">@style/MyActionBar</item>
    <item name="android:actionBarStyle">@style/MyActionBar</item>
    <!-- Customize your theme here. -->
</style>



<!-- ActionBar styles -->
<style name="MyActionBar" parent="@style/Widget.AppCompat.Light.ActionBar.Solid.Inverse">
    <item name="android:layout_height">5dp<background">@color/actionbar_bg</item>
    <item name="background">@color/actionbar_bg</item>
    <item name="android:homeAsUpIndicator">@drawable/ic_backarrow</item>
    <item name="homeAsUpIndicator">@drawable/ic_backarrow</item>
</style>

If you don´t fix Use "@style/AppTheme" in manifest 如果不解决,请在清单中使用“ @ style / AppTheme”

Custom layout 自定义布局

<?xml version="1.0" encoding="utf-8"?>
 <TextView
    android:id="@+id/cal_tvActionbarTitle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:textColor="@color/white"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:textStyle="bold" />

Write belove code in your problem with this post a screenshot please. 请在您的问题中编写Belove代码,并发布此屏幕快照。 java class for actionbar Actionbar的Java类

/**
 * Method to change ActionBar Title
 */
public void setMainScreenActionBar(String p_title)
{

    LayoutInflater m_inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    ActionBar m_actionBar = getSupportActionBar();
    View m_viewActionBar = m_inflater.inflate(R.layout.custom_actionbar_title_layout, null);
    ActionBar.LayoutParams m_params = new ActionBar.LayoutParams(ActionBar.LayoutParams.WRAP_CONTENT, ActionBar.LayoutParams.MATCH_PARENT, Gravity.CENTER);
    TextView m_tvTitle = (TextView) m_viewActionBar.findViewById(R.id.cal_tvActionbarTitle);
    m_tvTitle.setText(p_title);
    m_actionBar.setCustomView(m_viewActionBar, m_params);
    m_actionBar.setDisplayShowCustomEnabled(true);
    m_actionBar.setDisplayShowTitleEnabled(false);
    m_actionBar.setDisplayHomeAsUpEnabled(true);
    m_actionBar.setHomeButtonEnabled(true);

}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM