我已经使用了viewpager
,当页面更改时,标题将根据位置进行更改。
这是我的代码onCreate()
setContentView(R.layout.activity_single_news);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
final ActionBar actionBar=getSupportActionBar();
if(actionBar!=null) {
actionBar.setDisplayHomeAsUpEnabled(true);
actionBar.setDisplayShowTitleEnabled(true);
}
ViewPager pager=findViewById(R.id.viewpager);
final ImageView actionbarImageview=findViewById(R.id.actionbar_news_image);
pager.setAdapter(new SingleNewsPagerAdapter(getSupportFragmentManager(), newslist));
int position=getIntent().getIntExtra("position", 0);
pager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
final NHBean news = newslist.get(position);
if (actionBar != null) {
actionBar.setTitle(news.getHeadline());
} else
Log.d("status", "actionbar is null");
new SetImageFromURL(actionbarImageview).execute(news.getImageUrl());
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
pager.setCurrentItem(position);
}
和XML文件
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 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="xyz.NewsActivity">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar"
android:layout_width="match_parent"
android:layout_height="@dimen/app_bar_height"
android:fitsSystemWindows="true"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/toolbar_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="?attr/colorPrimary"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:id="@+id/actionbar_news_image"
app:layout_collapseMode="parallax"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="fitXY"
android:src="@drawable/facebookshare"
/>
<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>
<android.support.v4.view.ViewPager
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/viewpager" />
</android.support.design.widget.CoordinatorLayout>
这是我的res/values/styles.xml
<resources>
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="AppTheme.NoActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
<style name="AppTheme.ActionBar.Transparent" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowActionBarOverlay">true</item>
<item name="android:windowContentOverlay">@null</item>
<item name="colorPrimary">@android:color/transparent</item>
<item name="colorPrimaryDark">@android:color/black</item>
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
</resources
最初,标题是
<string name="title_activity_news">News</string>
当我启动活动时,它将更改为此项目的标题。当页面更改时,
pager.setCurrentItem(position);
图像完全更改。但标题没有改变。imageview
不为空。有人能帮我吗?我尝试了所有与actionbar.setTitle()相关的帖子。不幸的是,我没有得到解决办法
最佳答案
解决方案1:您的代码是正确的。只需将这一行添加到折叠工具栏中的app:titleEnabled="false"
。
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/toolbar_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:titleEnabled="false"
app:contentScrim="?attr/colorPrimary"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
解决方案2:
final CollapsingToolbarLayout collapsingToolbarLayout = findViewById(R.id.toolbar_layout);
并在您的onpageselected中执行此操作:
if (collapsingToolbarLayout != null) {
collapsingToolbarLayout.setTitle(news.getHeadline());
}