簡體   English   中英

折疊工具欄標題與我的菜單圖標重疊

[英]Collapsing toolbar title overlaps with my menu icons

我在當前正在處理的項目中使用折疊工具欄。 我正在從我的代碼中設置折疊工具欄的標題,但問題是如果標題太大,那么它會與工具欄中的菜單圖標重疊。 那么我該如何解決這個問題呢?

標題與菜單圖標重疊: 標題與菜單圖標重疊

我的xml代碼:

<android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="205dp"
        android:fitsSystemWindows="true"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/agent_profile_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginBottom="87dp"
            app:expandedTitleMarginStart="130dp"
            app:expandedTitleTextAppearance="@style/expandedappbar"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="#fff"
                android:fitsSystemWindows="true"
                app:layout_collapseMode="parallax">

                <ImageView
                    android:id="@+id/backdrop"
                    android:layout_width="match_parent"
                    android:layout_height="170dp"
                    android:fitsSystemWindows="true"
                    android:scaleType="centerCrop"
                    android:src="@drawable/back" />

                <RelativeLayout
                    android:layout_width="match_parent"
                    android:layout_height="170dp"
                    android:background="#66000000">

                    <LinearLayout
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:layout_alignParentBottom="true"
                        android:layout_marginBottom="8dp"
                        android:layout_marginLeft="130dp"
                        android:orientation="vertical">

                        <TextView
                            android:id="@+id/lbl_agent_profile_position"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:layout_below="@+id/lbl_agent_profile_Name"
                            android:layout_marginBottom="5dp"
                            android:ellipsize="end"
                            android:maxLines="1"
                            android:text="Real Estate Professional at Exit Alliance Realty"
                            android:textAppearance="?android:attr/textAppearanceSmall"
                            android:textColor="#fff"
                            android:textSize="12sp"
                            android:typeface="sans" />


                        <TextView
                            android:id="@+id/lbl_agent_profile_ibaaxid"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:background="#33ffffff"
                            android:paddingBottom="1dp"
                            android:paddingEnd="3dp"
                            android:paddingLeft="3dp"
                            android:paddingRight="3dp"
                            android:paddingStart="3dp"
                            android:paddingTop="1dp"
                            android:text="iBaax ID : 123456789"
                            android:textAppearance="?android:attr/textAppearanceSmall"
                            android:textColor="#fff"
                            android:textSize="12sp"
                            android:typeface="sans" />
                    </LinearLayout>
                </RelativeLayout>

                <LinearLayout
                    android:id="@+id/lnr_img"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:padding="2dp"
                    android:background="#fff"
                    android:layout_marginLeft="10dp"
                    android:layout_marginStart="10dp"
                    android:layout_alignParentBottom="true"
                    android:layout_alignParentLeft="true"
                    android:layout_alignParentStart="true">

                    <ImageView
                        android:id="@+id/img_agent_profile_image"
                        android:layout_width="110dp"
                        android:layout_height="110dp"

                        android:scaleType="centerCrop"
                        android:src="@drawable/no_profile" />
                </LinearLayout>


                <Button
                    android:layout_width="wrap_content"
                    android:layout_height="22dp"
                    android:layout_below="@+id/backdrop"
                    android:layout_marginLeft="8dp"
                    android:layout_marginTop="8dp"
                    android:layout_toRightOf="@+id/lnr_img"
                    android:background="#4d6088"
                    android:paddingEnd="3dp"
                    android:paddingLeft="3dp"
                    android:paddingRight="3dp"
                    android:paddingStart="3dp"
                    android:text="Write Review"
                    android:textAllCaps="false"
                    android:textSize="12sp" />
            </RelativeLayout>

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/AppTheme.PopupOverlay" />

        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

我的活動的 OnCreate 方法中的代碼:

setContentView(R.layout.activity_agent_profile2);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);
    //getSupportActionBar().setTitle("Name");
    agent = (Agent) getIntent().getSerializableExtra("Agent");
    CollapsingToolbarLayout collapsingToolbar =
            (CollapsingToolbarLayout) findViewById(R.id.agent_profile_toolbar);
    collapsingToolbar.setTitle(agent.name);

我以某種方式修復了它。 我不知道為什么它會起作用。 我不得不為具有不同文本大小的 expandTitle 和 collapseTitle 提供單獨的樣式。 如果它們是相同的 textSizes 那么它會起作用。 下面是我的款式,

<style name="expandedappbar" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">20sp</item>
    <item name="android:textStyle">bold</item>
    <item name="android:ellipsize">end</item>
    <item name="android:maxLines">1</item>
    <item name="android:width">100dp</item>
</style>
<style name="collapseappbar" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">18sp</item>
    <item name="android:textStyle">bold</item>
</style>

和布局:

<android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/agent_profile_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginBottom="87dp"
            app:expandedTitleMarginStart="130dp"
            app:expandedTitleTextAppearance="@style/expandedappbar"
            app:collapsedTitleTextAppearance="@style/collapseappbar"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

並截圖證明它有效,

固定

請為菜單項添加選項菜單,不會出現重疊問題

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.option_menu, menu);
    return true; 
}

並設置actionBar在活動onCreate

setSupportActionBar(toolbar)

option_menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
 
    <item
        android:id="@+id/bt_share"
        android:icon="@drawable/ic_send"
        android:title="@string/share"
        app:showAsAction="always" />

    <item
        android:id="@+id/bt_suggest_edit"
        android:icon="@drawable/ic_menu"
        android:title="@string/suggest_an_edit"
        app:showAsAction="always" />
</menu>

折疊的工具欄屏幕截圖

Collapsed toolbar screenshot

展開的工具欄截圖

Expanded toolbar screenshot

這行不通?

getSupportActionBar().setTitle("LongTitle");

我的解決方案是監聽CollapsingToolbarLayout折疊進度。 當它完全折疊時,我禁用AppBarLayout標題並將其設置為活動:

@Override
public void onAppBarOffsetChanged(AppBarLayout appBarLayout, int offset) {
    boolean collapsed = offset == appBarLayout.getTotalScrollRange();
    collapsingToolbarLayout.setTitleEnabled(!collapsed);
    getActivity().setTitle(collapsed ? title : null);
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM