android+多种行视图,android – 在CollapsingToolbarLayout而不是Title中的多行文本视图

如果要在

CollapsingToolbarLayout中进行自定义,则需要了解相关信息.在android项目中添加CollapsingToolbarLayout很容易.如果您使用的是

AndroidStudio,那么很容易添加.

只需右键单击com.project等软件包,选择New-> Activity-> ScrollingActivity并在项目中添加它.现在,您只需要对代码进行一些自定义.

转到你的样式文件并添加这两种风格: –

@android:color/white

11sp

@android:color/white

14sp

转到您的activity_scrolling.xml文件,并在CollapsingToolbarLayout中设置这两种样式.其他是在CollapsingToolbarLayout中添加TextView作为您的要求.像这样:-

xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:app="http://schemas.android.com/apk/res-auto"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:fitsSystemWindows="true"

tools:context="com.mailcollection.ScrollingActivity">

android:id="@+id/appBarLayout"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:fitsSystemWindows="true"

android:theme="@style/AppTheme.AppBarOverlay">

android:id="@+id/collapsingToolbar"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:fitsSystemWindows="true"

app:expandedTitleMarginEnd="64dp"

app:expandedTitleMarginStart="48dp"

app:collapsedTitleTextAppearance="@style/TextAppearance.MyApp.Title.Collapsed"

app:contentScrim="?attr/colorPrimary"

app:expandedTitleTextAppearance="@style/TextAppearance.MyApp.Title.Expanded"

app:layout_scrollFlags="scroll|exitUntilCollapsed">

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="left|bottom"

android:orientation="vertical"

android:padding="10dp"

android:layout_marginBottom="20dp"

app:layout_collapseMode="parallax">

android:id="@+id/tv_title"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_alignParentRight="true"

android:text="@string/app_name"

android:textSize="15sp"/>

android:id="@+id/tv_description"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_alignParentRight="true"

android:textSize="20sp"

android:text="@string/title_description"/>

android:id="@+id/toolbar"

android:layout_width="match_parent"

android:layout_height="?attr/actionBarSize"

app:layout_collapseMode="pin"

app:popupTheme="@style/AppTheme.PopupOverlay"/>

android:id="@+id/fab"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_margin="@dimen/fab_margin"

app:layout_anchor="@id/appBarLayout"

app:layout_anchorGravity="bottom|end"

app:srcCompat="@android:drawable/ic_dialog_email"/>

当您使用CollapsingToolbarLayout进行一些自定义时,您还需要在活动文件中实现一些自定义代码.

转到ScrollingActivity.java文件: –

public class ScrollingActivity extends AppCompatActivity {

CollapsingToolbarLayout collapsingToolbar;

AppBarLayout appBarLayout;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_scrolling);

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

setSupportActionBar(toolbar);

collapsingToolbar = (CollapsingToolbarLayout) findViewById(R.id.collapsingToolbar);

collapsingToolbar.setCollapsedTitleTextAppearance(R.style.TextAppearance_MyApp_Title_Collapsed);

collapsingToolbar.setExpandedTitleTextAppearance(R.style.TextAppearance_MyApp_Title_Expanded);

//This is the most important when you are putting custom textview in CollapsingToolbar

collapsingToolbar.setTitle(" ");

appBarLayout = (AppBarLayout) findViewById(R.id.appBarLayout);

appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {

boolean isShow = false;

int scrollRange = -1;

@Override

public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {

if (scrollRange == -1) {

scrollRange = appBarLayout.getTotalScrollRange();

}

if (scrollRange + verticalOffset == 0) {

//when collapsingToolbar at that time display actionbar title

collapsingToolbar.setTitle(getResources().getString(R.string.app_name));

isShow = true;

} else if (isShow) {

//carefull there must a space between double quote otherwise it dose't work

collapsingToolbar.setTitle(" ");

isShow = false;

}

}

});

}

}

如果要在CollapsingToolbarLayout中添加Multiline TextView而不是Title,这是完整的代码.我希望你会得到解决方案.

当您实现这样的代码时,不需要设置最小的CollapsingToolbar高度,它总是根据文本长度显示所有文本行.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值